青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

socketref,再見!高德

https://github.com/adoggie

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  246 Posts :: 4 Stories :: 312 Comments :: 0 Trackbacks

常用鏈接

留言簿(54)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜


一友人做游戲服務(wù)器,涉及通信模塊和業(yè)務(wù)模塊,在軟件行業(yè)也算個老兵了,也搞c++n多年了,對于軟件開發(fā)也有自己的一些想法和心得,將其代碼與我分享,讓我觀贊一下。
c++是我從業(yè)一來一直信奉的開發(fā)工具,雖然近些年一直用python來搞定應(yīng)用需求,但關(guān)鍵時刻還必須是c++搞定, 所以c++的程序代碼能hold住的。 

我知道寫通信部分代碼的關(guān)鍵點在哪里,比如: 性能、安全、完整性、模塊化設(shè)計和處理,所以有針對性的去檢查友人的代碼,當(dāng)看到這個函數(shù)的時候,致命的錯誤來了: 
分別在于: 第 13,20行 ,其分別會導(dǎo)致服務(wù)器崩潰和不響應(yīng)

 1 
 2 tagPack* CClient::getRecvPack()
 3 {
 4     uv_mutex_lock(&_lockrecv);
 5     tagPack *t = NULL;
 6     if(_recvPackLenght < 4)
 7     {
 8         _recvOver = true;
 9         uv_mutex_unlock(&_lockrecv);
10         return t;
11     }
12     tagPack* tmp = _lsRecvBuf.front();
13     unsigned int size = *(unsigned int*)&tmp->pack[0];
14     if(_recvPackLenght < size)
15     {
16         _recvOver = true;
17         uv_mutex_unlock(&_lockrecv);
18         return t;
19     }
20     BYTE* mem = new BYTE[size];
21 
22     unsigned int index = 0;
23     unsigned int needSize = size;
24     while(true)
25     {
26         if(tmp->size < needSize)
27         {
28             memcpy(&mem[index], tmp->pack, tmp->size);
29             needSize -= tmp->size;
30             index += tmp->size;
31             delete tmp;
32             _lsRecvBuf.pop_front();
33         }
34         else if(tmp->size == needSize)
35         {
36             memcpy(&mem[index], tmp->pack, tmp->size);
37             needSize -= tmp->size;
38             index += tmp->size;
39             delete tmp;
40             _lsRecvBuf.pop_front();
41         }
42         else
43         {
44             memcpy(&mem[index], tmp->pack, needSize);
45             memcpy(tmp->pack, &tmp->pack[needSize], tmp->size - needSize);
46             tmp->size -= needSize;
47 
48             needSize = 0;
49         }
50 
51         if( needSize == 0 )
52         {
53             t = new tagPack(size);
54             t->addBytes(mem, size);
55             t->_sock = _sock;
56             delete []mem;
57             _recvPackLenght -= t->size;
58             break;
59         }
60         tmp = _lsRecvBuf.front();
61     }
62     uv_mutex_unlock(&_lockrecv);
63 
64     return t;
65 }

13行:  開發(fā)者直接將緩存內(nèi)存地址作為接收和發(fā)送地址,沒考慮 字節(jié)序問題  (htonl,ntohl) 
20行:  邏輯不嚴(yán)密,如果用戶發(fā)送4個字節(jié)數(shù)據(jù),且均為0 ,結(jié)果就是服務(wù)器崩潰。 

所以codereview還是很重要的,特別是將c++應(yīng)用在性能,效率關(guān)鍵部位的代碼。 







posted on 2016-03-24 15:29 放屁阿狗 閱讀(16322) 評論(4)  編輯 收藏 引用 所屬分類: C++/Boost/STL/Template

Feedback

# re: 有問題的c++通信代碼的識別 2016-03-26 22:28 火紅地太陽
這代碼能力,說實話,感覺太一般了,沒什么功底。  回復(fù)  更多評論
  

# re: 有問題的c++通信代碼的識別 2016-03-27 00:23 放屁阿狗
是不夠精簡,思路不夠嚴(yán)密  回復(fù)  更多評論
  

# re: 有問題的c++通信代碼的識別[未登錄] 2016-04-12 11:36 hdqqq
12 行沒檢查返回值
53 行 new 一定成功嗎
  回復(fù)  更多評論
  

