今天上班的时候,这个 segmentation fault 困扰了我半天,调试了半天就是不知道问题在哪,于是愤愤的下班了,晚饭都没吃好。不过饭后坐下来,仔细想了想,想到以下办法快速定位出错的语句。方法如下:
在介绍这个方法之前,先让我扯会蛋。首先先简单说一下这个 segmentation fault 产生的过程 (个人理解)。segmentation fault 一般是指内存的非法访问。是由CPU硬件首先产生缺页异常,然后转到linux内核事先安装好的异常处理程序,在这里内核会检查下缺页异常产生的原因。如果是由于内核只是已经答应给应用程序分配该地址指向的内存,但是还没有实际分配(也就是还没有创建页表项),那么内核会说“不好意思哈,我现在给你分配这块内存”。然后分配完这块内存之后,应用程序返回用户空间之后,会继续执行刚刚产生缺页异常的那条语句,由于这时候内核已经创建了相应的页表项,这次就不会再产生缺页异常了。整个过程在应用程序看来,好像就没有缺页异常这回事。这样并不奇怪,内核总是在最后迫不得已的时候才肯真正将内存分配出来的(懒内核