我已经阅读了ping代码。而我对此代码感到困惑
*(u_char *)(&u) = *(u_char *)w ;
在这个函数中,我认为你的值为0,为什么再次赋值。
/*
* I N _ C K S U M
*
* Checksum routine for Internet Protocol family headers (C Version)
*
*/
in_cksum(addr, len)
u_short *addr;
int len;
{
register int nleft = len;
register u_short *w = addr;
register u_short answer;
register int sum = 0;
/*
* Our algorithm is simple, using a 32 bit accumulator (sum),
* we add sequential 16 bit words to it, and at the end, fold
* back all the carry bits from the top 16 bits into the lower
* 16 bits.
*/
while( nleft > 1 ) {
sum += *w++;
nleft -= 2;
}
/* mop up an odd byte, if necessary */
if( nleft == 1 ) {
u_short u = 0;
*(u_char *)(&u) = *(u_char *)w ;
sum += u;
}
/*
* add back carry outs from top 16 bits to low 16 bits
*/
sum = (sum >> 16) + (sum & 0xffff); /* add hi 16 to low 16 */
sum += (sum >> 16); /* add carry */
answer = ~sum; /* truncate to 16 bits */
return (answer);
}
答案 0 :(得分:2)
&u
是指向u
的指针。
(u_char *)(&u)
是指向u_char
的{{1}}指针。
u
取消引用指针,所以
*(u_char *)(&u)
将*(u_char *)(&u) = *(u_char *)w ;
的第一个字节复制到w
的第一个字节。第二个字节为零。
(假设,正如此代码的作者所做的那样,u
是16位宽。根据C标准,这不一定是真的。)