在自学Linux C 网络编程时,经过实验发现一个问题。

 
  
  1. int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen) 

大部分资料对于accept函数第三个参数的描述如下:

连线成功时,参数addr所指的结构会被系统填入远程主机的地址数据,参数addrlen为scokaddr的结构长度。

亦即指针addrlen为从申请连接的客户机socket获取的数据长度。

但实验时发现,如果将addrlen指针所指向的值中的数据不初始化或初始化为一个小于sizeof(struct sockaddr)的值时,所获取的客户机地址就会出现错误。

官方关于accept的*addrlen参数解释如下:

The addrlen argument is a value-result argument: the caller  must  initialize  it  to contain the size (in bytes) of the structure pointed to by addr; on return it will contain the actual size of the peer address.

也就是说,这里的addrlen所指向的值,是必须初始化的,而且要初始化为一个大于等于实际获取socket的数据长度的值,而accept函数在执行后,会将实际值赋给addrlen所指向的值,故如果期望值小于实际值,所获取的数据在存储时就会发生溢出,读取时所得值便产生了错误。

看来遇到问题多看看官方文档还是很有用的,不要怕语言不行,看看总会懂得。