• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            Socket學習筆記之二(常用基本函數)

            函數:
            u_long htonl(u_long hostlong)
            u_short htons(u_short hostshort)
            u_long ntohl(u_long netlong)
            u_short ntohs(u_short netshort)

            這上面四個函數類似,功能相似,都用來轉換數據格式。用來實現處理器中short,long數據類型與網絡中的轉換。在網絡中傳輸均以字節為單位(除了bit外就是最小的單位了)。一個short占兩字節,一個long占四個字節。一個short從一臺機子傳到另外一臺機子上要能夠還原,則必須統一規定高低字節順序。在TCP/IP協議規范中short的高位在低字節,低位在高字節。這與有些處理器中或者系統中表示不一樣。例如在windows中:
            ?unsigned short hs = 0x0102;
            ?unsigned short ns = htons( hs );
            ?printf( "0x%04x",ns);//ns:0x0201
            所以對于網絡端口等數據在使用前必須進行統一,例如
            unsigned short port = 2088;
            m_sockaddr.sin_port = htons( port );
            等等。這四個函數,我開始不知道為什么取這些名字總是記不住,后來想明白了
            htons表示host to net short,ntohs表示net to host short
            htonl表示host to net long,ntohl表示net to host long
            這樣不需要刻意去記也就明白了。

            unsigned long inet_addr(const char* cp);
            char* FAR inet_ntoa(struct in_addr in);

            這兩個函數用來把表示ip地址的字符串(如:202.114.14.12)跟表示ip的long或者結構之間轉換。
            inet_addr得到的是已經統一字節順序的,可以直接賦值給in_addr里的s_adr,例如:
            ?char *pHost = "202.114.14.12"
            ?m_sockaddr.sin_addr.s_addr?=?inet_addr( pHost );

            int WSAStartup(WORD wVersionRequested,LPWSADATA lpWSAData);
            加載winsock庫。返回0表示成功,非0表示錯誤。第一個參數是版本號,現在最高版本是2.2版,不過Win CE好像只支持1.1版,高位字節表示副版本號,低位字節表示高版本號,所以這里一般就是0x0202或者0x0101或者使用宏定義MAKEWORD(2,2)或者MAKEWORD(1,1),第二個參數是一個與winsock庫信息有關的結構,一把不用去管它。在使用winsock前,都必須加載,一般在程序初始化時候做這個事情。一般使用如下:
            ?WSADATA data;
            ?if ( WSAStartup(0x0202,&data) != 0 )
            ?{
            ??printf("error id: %d",GetLastError());
            ?}
            上面的GetLastError()是使用非常頻繁的函數。很多函數的返回值得意義都是表示函數執行是否出錯。當winsock的函數發生錯誤時,用GetLastError()可以得到最后一次發生錯誤的錯誤號。在.Net中有個工具:查找錯誤,輸入錯誤號,得到錯誤信息。

            int gethostname(char* name,int namelen);
            獲取主機名。輸入參數為緩沖區地址和大小。
            struct hostent* FAR gethostbyname(const char* name);
            由主機名得到主機信息,可以用來解析域名。需要注意的是MSDN中的一段話“The application must never attempt to modify this structure or to free any of its components. Furthermore, only one copy of this structure is allocated per thread, so the application should copy any information it needs before issuing any other Windows Sockets function calls”這說明了一般用法的時候,要把數據拷貝出來,看看下面代碼:
            ?char???name[255];
            ?PHOSTENT??phostinfo;
            ?PHOSTENT??phostinfo1;
            ?WSADATA data;
            ?struct in_addr** addrPtr;
            ?struct in_addr** addrPtr1;

            ?if ( WSAStartup(0x0202,&data) != 0 )
            ?{
            ??printf("error id: %d",GetLastError());
            ?}

            ?if( gethostname ( name, sizeof(name)) == 0)
            ?{
            ??printf("%s",name);
            ??if((phostinfo = gethostbyname(name)) != NULL)
            ??{
            ???for (addrPtr = (struct in_addr **)phostinfo->h_addr_list;*addrPtr;addrPtr++)
            ???{//顯示我機子的ip
            ????printf("%s\n", inet_ntoa(**addrPtr));
            ???}
            ??}
            ??else
            ???printf("error id : %d",GetLastError());
            ?}
            ?else
            ?{
            ??printf("error id :%d",GetLastError());
            ?}

            ?if((phostinfo1 = gethostbyname("bbs.whnet.edu.cn")) != NULL)
            ?{
            ??for (addrPtr1 = (struct in_addr **)phostinfo->h_addr_list;*addrPtr1;addrPtr1++)
            ??{//顯示bbs.whnet.edu.cn的ip:202.114.0.248
            ???printf("%s\n", inet_ntoa(**addrPtr1));
            ??}
            ?}
            ?else
            ??printf("error id : %d",GetLastError());

            ?for (addrPtr = (struct in_addr **)phostinfo->h_addr_list;*addrPtr;addrPtr++)
            ?{//在這里顯示的是bbs.whnet.edu.cn的ip:202.114.0.248,不是我機子的ip
            ??printf("%s\n", inet_ntoa(**addrPtr));
            ?}

            struct HOSTENT* FAR gethostbyaddr(const char* addr,int len,int type);
            根據ip地址得到主機信息。這里的ip必須是網絡字節順序的。示例代碼:
            ?PHOSTENT phostinfo2;
            ?unsigned long ip = inet_addr("127.0.0.1");
            ?if ( (phostinfo2 = gethostbyaddr((char*)&ip,sizeof(ip),AF_INET)) != NULL)
            ?{//顯示localhost
            ??printf("host name : %s",phostinfo2->h_name );
            ?}
            ?else
            ??printf("error id : %d",GetLastError());

            int getsockname(SOCKET s,struct sockaddr* name,int* namelen);
            這個函數用來的得到socket的本地地址,但是前提是socket必須已經bind或者已經是連接上的。如果socket不是面向連接的話,比如udp,那得socket上有數據才行。
            int getpeername(SOCKET s,struct sockaddr* name,int* namelen);
            這個函數用來得到socket那一邊上的地址,顯然socket必須得連接上?!癟he getpeername function can be used only on a connected socket. For datagram sockets, only the name of a peer specified in a previous connect call will be returned—any name specified by a previous sendto call will not be returned by getpeername.”

            至于bind,listen,accept,recv,send等后面學select模型的時候再仔細研究。



            Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=551760

            posted on 2006-04-20 17:27 楊粼波 閱讀(852) 評論(0)  編輯 收藏 引用 所屬分類: 網絡編程

            国产精品久久久久久久久| 久久精品免费大片国产大片| 精品国际久久久久999波多野| 国产一久久香蕉国产线看观看| 久久国产精品免费| 漂亮人妻被黑人久久精品| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲国产一成久久精品国产成人综合| 久久久久久久久久久久久久| 91久久精品无码一区二区毛片| 无码人妻少妇久久中文字幕蜜桃| 免费国产99久久久香蕉| 色综合久久久久无码专区| 久久久久亚洲爆乳少妇无| 久久亚洲AV成人出白浆无码国产| 亚洲午夜无码AV毛片久久| 成人国内精品久久久久影院VR| 亚洲AV无一区二区三区久久| 亚洲成av人片不卡无码久久| 久久99精品久久久久久水蜜桃| 国产精品18久久久久久vr| 久久精品国产亚洲av麻豆小说| 亚洲色婷婷综合久久| 青青青青久久精品国产h久久精品五福影院1421| 亚洲国产一成人久久精品| 一本色道久久88精品综合| 久久精品久久久久观看99水蜜桃| 亚洲精品无码久久不卡| 亚洲人成无码久久电影网站| 久久久久亚洲AV综合波多野结衣| 久久国产视频网| 亚洲国产成人久久笫一页| 天堂无码久久综合东京热| 2021国内精品久久久久久影院| 亚洲乱码日产精品a级毛片久久| 天天影视色香欲综合久久| 婷婷久久综合| 久久久精品人妻一区二区三区四 | 亚洲国产香蕉人人爽成AV片久久| 伊色综合久久之综合久久| 亚洲日本va中文字幕久久|