• <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>
            隨筆 - 96  文章 - 255  trackbacks - 0
            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            E-mail:zbln426@163.com QQ:85132383 長(zhǎng)期尋找對(duì)戰(zhàn)略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關(guān)網(wǎng)站

            我的個(gè)人網(wǎng)頁(yè)

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 493132
            • 排名 - 39

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            作者:龍飛

                    現(xiàn)在,我們通過(guò)accept()創(chuàng)建了新的socket,也就是我們類中的數(shù)據(jù)成員communicationSock,現(xiàn)在,我們就可以通過(guò)這個(gè)socket進(jìn)行通訊了。

            TCP通訊模型

                    在介紹函數(shù)之前,我們應(yīng)該了解一些事實(shí)。TCP的Server/Client模型類似這樣:
            ServApp——ServSock——Internet——ClntSock——ClntApp
            當(dāng)然,我們這里的socket指的就是用于“通訊”的socket。TCP的server端至少有兩個(gè)socket,一個(gè)用于監(jiān)聽(tīng),一個(gè)用于通訊;TCP的server端可以只有一個(gè)socket,這個(gè)socket同時(shí)“插”在server的兩個(gè)socket上。當(dāng)然,插上listen socket的目的只是為了創(chuàng)建communication socket,創(chuàng)建完備后,listen是可以關(guān)閉的。但是,如果這樣,其他的client就無(wú)法再連接上server了。
                    我們這個(gè)模型,是client的socket插在server的communication socket上的示意。這兩個(gè)socket,都擁有完整的本地地址信息以及遠(yuǎn)程計(jì)算機(jī)地址信息,所以,這兩個(gè)socket以及之間的網(wǎng)絡(luò)實(shí)際上形成了一條形式上“封閉”的管道。數(shù)據(jù)包只要從一端進(jìn)來(lái),就能知道出去的目的地,反之亦然。這正是TCP協(xié)議,數(shù)據(jù)流形式抽象化以及實(shí)現(xiàn)。因?yàn)椴辉傩枰该?#8220;出處”和“去向”,對(duì)這樣的socket(實(shí)際上是S/C上的socket對(duì))的操作,就如同對(duì)本地文件描述符的操作一樣。但是,盡管我們可以使用read()和write(),但是,為了完美的控制,我們最好使用recv()和send()。

            recv()和send()
            int send(int socket, const void* msg, unsigned int msgLength, int flags);
            int recv(int socket, void* rcvBuffer, unsigned int bufferLength, int flags);
            在Linux中的實(shí)現(xiàn)為:
            #include <sys/socket.h>

            /* Send N bytes of BUF to socket FD.  Returns the number sent or -1.

               This function is a cancellation point and therefore not marked with
               __THROW.  
            */
            extern ssize_t send (int __fd, __const void *__buf, size_t __n, int __flags);

            /* Read N bytes into BUF from socket FD.
               Returns the number read or -1 for errors.

               This function is a cancellation point and therefore not marked with
               __THROW.  
            */
            extern ssize_t recv (int __fd, void *__buf, size_t __n, int __flags);
            這兩個(gè)函數(shù)的第一個(gè)參數(shù)是用于“通訊”的socket,第二個(gè)參數(shù)是發(fā)送或者接收數(shù)據(jù)的起始點(diǎn)指針,第三個(gè)參數(shù)是數(shù)據(jù)長(zhǎng)度,第四個(gè)參數(shù)是控制符號(hào)(默認(rèn)屬性設(shè)置為0就可以了)。失敗時(shí)候傳回-1,否則傳回實(shí)際發(fā)送或者接收數(shù)據(jù)的大小,返回0往往意味著連接斷開(kāi)了。

            處理echo行為
            void TcpServer::handleEcho()
            {
                
            const int BUFFERSIZE = 32;
                
            char buffer[BUFFERSIZE];
                
            int recvMsgSize;
                
            bool goon = true;

                
            while ( goon == true ) {
                    
            if ( (recvMsgSize = recv(communicationSock, buffer, BUFFERSIZE, 0)) < 0 ) {
                        
            throw "recv() failed";
                    } 
            else if ( recvMsgSize == 0 ) {
                        goon 
            = false;
                    } 
            else {
                        
            if ( send(communicationSock, buffer, recvMsgSize, 0!= recvMsgSize ) {
                            
            throw "send() failed";
                        }
                    }
                }

                close(communicationSock);
            }
            本小節(jié)最后要講的函數(shù)是close(),它包含在<unistd.h>中
            #include <unistd.h>

            /* Close the file descriptor FD.

               This function is a cancellation point and therefore not marked with
               __THROW.  
            */
            extern int close (int __fd);
            這個(gè)函數(shù)用于關(guān)閉一個(gè)文件描述符,自然,也就可以用于關(guān)閉socket。
            下一小節(jié)是完整的源代碼。默認(rèn)的監(jiān)聽(tīng)端口是5000。我們可以通過(guò)
            $telnet 127.0.0.1 5000
            驗(yàn)證在本機(jī)運(yùn)行的echo server程序。
            posted on 2008-07-16 12:26 lf426 閱讀(8141) 評(píng)論(2)  編輯 收藏 引用 所屬分類: SDL入門(mén)教程Linux與C++socket 編程入門(mén)教程

            FeedBack:
            # re: socket 編程入門(mén)教程(一)TCP server 端:7、接收與發(fā)送 2010-10-16 16:43 莉薩
            樓主有筆誤哦. TCP通訊模型第二段:

            TCP 的server端可以只有一個(gè)socket,這個(gè)socket同時(shí)“插”在server的兩個(gè)socket上。

            這里應(yīng)該是: TCP的 client端可以只有一個(gè)......  回復(fù)  更多評(píng)論
              
            # re: socket 編程入門(mén)教程(一)TCP server 端:7、接收與發(fā)送 2010-10-16 16:50 莉薩
            這段貌似沒(méi)有前幾段寫(xiě)的詳細(xì)了呢...在描述send 和recv函數(shù)中有這樣一句話:

            "這兩個(gè)函數(shù)的第一個(gè)參數(shù)是用于“通訊”的socket"

            這里的"通訊"這個(gè)詞是否指的是destination 的socket呢?
            改為"被叫端"是否更妥當(dāng)呢?如果client和server都進(jìn)行send和recv的,"通訊"這個(gè)詞就不能很清楚的說(shuō)明樓主想表達(dá)的意思了呢.  回復(fù)  更多評(píng)論
              
            久久天天躁夜夜躁狠狠| 大美女久久久久久j久久| 久久久久人妻精品一区三寸蜜桃| 青青草国产成人久久91网| 欧美久久综合性欧美| 伊人久久综合热线大杳蕉下载| 一级a性色生活片久久无| 久久精品国产亚洲αv忘忧草| 久久久久高潮毛片免费全部播放| 99久久婷婷国产综合精品草原| 久久久精品久久久久特色影视| 综合久久一区二区三区| 2021精品国产综合久久| 亚洲精品无码久久久久久| 久久久亚洲精品蜜桃臀| 久久久久夜夜夜精品国产| 日韩电影久久久被窝网| 国产69精品久久久久9999| A级毛片无码久久精品免费| 国产999精品久久久久久| 国产成人久久精品一区二区三区| 国产精品内射久久久久欢欢| 久久99精品国产麻豆| 久久夜色精品国产噜噜亚洲AV| 国内精品久久久久影院老司| 蜜桃麻豆www久久国产精品| 久久精品国产亚洲精品2020| 国产精品99久久久精品无码| 国产巨作麻豆欧美亚洲综合久久 | 亚洲级αV无码毛片久久精品| 久久www免费人成精品香蕉| 精品久久国产一区二区三区香蕉| 久久人人爽人人爽人人片AV不| 久久大香萑太香蕉av| 一本大道久久香蕉成人网| 色婷婷狠狠久久综合五月| 狠狠精品干练久久久无码中文字幕| 免费国产99久久久香蕉| 久久精品国产免费一区| 亚洲v国产v天堂a无码久久| 激情久久久久久久久久|