正确的填写IP地址是很重要的一个环节。所谓填写IP地址就是指在SOCKADDR_IN结构体中填写IP地址:
struct sockaddr_in {
short sin_family;
u_short sin_port;
struct in_addr sin_addr;
char sin_zero[8];
};
在这里已经定义了 &emsptypedef sockaddr_in SOCKADDR_IN 。该结构中的一个in_addr 结构体 sin_addr 考试大提示就是要填写的IP地址。in_addr 结构的定义如下(MSDN):
typedef struct in_addr {
union {
struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;
struct { u_short s_w1,s_w2; } S_un_w;
u_long S_addr;
} S_un;
} in_addr;
于是填写信息如下:
SOCKADDR_IN serverAdd;
unsigned long ipadd;
m_ServerIp.GetAddress( ipadd ); m_ServerIp 是一个CIPAddressCtrl 控件,用来读取IP地址
serverAdd.sin_family = AF_I; IP地址家族
serverAdd.sin_addr.s_addr = htonl(ipadd) ; 填写IP
serverAdd.sin_port = htons(m_ServerPort); 填写端口
这里的serverAdd.sin_addr.s_addr = htonl(ipadd) ; 引起了困惑,本应该是serverAdd.sin_addr.S_un.S_addr = htonl(ipadd) ; 这样才对嘛,怎么就直接访问union里面的成员呢S_addr(当时还没有看出大小写问题)? 发现s原来是小写的,呵呵,查看定义(winsock2.h):
struct in_addr {
union {
struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;
struct { u_short s_w1,s_w2; } S_un_w;
u_long S_addr;
} S_un;
&emspdefine s_addr S_un.S_addr
/* can be used for most tcp
不要定义只有大小写区分的变量如:
student, Student, 或者是只有s区别的如:student, students。
当时还不觉得什么,考试大提醒现在看起来真是太重要了?