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

            大家看一下這個問題

            今天在看一本書附的源代碼的時候,發現了一個問題,大家來探討一下:關于Winsock的
            下面是兩個程序,一個是服務器端的程序,不斷在監客戶端的連接
            另外一個是客戶端的程序,試圖連接服務器端
            服務器端的程序代碼:
            int main()
            {
            ?// 創建套節字
            ?SOCKET sListen = ::socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
            ?if(sListen == INVALID_SOCKET)
            ?{
            ??printf("Failed socket() \n");
            ??return 0;
            ?}
            ?
            ?// 填充sockaddr_in結構
            ?sockaddr_in sin;
            ?sin.sin_family = AF_INET;
            ?sin.sin_port = htons(4567);
            ?sin.sin_addr.S_un.S_addr = INADDR_ANY;
            ?
            ?// 綁定這個套節字到一個本地地址
            ?if(::bind(sListen, (LPSOCKADDR)&sin, sizeof(sin)) == SOCKET_ERROR)
            ?{
            ??printf("Failed bind() \n");
            ??return 0;
            ?}
            ?
            ?// 進入監聽模式
            ?if(::listen(sListen, 2) == SOCKET_ERROR)
            ?{
            ??printf("Failed listen() \n");
            ??return 0;
            ?}
            ?
            ?// 循環接受客戶的連接請求
            ?sockaddr_in remoteAddr;
            ?int nAddrLen = sizeof(remoteAddr);
            ?SOCKET sClient;
            ?char szText[] = " TCP Server Demo! \r\n";
            ?while(TRUE)
            ?{
            ??// 接受一個新連接
            ??sClient = ::accept(sListen, (SOCKADDR*)&remoteAddr, &nAddrLen);
            ??if(sClient == INVALID_SOCKET)
            ??{
            ???printf("Failed accept()");
            ???continue;
            ??}
            ??
            ??printf(" 接受到一個連接:%s \r\n", inet_ntoa(remoteAddr.sin_addr));

            ??// 向客戶端發送數據
            ??::send(sClient, szText, strlen(szText), 0);
            ??// 關閉同客戶端的連接
            ??::closesocket(sClient);
            ?}
            ??
            ?// 關閉監聽套節字
            ?::closesocket(sListen);
            ?::MessageBox(NULL,"","",MB_OK);
            ?return 0;
            }
            大家請注意上面的while循環,在不斷監聽客戶端的連接。除非你手動關閉該服務器程序,否則while循環是不會退出的。那么,問題是:關閉套接字的那段代碼始終不會執行(我用MessageBox做了試驗,即使是手動關閉該程序,也不會MessageBox),這樣,是不是會發生資源泄露呢?難道windows會幫你關閉?

            posted on 2006-06-10 20:17 bo 閱讀(868) 評論(3)  編輯 收藏 引用 所屬分類: Network

            評論

            # re: 大家看一下這個問題 2006-06-10 21:42 LOGOS

            程序關閉后,他所占用的內存空間會被系統回收。
            不過我不能確定sListen是否會被關閉  回復  更多評論   

            # re: 大家看一下這個問題 2006-06-11 09:37 從頭再來

            為什么不開一個線程去循環接受客戶的連接請求?目前的情況下,就是關閉了同客戶端的連接,也不會退出while循環的,不退出循環怎么會繼續下面的messagebox()?

              回復  更多評論   

            # re: 大家看一下這個問題 2006-06-11 12:20 cooelaf

            用異步socket AcceptEx來接受連接.  回復  更多評論   

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(23)

            隨筆檔案(23)

            URL

            最新隨筆

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            国内精品九九久久久精品| 91麻豆精品国产91久久久久久 | 精品久久久久久久久久中文字幕 | 亚洲国产精品成人AV无码久久综合影院 | 性欧美大战久久久久久久久| 久久久久AV综合网成人| 久久国产福利免费| 国产精品中文久久久久久久 | 欧美日韩中文字幕久久伊人| 国产综合免费精品久久久| 亚洲人AV永久一区二区三区久久| 亚洲AV日韩AV永久无码久久| 中文精品久久久久国产网址| 久久精品国产男包| 伊人久久大香线蕉综合网站| 国产成人久久精品区一区二区| 久久精品国产亚洲αv忘忧草| 久久精品国产99久久无毒不卡 | 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久成人18免费网站| 亚洲AV无码成人网站久久精品大| 国产叼嘿久久精品久久| 精品午夜久久福利大片| 色欲久久久天天天综合网精品| 国产成人久久激情91| 77777亚洲午夜久久多人| 97香蕉久久夜色精品国产| 香蕉久久一区二区不卡无毒影院| 亚洲国产精品18久久久久久| 一个色综合久久| 欧美伊人久久大香线蕉综合| 久久国产精品视频| 精品乱码久久久久久久| 亚洲女久久久噜噜噜熟女| 亚洲精品99久久久久中文字幕 | 无码精品久久久久久人妻中字| 日本久久久久久久久久| 久久伊人色| 囯产精品久久久久久久久蜜桃| 久久午夜无码鲁丝片午夜精品| 久久精品国产精品亚洲下载|