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

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            socket長連接的keeplive

            Posted on 2008-12-11 16:04 Prayer 閱讀(3242) 評論(0)  編輯 收藏 引用 所屬分類: SOCKET

            //設置KeepAlive
            BOOL bKeepAlive = TRUE;
            nRet = ::setsockopt(m_sockDesc, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof(bKeepAlive));
            if (nRet !=0)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Socket SetOpt failed ", WSAGetLastError());
            return FALSE;
            }

            //設置KeepAlive檢測時間和次數
            TCP_KEEPALIVE inKeepAlive = {0}; //輸入參數
            unsigned long ulInLen = sizeof(TCP_KEEPALIVE);

            TCP_KEEPALIVE outKeepAlive = {0}; //輸出參數
            unsigned long ulOutLen = sizeof(TCP_KEEPALIVE);

            unsigned long ulBytesReturn = 0;

            //設置socket的keep alive為10秒,并且發送次數為3次
            inKeepAlive.onoff = 1;
            inKeepAlive.keepaliveinterval = 10000; //兩次KeepAlive探測間的時間間隔
            inKeepAlive.keepalivetime = 3; //開始首次KeepAlive探測前的TCP空閉時間

            nRet = WSAIoctl(m_sockDesc,
            SIO_KEEPALIVE_VALS,
            (LPVOID)&inKeepAlive,
            ulInLen,
            (LPVOID)&outKeepAlive,
            ulOutLen,
            &ulBytesReturn,
            NULL,
            NULL);
            if(SOCKET_ERROR == nRet)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Nonblocking socket call error ", WSAGetLastError());
            return FALSE;
            }

            -------------------------------------------------------------------------------------------------------------------------------

            //設置KeepAlive
            BOOL bKeepAlive = TRUE;
            nRet = ::setsockopt(m_sockDesc, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof(bKeepAlive));
            if (nRet !=0)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Socket SetOpt failed ", WSAGetLastError());
            return FALSE;
            }

            //設置KeepAlive檢測時間和次數
            TCP_KEEPALIVE inKeepAlive = {0}; //輸入參數
            unsigned long ulInLen = sizeof(TCP_KEEPALIVE);

            TCP_KEEPALIVE outKeepAlive = {0}; //輸出參數
            unsigned long ulOutLen = sizeof(TCP_KEEPALIVE);

            unsigned long ulBytesReturn = 0;

            //設置socket的keep alive為10秒,并且發送次數為3次
            inKeepAlive.onoff = 1;
            inKeepAlive.keepaliveinterval = 10000; //兩次KeepAlive探測間的時間間隔
            inKeepAlive.keepalivetime = 3; //開始首次KeepAlive探測前的TCP空閉時間

            nRet = WSAIoctl(m_sockDesc,
            SIO_KEEPALIVE_VALS,
            (LPVOID)&inKeepAlive,
            ulInLen,
            (LPVOID)&outKeepAlive,
            ulOutLen,
            &ulBytesReturn,
            NULL,
            NULL);
            if(SOCKET_ERROR == nRet)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Nonblocking socket call error ", WSAGetLastError());
            return FALSE;
            }

            久久人人爽人人爽人人片AV东京热 | 久久se精品一区精品二区国产| 国内精品人妻无码久久久影院导航 | 日产精品99久久久久久| 青草国产精品久久久久久| 狠狠久久亚洲欧美专区| 狠狠色伊人久久精品综合网 | 久久久久久噜噜精品免费直播 | 精品无码久久久久国产| 91麻精品国产91久久久久| 久久人人爽人人爽人人爽| 久久99毛片免费观看不卡| 久久婷婷午色综合夜啪| 国产精品久久久久久久久免费| 国产美女亚洲精品久久久综合| 成人综合伊人五月婷久久| 热综合一本伊人久久精品| 好久久免费视频高清| 成人综合久久精品色婷婷| 久久综合久久综合九色| 婷婷久久久亚洲欧洲日产国码AV| 伊人热人久久中文字幕| 麻豆AV一区二区三区久久| 欧美日韩久久中文字幕| 久久精品中文字幕一区| 日本一区精品久久久久影院| 色欲久久久天天天综合网精品 | 国产精品一久久香蕉国产线看| 91麻豆国产精品91久久久| 久久久免费观成人影院| 九九久久精品无码专区| 日韩亚洲欧美久久久www综合网| MM131亚洲国产美女久久| 色欲综合久久躁天天躁蜜桃| 囯产精品久久久久久久久蜜桃| 久久综合成人网| 久久这里只有精品视频99| 久久国产一片免费观看| 久久综合久久性久99毛片| 久久久WWW成人免费精品| 久久亚洲中文字幕精品一区|