SIGPIPE信号

对一个已经收到FIN包的socket调用read方法, 如果接收缓冲已空, 则返回0,
这就是常说的表示连接关闭. 但第一次对其调用write方法时, 如果发送缓冲没问题,
会返回正确写入(发送). 但发送的报文会导致对端发送RST报文,
因为对端的socket已经调用了close, 完全关闭, 既不发送, 也不接收数据. 所以,
第二次调用write方法(假设在收到RST之后), 会生成SIGPIPE信号, 导致进程退出.

为了避免进程退出, 可以捕获SIGPIPE信号, 或者忽略它,
给它设置SIG_IGN信号处理函数:

这样, 第二次调用write方法时, 会返回-1, 同时errno置为SIGPIPE.
程序便能知道对端已经关闭.

PS: Linux下的SIGALRM似乎会每1秒钟往后偏移1毫秒,
但Windows下经过测试完全准时, 不差1毫秒.

sigsegv 引起的core dumped

core中的问题:
sigsegv信号的产生是由于非法访问内存,而不是数组越界,数组小范围越界不会产生此问题,但是局部的数组变量,再访问越界的时候是会在函数退出时报错的。
全局的数组则不会报错信号的产生是由于非法访问内存,而不是数组越界,数组小范围越界不会产生此问题,但是局部的数组变量,再访问越界的时候是会在函数退出时报错的。
全局的数组则不会报错