# re: 有問題的c++通信代碼的識別 2016-05-06 09:36 tqt
還new,還mutex_unlock,服.  回復(fù)  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产三级网| 欧美亚洲一区二区三区| 亚洲免费在线电影| 99re66热这里只有精品3直播 | 亚洲自拍偷拍网址| 亚洲国产精品小视频| 亚洲图片在线| 亚洲国产成人久久综合一区| 亚洲深夜影院| 91久久亚洲| 欧美一级片久久久久久久| 日韩视频在线免费观看| 欧美亚洲三级| 一区二区三区日韩欧美精品| 正在播放欧美一区| 国际精品欧美精品| 亚洲美女视频在线免费观看| 国产在线拍偷自揄拍精品| 欧美电影在线| 国产欧美日韩视频一区二区三区 | 久久久天天操| 欧美亚韩一区| 亚洲国产清纯| 激情婷婷久久| 亚洲香蕉在线观看| 99国产一区| 乱人伦精品视频在线观看| 欧美一区二区三区在线看| 欧美日韩大片| 欧美激情中文字幕一区二区| 国产欧美日韩专区发布| 亚洲性图久久| 日韩亚洲欧美成人一区| 久久国产精品久久久| 欧美专区日韩视频| 欧美视频在线观看免费网址| 亚洲精品护士| 国产婷婷97碰碰久久人人蜜臀| 一区二区三区国产盗摄| 在线综合欧美| 欧美日韩国产影片| 亚洲精品一区二区在线观看| 亚洲国产成人久久| 欧美sm极限捆绑bd| 亚洲国产精品久久久久秋霞影院| 在线欧美不卡| 老司机午夜精品视频| 欧美69wwwcom| 亚洲欧洲一区二区在线观看 | 亚洲少妇中出一区| 午夜精品久久久久久| 国产欧美日韩高清| 亚洲欧美在线一区二区| 久久不射2019中文字幕| 国产视频精品xxxx| 久久久久久午夜| 亚洲电影视频在线| 亚洲视频一区在线| 国产精品久久久久久妇女6080 | 亚洲精品久久久久久久久久久久| 亚洲免费观看在线视频| 欧美日韩一区二区在线观看| 一区二区三区日韩在线观看| 先锋影音网一区二区| 国产一区二区三区四区hd| 老司机久久99久久精品播放免费 | 中文日韩电影网站| 日韩一区二区高清| 国产精品毛片va一区二区三区 | 99在线热播精品免费| 欧美视频日韩视频| 性做久久久久久| 欧美在线短视频| 国产一区二区三区不卡在线观看| 欧美一区二区三区精品| 久久精品国语| 日韩亚洲国产精品| 欧美日韩一区在线播放| 亚洲影院在线观看| 久久女同精品一区二区| 亚洲电影中文字幕| 欧美体内谢she精2性欧美| 性欧美精品高清| 亚洲黄色一区二区三区| 欧美影院久久久| 亚洲精品1区2区| 国产精品免费视频xxxx| 久久男人av资源网站| 在线亚洲精品| 欧美电影在线观看完整版| 一本色道久久综合亚洲精品按摩 | 亚洲激情视频网| 欧美日韩国产a| 久久av免费一区| 夜色激情一区二区| 欧美成年视频| 欧美在线看片a免费观看| 亚洲精品一区二区网址| 国产香蕉久久精品综合网| 欧美国产另类| 久久精品亚洲| 亚洲综合色噜噜狠狠| 亚洲国产aⅴ天堂久久| 久久久蜜臀国产一区二区| 亚洲午夜av在线| 亚洲黄色天堂| 在线观看欧美视频| 欧美日韩在线直播| 久久夜色精品国产亚洲aⅴ| 99在线精品视频在线观看| 美女诱惑一区| 香蕉乱码成人久久天堂爱免费 | 一本色道久久88综合日韩精品| 久久精品国产69国产精品亚洲| 一区二区三区产品免费精品久久75 | 久久久久综合| 午夜欧美精品久久久久久久| 在线中文字幕不卡| 亚洲黄色一区二区三区| 国产精品二区二区三区| 欧美日韩国产二区| 欧美人妖另类| 欧美精品高清视频| 欧美激情aⅴ一区二区三区| 久久婷婷国产综合国色天香| 久久国产精品久久w女人spa| 亚洲欧美中文另类| 午夜一区在线| 午夜精品影院| 亚洲性感美女99在线| 亚洲午夜小视频| 亚洲综合好骚| 午夜免费电影一区在线观看| 亚洲欧美变态国产另类| 一本大道久久a久久综合婷婷| 欧美高清不卡| 亚洲国产精品悠悠久久琪琪| 亚洲国产成人精品女人久久久 | 另类专区欧美制服同性| 裸体一区二区三区| 麻豆精品视频在线| 欧美激情在线狂野欧美精品| 亚洲激情图片小说视频| 日韩一级精品视频在线观看| 亚洲天堂成人| 性欧美xxxx视频在线观看| 久久成人免费网| 麻豆91精品| 欧美激情精品久久久久久黑人| 欧美久久成人| 国产精品日本一区二区| 国内精品福利| 亚洲人午夜精品免费| 在线性视频日韩欧美| 日韩午夜免费| 亚洲一区二区三区在线| 香蕉久久夜色精品国产使用方法| 欧美一区二区三区另类| 久久久久欧美精品| 免费成人在线视频网站| 亚洲高清视频的网址| 99re66热这里只有精品3直播| 99国产欧美久久久精品| 一区二区三区视频在线| 午夜精品一区二区三区电影天堂| 久久久久久免费| 欧美伦理a级免费电影| 国内精品久久久久伊人av| 一区二区欧美在线| 久久av在线看| 亚洲国产精品视频| 欧美有码在线视频| 欧美日韩黄色大片| 国内外成人在线视频| 一区二区欧美激情| 六月婷婷一区| 亚洲伦理在线| 欧美一区二视频在线免费观看| 理论片一区二区在线| 国产欧美日韩综合| 日韩亚洲欧美在线观看| 久久久综合激的五月天| 中日韩美女免费视频网站在线观看| 欧美一区深夜视频| 欧美视频福利| 亚洲精品乱码久久久久久日本蜜臀 | 欧美三级小说| 亚洲第一成人在线| 欧美在线免费观看视频| 亚洲精品自在在线观看| 老司机亚洲精品| 国产一区二区主播在线| 亚洲视频一区二区| 亚洲国产高清一区二区三区| 久久久免费观看视频| 国产日韩欧美日韩大片| 亚洲欧洲在线看| 亚洲欧美在线aaa| 亚洲国产一区视频| 久久人人爽爽爽人久久久|