首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在Linux上获得错误核心转储

今天小编要跟大家分享文章是关于Linux错误核心转储问题。喜欢Linux操作系统,对Linux感兴趣小伙伴快来看一看吧,希望通过本篇文章能够有所收获。 首先我们来说一说什么是错误?...“错误(segmentation fault)”是指你程序尝试访问不允许访问内存地址情况。...这个“C++ 虚表指针”是我程序发生错误情况。我可能会在未来博客中解释这个,因为我最初并不知道任何关于 C++ 知识,并且这种虚表查找导致程序错误情况也是我所不了解。...当您程序出现错误Linux 内核有时会把一个核心转储写到磁盘。 当我最初试图获得一个核心转储时,我很长一时间非常沮丧,因为 – Linux 没有生成核心转储!我核心转储在哪里?.... $ gdb -c my_core_file 接下来,我们想知道程序崩溃时堆栈是什么。在 gdb 提示符下运行 bt 会给你一个调用序列(backtrace)。

3.9K20

如何优雅调试错误

摘要:当程序运行出现错误时,目标文件没有调试符号,也没配置产生 core dump,如何定位到出错文件和函数,并尽可能提供更详细一些信息,如参数,代码等。.../a.out Segmentation fault (core dumped) 可以看到发生了错误。...),我们可以用一 python 代码来找到出错代码偏移量,如下: $ python3 -c "print((0x00007f93d96cf3cc-0x7f93d9674000).to_bytes(4...整行代码意思要把 rdi 寄存器某个偏移处数据复制给 eax 寄存器,前面我们知道引起错误原因是 用户态程序,读内存越界,原因是非法地址,而不是没权限,所以就是说读取 0xc0(%rdi) 发生错误...= -1) return -1 看函数名感觉是判断当前流 FILE 是否是宽字节流,推测是从 FILE 结构里取信息,结果 FILE 结构地址非法,所以内存读取错误,直接就错误了。

4.3K52
您找到你想要的搜索结果了吗?
是的
没有找到

Linux

Linux Intel 微处理器机制是从8086 开始提出, 那时引入机制解决了从CPU 内部 16 位地址到20 位实地址转换。...这不仅简化了Linux 内核设计,而且为把Linux 移植到其他平台创造了 条件,因为很多RISC 处理器并不支持机制。但是,对机制相关知识了解是进入Linux 内核必经之路。...linuxGDT Linux 在启动过程中设置了寄存器值和全局描述符表GDT 内容,定义在include/asm-i386/segment.h 中: #define __KERNEL_CS...只不过,Linux机制变得相当简单,它只把分为两种:用户态(RPL =3)和内核态(RPL=0)。...Linux 这样设计所带来好处是显而易见,Intel 部件对Linux 性能造成影响可以忽略不计。

4.5K20

Linux笔记(15)| Linux信号

今天要分享Linux信号机制,信号是一种软件中断,是一种处理异步事件方法,可以很好地在多个进程之间进行同步和简单数据交换。...二、信号注册和响应 前面讲了三种发送信号方式,但是光发送信号还不够,对于接收方来说,还得对信号进行处理。 一般可以使用signal函数和sigaction函数来注册信号。...signal函数第一个参数是信号类型,第二个参数是函数指针,也就是跳转到哪里去执行。也就是说,当收到第一个参数表示信号之后,就会跳转到第二个参数指向代码去执行。...成员sa_sigaction 则是另一个信号处理函数,它有三个参数,可以获得关于信号更详细信息。...接下来写一个简单代码,来应用一下上面的几个函数。实现需求就是创建一个子进程,父进程每隔一秒钟向子进程发送一个信号,子进程收到信号之后往一个txt文档中写入一句话。

2.5K10

常见C编程错误及对策

再有一点就是,参数出现错误并非本函数有问题,而是调用者传过来实参有问题。assert 宏可以帮助我们定位错误,而不是排除错误。...二、为指针分配内存太小 为指针分配了内存,但是内存大小不够,导致出现越界错误。...五、内存泄漏 内存泄漏几乎是很难避免,不管是老手还是新手,都存在这个问题。甚至包括windows,Linux 这类软件,都或多或少有内存泄漏。...也就是说,在程序中malloc 使用次数一定要和free 相等,否则必有错误。这种错误主要发生在循环使用malloc 函数时,往往把malloc 和free 次数弄错了。...解决办法是重新设计程序,改善对象之间调用关系。 上面详细讨论了常见六种错误及解决对策,希望读者仔细研读,尽量使自己对每种错误发生原因及预防手段烂熟于胸。

1.4K40

LinuxSIGCHLD信号

那么这两个操作对于父进程来说都不是理想,因此可以通过SIGCHLD信号来实现异步操作。...也就是当子进程结束时候通过SIGCHLD信号告诉父进程,然后父进程再去释放其资源,如果没有收到该信号也不影响父进程运行。        ...子进程处在停止态,接受到SIGCONT后唤醒时        下面我们通过示例来进一步详细说明,我们实现一个父进程来创建10个子进程,然后通过捕捉信号来实现上述所说功能。...首先我们需要考虑,当我们创建子进程时候,如果父进程还没有定义捕捉函数子进程就结束了,那么这个子进程就变为了僵尸进程,所以在定义捕捉函数之前需要先将SIGCHLD信号进行阻塞,在定义捕捉函数后再去UNBLOCK...,就可以捕捉到子进程信号了。

