久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 3504|回復: 0
收起左側

內存泄露問題的解決過程

[復制鏈接]
ID:113276 發表于 2016-4-10 20:17 | 顯示全部樓層 |閱讀模式
測試中發現有內存泄露的情況,通過增加內存的信息通過TCP輸出的 2301端口debug后發現
  異常的如下
總內存數(字節):6144
已用內存(字節):5816
剩余內存數(字節):328
使用標示:1
正常的如下
總內存數(字節):6144
已用內存(字節):20
剩余內存數(字節):6124
使用標示:1
顯然memalloc使內存溢出查找代碼因為除了SMTP應用程序使用malloc外其他不具有使用的情況。
所以肯定是SMTP出問題
進一步分析代碼為SMTP的smtp_send_mail()中
smtp_send_mail_alloced(struct smtp_session *s)
函數使用的
s = (struct smtp_session *)SMTP_STATE_MALLOC((mem_size_t)mem_len);
分配了一塊內存沒有事正常的釋放。
這樣反復
幾次最終導致這塊應用代碼不能正常返回一塊完整的 mem_le大小的內存塊而一直保留了328字節的剩余內存。
這最終導致了所有依賴mem的應用程序全部獲取不到足夠的內存塊。而出現的內存溢出。
繼續分析 釋放的內存句柄  (struct smtp_session *) s
發現幾處問題

1)非正常中止        “風險”
   if (smtp_verify(s->to, s->to_len, 0) != ERR_OK) {
    return ERR_ARG;
  }
  if (smtp_verify(s->from, s->from_len, 0) != ERR_OK) {
    return ERR_ARG;
  }
  if (smtp_verify(s->subject, s->subject_len, 0) != ERR_OK) {
    return ERR_ARG;
  }
  由于沒有對  smtp_send_mail_alloced 函數進行判斷所以如果此處返回會造成函數不能正常中止
  也就會導致 (struct smtp_session *) s        沒有機會釋放(因為在不正常中止時是在后面處理的)
  但是考慮到源數據是固定的從片上flash中取得的,這種幾率幾乎沒有。但是存在風險。所以統一改為
  if (smtp_verify(s->to, s->to_len, 0) != ERR_OK) {
             err = ERR_ARG;
     goto leave;
  }
  if (smtp_verify(s->from, s->from_len, 0) != ERR_OK) {
             err = ERR_ARG;
     goto leave;
  }
  if (smtp_verify(s->subject, s->subject_len, 0) != ERR_OK) {
             err = ERR_ARG;
     goto leave;
  }

  2)、非正常TCP連接,主要原因。
  原來的函數為:
  if(tcp_bind(pcb, IP_ADDR_ANY, SMTP_PORT)!=ERR_OK)
        {
        return        ERR_USEl;
            
        }
  顯然還是同樣的會造成malloc 分配了但是沒有被調用,修改為
  if(tcp_bind(pcb, IP_ADDR_ANY,SMTP_PORT)!=ERR_OK)
  {
        err = ERR_USE;
    goto leave;                  
  }

   這樣          leave中就會自動處理釋放掉這個非正常中止的而造成的內存的溢出問題。
   leave:
  smtp_free_struct(s);
  return err;

歸根結底是一個問題。那就是必須保證malloc 和free 成對出現。
實際驗證時發現就是tcp_bind的時反回了(在100K以上的壓力數據下)


回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日韩一区在线视频 | www.日韩在线 | ass亚洲尤物裸体pics | 91福利网 | 亚洲一区二区免费视频 | 国产永久视频 | 久久一区视频 | 国产免费视频 | 五月av| 午夜激情在线观看 | 亚洲激情综合网 | 免费成人在线看 | 久久久久久中文字幕 | 182tv午夜| 亚洲成a人 | 一区二区在线免费观看 | 亚洲日本视频 | aaa级片| 亚洲福利视频一区 | 免费一看一级毛片 | 欧美精品第一页 | 亚洲精品1区 | 成人扒开伸进免费观看 | 国产h视频在线观看 | 日韩无遮挡| 中文一级片 | 成人激情视频在线观看 | 亚洲在线中文字幕 | 色啪视频 | 特级特黄aaaa免费看 | 97精品国产97久久久久久免费 | 欧美性猛交xxxx黑人猛交 | 日韩精品久久久久久 | 亚洲最新网址 | 激情综合网五月 | 天天躁日日躁bbbbb | 国产精品成人一区 | 国产成人影视 | 久草视频观看 | 亚洲天堂免费视频 | www.成人网|