• <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
            <2008年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            E-mail:zbln426@163.com QQ:85132383 長期尋找對戰略游戲感興趣的合作伙伴。

            常用鏈接

            留言簿(21)

            隨筆分類

            隨筆檔案

            SDL相關網站

            我的個人網頁

            我的小游戲

            資源下載

            搜索

            •  

            積分與排名

            • 積分 - 492144
            • 排名 - 38

            最新評論

            閱讀排行榜

            評論排行榜

            作者:龍飛

                    現在,我們通過accept()創建了新的socket,也就是我們類中的數據成員communicationSock,現在,我們就可以通過這個socket進行通訊了。

            TCP通訊模型

                    在介紹函數之前,我們應該了解一些事實。TCP的Server/Client模型類似這樣:
            ServApp——ServSock——Internet——ClntSock——ClntApp
            當然,我們這里的socket指的就是用于“通訊”的socket。TCP的server端至少有兩個socket,一個用于監聽,一個用于通訊;TCP的server端可以只有一個socket,這個socket同時“插”在server的兩個socket上。當然,插上listen socket的目的只是為了創建communication socket,創建完備后,listen是可以關閉的。但是,如果這樣,其他的client就無法再連接上server了。
                    我們這個模型,是client的socket插在server的communication socket上的示意。這兩個socket,都擁有完整的本地地址信息以及遠程計算機地址信息,所以,這兩個socket以及之間的網絡實際上形成了一條形式上“封閉”的管道。數據包只要從一端進來,就能知道出去的目的地,反之亦然。這正是TCP協議,數據流形式抽象化以及實現。因為不再需要指明“出處”和“去向”,對這樣的socket(實際上是S/C上的socket對)的操作,就如同對本地文件描述符的操作一樣。但是,盡管我們可以使用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中的實現為:
            #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);
            這兩個函數的第一個參數是用于“通訊”的socket,第二個參數是發送或者接收數據的起始點指針,第三個參數是數據長度,第四個參數是控制符號(默認屬性設置為0就可以了)。失敗時候傳回-1,否則傳回實際發送或者接收數據的大小,返回0往往意味著連接斷開了。

            處理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);
            }
            本小節最后要講的函數是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);
            這個函數用于關閉一個文件描述符,自然,也就可以用于關閉socket。
            下一小節是完整的源代碼。默認的監聽端口是5000。我們可以通過
            $telnet 127.0.0.1 5000
            驗證在本機運行的echo server程序。
            posted on 2008-07-16 12:26 lf426 閱讀(8135) 評論(2)  編輯 收藏 引用 所屬分類: SDL入門教程Linux與C++socket 編程入門教程

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

            TCP 的server端可以只有一個socket,這個socket同時“插”在server的兩個socket上。

            這里應該是: TCP的 client端可以只有一個......  回復  更多評論
              
            # re: socket 編程入門教程(一)TCP server 端:7、接收與發送 2010-10-16 16:50 莉薩
            這段貌似沒有前幾段寫的詳細了呢...在描述send 和recv函數中有這樣一句話:

            "這兩個函數的第一個參數是用于“通訊”的socket"

            這里的"通訊"這個詞是否指的是destination 的socket呢?
            改為"被叫端"是否更妥當呢?如果client和server都進行send和recv的,"通訊"這個詞就不能很清楚的說明樓主想表達的意思了呢.  回復  更多評論
              
            综合久久精品色| 精品久久久久久无码人妻热| 国内精品伊人久久久久影院对白| 久久久久亚洲av无码专区喷水| 囯产精品久久久久久久久蜜桃| 久久久国产视频| 狠狠色丁香婷婷久久综合五月| 久久综合五月丁香久久激情| 久久av免费天堂小草播放| 久久久免费观成人影院| 久久乐国产精品亚洲综合| 一本色道久久88综合日韩精品| 久久久久无码精品| 色综合久久88色综合天天 | 久久人人爽人人爽人人av东京热 | 狠狠色狠狠色综合久久| 18禁黄久久久AAA片| 亚洲中文字幕无码久久精品1 | 欧美午夜精品久久久久免费视| 香蕉久久av一区二区三区| 久久久久亚洲精品无码蜜桃 | 97久久国产亚洲精品超碰热| 久久久青草久久久青草| 久久久久亚洲精品天堂久久久久久| 久久99精品久久久久久野外| 国产香蕉久久精品综合网| 无码人妻久久一区二区三区| 一本色道久久88加勒比—综合| 久久电影网| 日本人妻丰满熟妇久久久久久| 亚洲乱亚洲乱淫久久| 99久久香蕉国产线看观香| 国产精品久久久久影院色| 综合久久精品色| 久久亚洲国产精品一区二区| 久久笫一福利免费导航| 久久精品国产精品国产精品污 | 亚洲综合精品香蕉久久网97 | 麻豆精品久久精品色综合| 四虎影视久久久免费观看| 国产精品福利一区二区久久|