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

socketref,再見!高德

https://github.com/adoggie

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

常用鏈接

留言簿(54)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜


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

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

 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行:  開發者直接將緩存內存地址作為接收和發送地址,沒考慮 字節序問題  (htonl,ntohl) 
20行:  邏輯不嚴密,如果用戶發送4個字節數據,且均為0 ,結果就是服務器崩潰。 

所以codereview還是很重要的,特別是將c++應用在性能,效率關鍵部位的代碼。 







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

Feedback

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

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

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

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品在这里| 国产精品女主播| 亚洲欧洲另类国产综合| 久久久人人人| 久久久免费精品视频| 老司机成人在线视频| 欧美成人免费全部观看天天性色| 裸体一区二区| 亚洲国产免费| 亚洲一区二区三区在线看| 性欧美videos另类喷潮| 久久久精品免费视频| 久久一区免费| 国产精品久久久亚洲一区| 国内精品久久久久久影视8| 亚洲人成毛片在线播放| 亚洲已满18点击进入久久| 久久er精品视频| 亚洲成人在线视频网站| 亚洲婷婷在线| 美女网站久久| 国产精品美女久久久浪潮软件| 国产综合色产在线精品| 99re8这里有精品热视频免费| 亚洲视频在线看| 蜜桃av一区二区| 亚洲视频导航| 美女黄网久久| 国产亚洲欧美日韩一区二区| 亚洲久久视频| 久久久久久午夜| av成人免费| 欧美第一黄网免费网站| 好吊色欧美一区二区三区视频| 亚洲免费观看高清完整版在线观看| 欧美亚洲日本一区| 亚洲精品中文字幕女同| 久久亚洲精选| 男人天堂欧美日韩| 亚洲视频999| 美女精品一区| 亚洲午夜视频| 欧美日韩在线三区| 亚洲精品在线一区二区| 免费在线成人av| 亚洲欧美一区在线| 国产精品免费看片| 亚洲午夜电影| 99精品视频免费观看视频| 欧美国产在线观看| 亚洲激情影院| 亚洲电影欧美电影有声小说| 久热精品在线视频| 亚洲高清资源综合久久精品| 午夜亚洲一区| 亚洲制服av| 国产精品综合久久久| 亚洲欧美日韩国产一区| 一区二区三区四区五区精品| 欧美日韩高清在线观看| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产美女久久久久| 欧美国产专区| 亚洲网址在线| 亚洲一区国产| 国产亚洲美州欧州综合国| 久久www成人_看片免费不卡| 欧美与欧洲交xxxx免费观看| 国产欧美日韩综合| 美日韩在线观看| 免费国产自线拍一欧美视频| 亚洲每日在线| 在线视频欧美精品| 国产精品一区一区三区| 久久国产一二区| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲激情国产| av不卡在线观看| 国产精品综合久久久| 久久野战av| 欧美理论片在线观看| 亚洲一级黄色av| 欧美在线视频导航| 亚洲精品男同| 亚洲综合色网站| 原创国产精品91| 9i看片成人免费高清| 国产精品爽爽ⅴa在线观看| 久久蜜桃精品| 欧美日本二区| 久久婷婷国产综合尤物精品| 欧美不卡视频| 欧美一级网站| 欧美大片免费观看| 欧美一区二区性| 牛夜精品久久久久久久99黑人| 亚洲网站视频| 久久亚洲电影| 亚洲欧美日韩在线观看a三区| 久久九九精品| 欧美美女bbbb| 欧美mv日韩mv国产网站app| 亚洲国产日韩欧美综合久久 | 欧美.www| 欧美亚洲网站| 欧美夫妇交换俱乐部在线观看| 午夜宅男欧美| 欧美激情精品久久久久久黑人| 久久狠狠一本精品综合网| 蜜桃视频一区| 久久久97精品| 国产精品成人国产乱一区| 欧美**人妖| 国产永久精品大片wwwapp| 99国产精品一区| 9i看片成人免费高清| 免费成人黄色| 欧美成人一区二免费视频软件| 国产一区二区剧情av在线| 亚洲淫性视频| 亚洲综合日韩| 欧美日韩中文在线观看| 亚洲黄色一区| 99国产麻豆精品| 欧美二区在线看| 欧美fxxxxxx另类| 在线观看国产欧美| 久久精品国产亚洲一区二区| 欧美在线高清| 国产亚洲欧美一区在线观看| 亚洲欧美精品一区| 亚洲欧美另类综合偷拍| 欧美日韩在线三区| 国产精品99久久久久久久vr| 一区二区三区成人精品| 欧美啪啪一区| 99re在线精品| 亚洲欧美韩国| 国产网站欧美日韩免费精品在线观看| 亚洲性感激情| 欧美一区免费视频| 国产一区二区精品久久| 欧美中在线观看| 久久婷婷国产综合尤物精品| 激情综合视频| 母乳一区在线观看| 亚洲精品国精品久久99热| 亚洲美女在线国产| 欧美午夜免费影院| 亚洲欧美日韩天堂一区二区| 久久久之久亚州精品露出| 亚洲国产天堂久久国产91| 欧美成人tv| 亚洲一区二区三区四区五区黄| 欧美一二三视频| 精品成人在线| 欧美日韩国产天堂| 午夜免费电影一区在线观看| 猛干欧美女孩| 亚洲永久免费视频| 极品少妇一区二区三区精品视频| 美女精品国产| 亚洲男人的天堂在线观看| 免费成人av在线看| 亚洲一级片在线观看| 精品91久久久久| 欧美日韩精品一区二区天天拍小说| 你懂的亚洲视频| 久久伊人一区二区| 亚洲美女视频在线观看| 国产精品视频区| 欧美成人久久| 校园激情久久| 99成人免费视频| 噜噜噜在线观看免费视频日韩| 日韩亚洲一区二区| 韩国欧美国产1区| 欧美午夜在线一二页| 老司机精品导航| 亚洲欧美一区二区三区在线 | 日韩视频免费在线观看| 国产精品嫩草久久久久| 久久婷婷色综合| 午夜老司机精品| 99精品欧美| 亚洲国产高清高潮精品美女| 香蕉成人久久| 中文亚洲字幕| 亚洲精品久久| 一区一区视频| 国产亚洲成av人片在线观看桃| 欧美屁股在线| 免播放器亚洲一区| 欧美在线免费看| 亚洲欧美日韩系列| 亚洲特级片在线| 一本大道av伊人久久综合| 亚洲国产精品第一区二区| 久久视频一区二区| 欧美一区二区女人|