4.2K10

错误等造成死机问题分析

这种方法效率低,而且有时不准确,比如一个系统中有多个进程,但A进程跑B断点是,出现错误,系统发出11号信号,造成B,C等进程接到11号信号反初始化而推出。...注意该进程以及改进程所在库编译是必需加-g ,也不能strip,否则反汇编出来没有C代码映射行 如果是在内核空间,可以通过堆栈回溯法进程回溯。该方法需要熟悉汇编,其次需要耐心,这里不详述。...堆栈回溯法出来OOPS   通过反汇编,然后堆栈回溯,找到出问题函数,该方法需要熟悉汇编,其次需要耐心,这里不详述。...方法三:coredump分析法 对于死机问题,某些情况下OOPS打印出来信息不足以分析。coreDump给了个详细方法。...首先在内核当中打开coredup  开关,死机后就会产生一个core问题,事后可以通过 gdb调试方法来分析定位死机位置。

1.2K20

由于版本依赖造成YUM错误

查了一些资料,大体上说是由于Zlib版本造成。查看了一下,发现最近确实安装了zlib1.2.5版本,而造成了YUM依赖问题。...尝试重新编译安装了zlib1.2.3,但是结果还是错误。...仔细一看,发现zlib其实并没有将so安装到/usr/local/lib目录下,在/usr/lib下搜索了一下,找到了这个so,不清楚是什么时候安装,拷贝到/usr/local/lib目录下,然后重新进行了一次编译安装...总结:问题应该出在zlib版本更新上,但是应该和zlib软件本身代码没什么关系,只是在软链接配置上改变,对yum造成了影响。...参考资料: 1、yum segmentation fault in centos 2、YUM错误Centos Segmentation Fault @import url(http://www.cnblogs.com

1.2K20

Linux】进程信号 --- 信号产生 保存 捕捉递达

还有一个接口是abort,这个接口就是什么参数都不用传,它会自动给异常进程发送信号SIGABRT,默认处理动作就是终止该进程,abort有中止意思。...道理不就和信号类似吗,异常意义也不在于异常处理结果上,而是程序员能够通过异常种类代表产生错误不同事件来判定出程序错误所在。...云服务器默认关闭了core file选项,所以当发生越界访问也就是错误时,不会触发核心转储,核心转储实际上是将出现异常进程二进制数据转移存储到磁盘上,此时就会生成一个名为core.xxxxx普通文件...行出现了错误。...在了解上面与信号有关库函数接口以及系统调用接口之后,我们可以来实现一代码,我们想屏蔽一下2,3号信号,此时向进程发送对应信号信号一定是不被递达,但是pending位图中第2和第3个比特位一定被置为

1.5K10

如何读取Linux进程中代码和数据

Linux程序文件格式是ELF,里面分了各种,有代码、数据、等。当运行这个程序时,系统也会给这个进程创建虚拟内存,然后把ELF中数据分别加载到内存中对应位置。...本文整理了用cpp程序读取内存中代码和rodata数据方法。...这个文件前三列分别是代码、rodata数据、和普通数据,可以看到代码权限是读和执行,rodata数据是只读,普通数据可读写。...用程序读取内存代码和rodata数据 以tcpdump程序为例,用程序读取代码和radata过程如下: 1.查看tcpdump进程ID。...2.运行自己写程序,分别输入进程PID和代码地址。

3.4K20

错误之memset对类对象误用

,使用memset将对象实体置为0之后,在使用delete析构该对象,就会出现莫名其妙错误。...错误是指访问内存超出了系统给这个程序所设定内存空间,考虑到导致错误常见两种情况是: (1)访问系统保护内存地址,如向地址0写入数据。 (2)内存越界,如数组越界。...当然还有其他情况,如访问了不存在内存地址。总而言之,错误出现是因为对内存空间不正确操作。...基于对错误理解,本以为是对 dicOriTask处理过程中有不正确操作,但是几经周折排查后并未发现错误,莫名其妙,原来问题很简单。是memset对类对象误用。...这就是使用memset对类对象误用。即delete一个被 memset为空带有虚函数类对象指针时,就会出现错误

1.4K10

Linux】详解信号分类&&如何自定义信号作用

一、信号定义         Linux系统提供让用户(进程)给其他进程发送异步信息一种方式。在操作系统中,信号是一种进程间通讯有限制方式,主要用于提醒进程某个事件已经发生。...操作系统要可以对信号进行如下两个操作: 操作系统能够识别一个信号并对该信号进行处理。 因为信号是异步产生,所以操作系统要能够对到来信号进行临时保存。...二、信号分类 kill -l//查看系统中所存在信号 我们可以看到每一个信号对应一个信号和一个宏名称,以后我们给进程发送信号既可以采用发送数字形式也可以采用发送宏名称方式。 ...三、自定义信号处理方式         如果我们不对收到信号做自定义处理方式,那该信号就会按默认方式进行处理。...自定义信号处理方式在我理解中有两种,一种是让收到该信号进程处理我交给它任务,另外一种是忽略该收到信号,下面我会对这两种方式进行简单演示。

500

linux | kill命令详解以及linux信号

简介# kill命令很容易让人产生误解, 以为仅仅是用来终止linux进程....支持信号# [root@lvbibir ~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5)..., 在这些信号中只有9) SIGKILL可以无条件地终止process, 其他信号都将依照process中定义信号处理规则来进行忽略或者处理....上述信号中常用其实很少, 如下表所示 编号 名称 解释 1 SIGHUP 启动被终止程序, 也可以让进程重新读取自己配置文件, 类似重新启动 2 SIGINT 相当于输入 ctrl-c 来中断一个程序...常用命令# 以正常方式终止进程, 由于信号15是最常用也是最佳程序退出方式, 所以 kill 命令不指定信号时, 默认使用就是信号 15 kill pid # 或者 kill -15 pid 强制终止进程

2.5K60

linux系统编程之信号(四):信号捕捉与sigaction函数

一、内核如何实现信号捕捉 如果信号处理动作是用户自定义函数,在信号递达时就调用这个函数,这称为捕捉信号。由于信号处理函数代码是在用户空间,处理过程比较复杂,举例如下: 1....signo是指定信号编号。若act指针非空,则根据act修改该信号处理动作。若oact指针非空,则通过oact传出该信号原来处理动作。...当某个信号处理函数被调用时,内核自动将当前信号加入进程信号屏蔽字,当信号处理函数返回时自动恢复原来信号屏蔽字,这样就保证了在处理某个信号时,如果这种信号再次产生,那么它会被阻塞到当前处理结束为止。...()实现; 《Linux 多线程应用中如何编写安全信号处理函数》 http://www.ibm.com/developerworks/cn/linux/l-cn-signalsec/ 参考:《APUE...》、《linux c 编程一站式学习》

3K00

linux信号保存和递达处理

上节我们了解到了预备(信号是什么信号基础知识)再到信号产生(四种方式)。今天我们了解信号保存。...被阻塞信号产生时将保持在未决状态,直到进程解除对此信号阻塞,才执行递达动作。我们之前知道,进程递达之后动作有三种:默认动作、自定义动作、忽略动作(执行动作,只不过这个动作就是什么都不做)。...---- 二、信号保存         我们知道信号是保存到进程pcb中信号产生、信号递达、信号阻塞、信号未决这些到底怎么实现呢?...---- 2.3 用户态和内核态         信号产生时,进程可能不会立马去处理,而是等待合适时机,那么这个合适时机是什么时候呢?是从内核态返回到用户态!哦吼,那什么是用户态和内核态呢?...(信号处理细节)         当信号正在被递达中,又来了同类型信号,此时当前信号会被加入到进程信号屏蔽字,且会将pending中该信号对应那一位由0变为1。

14320

Linux 进程间通信:信号

由于其叫法中包含“信号”这个关键字,所以容易跟另一个信号signal搞混。在这里首先强调一下,Linux系统中semaphore信号量和signal信号是完全不同两个概念。...但是从本质上讲,信号量实际上是实现了一套可以实现类似锁功能原语,我们不仅可以用它实现锁,还可以实现其它行为,比如经典PV操作。 Linux环境下主要实现信号量有两种。...如果当前有进程使用sem_wait等待此信号量,POSIX可以允许有两种返回,一种是返回0,另一种是返回一个负值,这个负值绝对值就是等待进程个数。Linux默认实现是返回0。...这里要注意是,一个命名信号量在用sem_close关闭之后,还要使用sem_unlink删除其文件名,才算彻底被删除。 匿名信号量: 一个匿名信号量仅仅就是一内存区,并没有一个文件名与之对应。...另外要注意是,这些程序在编译时候需要加额外编译参数-lrt和-lpthread。 最后 希望这些内容对大家进一步深入了解Linux信号量。

6.5K01

尘封中国 Linux 往事

按照章文嵩对Julian描述说法,Julian写程序非常厉害,但也很神秘,两个人一直通过邮件联系,即便时间已经过去二十多年,两人至今仍然没见过面,却始终维持着一基于开源信仰珍贵友谊。...他也不是凡人,而是Linux中文化最积极推动者,也是水木清华BBS Linux斑竹(即版主),名叫方汉。...他们一起解决了很多Linux中文化问题,在圈内一时有了“中文Linux三剑客”名头。...两家公司为争夺Linux中文化战略高地打的天翻地覆,对外都在使劲推自己Linux中文化技术,在市场上也相互攻讦。...在使用Linux时,他发现Linux很好用,唯一忍受不了是其复杂且不成熟图形界面系统X Window。

1.2K10
领券