• <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>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運轉,開心的工作
            簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            Addrinfo and Getaddrinfo

            Posted on 2010-07-02 08:22 S.l.e!ep.¢% 閱讀(922) 評論(0)  編輯 收藏 引用 所屬分類: VC

            Addrinfo and Getaddrinfo

            網 絡編程 2009-08-27 09:12:54 閱讀309 評論0 字號:

            gethostbyname和gethostbyaddr這兩個函數僅僅支持 IPv4,getaddrinfo函數能夠處理名字到地址以及服務到端口這兩種轉換,返回的是一個sockaddr結構的鏈表而不是一個地址清單。這些 sockaddr結構隨后可由套接口函數直接使用。如此以來,getaddrinfo函數把協議相關性安全隱藏在這個庫函數內部。應用程序只要處理由 getaddrinfo函數填寫的套接口地址結構。該函數在 POSIX規范中定義了。

            #include<netdb.h>
            int getaddrinfo( const char *hostname, const char *service, const struct addrinfo *hints, struct addrinfo **result );
            返回0:? 成功
            返回非0:? 出錯

            hostname: 一個主機名或者地址串(IPv4的點分十進制串或者IPv6的16進制串)
            service:一個服務名或者10進制端口號數串。
            hints: 可以是一個空指針,也可以是一個指向某個addrinfo結構的指針,調用者在這個結構中填入關于期望返回的信息類型的暗示。舉例來說:如果指定的服務既 支持TCP也支持UDP,那么調用者可以把hints結構中的ai_socktype成員設置成SOCK_DGRAM使得返回的僅僅是適用于數據報套接口 的信息。

            本函數通過result指針參數返回一個指向addrinfo結構鏈表的指針,而addrinfo結構定義在頭文件 netdb.h中:
            struct addrinfo{
            ??? int ?? ?? ai_flags;??
            ??? int ?? ?? ai_family;
            ??? int ?? ?? ai_socktype;
            ??? int ?? ?? ai_protocol;
            ??? socklen_t ai_addrlen;
            ??? char ?? *ai_canonname;
            ??? struct sockaddr *ai_addr;
            ??? struct addrinfo *ai_next;
            };

            如 果本函數返回成功,那么由result參數指向的變量已被填入一個指針,它指向的是由其中的ai_next成員串聯起來的addrinfo結構鏈表。可以 導致返回多個addrinfo結構的情形有以下2個:
            ??? 1.??? 如果與hostname參數關聯的地址有多個,那么適用于所請求地址簇的每個地址都返回一個對應的結構。
            ??? 2.??? 如果service參數指定的服務支持多個套接口類型,那么每個套接口類型都可能返回一個對應的結構,具體取決于hints結構的ai_socktype 成員。

            我們必須先分配一個hints結構,把它清零后填寫需要的字段,再調用getaddrinfo然后遍歷一個鏈表逐個嘗試每個返回地 址。

            getaddrinfo解決了把主機名和服務名轉換成套接口地址結構的問題。

            其中,如果getaddrinfo出 錯,那么返回一個非0的錯誤值。

            #include<netdb.h>
            const char *gai_strerror( int error );
            該函數以getaddrinfo返回的非0錯誤值的名字和含義為他的唯一參數,返回一個 指向對應的出錯信息串的指針。

            由getaddrinfo返回的所有存儲空間都是動態獲取的,這些存儲空間必須通過調用 freeaddrinfo返回給系統。
            #include< netdb.h >
            void freeaddrinfo( struct addrinfo *ai );

            ai參數應指向由getaddrinfo返回的第一個addrinfo結構。這個連表中的 所有結構以及它們指向的任何動態存儲空間都被釋放掉。


            例子:
            struct addrinfo *host_serv( const char *host, const char *serv, int family, int socktype )
            {
            ??? int n;
            ??? struct?? addrinfo? hints,? *res;

            ??? bzero( &hints, sizeof(struct addrinfo) );
            ??? hints.ai_flags = AI_CANONNAME;
            ??? hints.ai_family = family;
            ??? hints.ai_socktype = socktype;

            ??? if( (n = getaddrinfo( host, serv, &hints, &res ) ) != 0 )
            ??? ?? return (NULL);

            ??? return ( res );
            }
            青青草原综合久久大伊人| 亚洲色欲久久久综合网东京热 | 一本色道久久88综合日韩精品 | 久久久91人妻无码精品蜜桃HD| 九九热久久免费视频| 亚洲AⅤ优女AV综合久久久| 亚洲综合熟女久久久30p| 久久er国产精品免费观看2| 久久综合亚洲色HEZYO国产| 男女久久久国产一区二区三区| 久久天堂电影网| 无码任你躁久久久久久老妇| 无码人妻少妇久久中文字幕蜜桃| 麻豆精品久久精品色综合| 亚洲精品国产自在久久| 久久综合狠狠综合久久综合88| 99久久精品九九亚洲精品| 久久国产色av免费看| 久久久久国产精品麻豆AR影院 | 亚洲国产成人精品无码久久久久久综合 | 久久人人爽人人爽人人片AV东京热| 久久国产AVJUST麻豆| 国产成人香蕉久久久久| 久久久久人妻精品一区| 亚洲人成无码久久电影网站| 精品久久久久一区二区三区| 国产精品美女久久久m| 久久妇女高潮几次MBA| 久久婷婷午色综合夜啪| 久久国产香蕉一区精品| 久久国产精品成人免费| AV无码久久久久不卡蜜桃| 日批日出水久久亚洲精品tv| 国产激情久久久久影院小草| 高清免费久久午夜精品| 无码人妻久久一区二区三区免费| 久久婷婷人人澡人人| 精品欧美一区二区三区久久久| 99久久精品国产一区二区蜜芽| 人人狠狠综合久久88成人| 色欲综合久久躁天天躁蜜桃|