作者是ZX_WING(xing5820@163.com)
段错误的问题,天天都有人问,我以前也常常问,既然大牛写了个PDF,我就拜读了一下,并且在这里做个总结。
段错误的定义:
段错误就是说,访问了不允许访问的存储位置,或者访问的方式不对,例如写了只读的位置等。
程序访问一个会引发SIGSEGV 的地址时,硬件首先产生一个page fault,即“缺页异常”。在内核的page fault 处理函数中,首先判断该地址是否属于用户态程序的地址空间[*]。以Intel的32bit IA32 架构的CPU 为例,用户态程序的地址空间为[0,3G],内核地址空间为[3G,4G]。如果该地址属于用户态地址空间,检查访问的类型是否和该内存区域的类型是否匹配,不匹配,则发送SIGSEGV 信号;如果该地址不属于用户态地址空间,检查访问该地址的操作是否发生在用户态,如果是,发送SIGSEGV 信号。
未完