基于C++中常見內存錯誤的總結

在系統開發過程中出現的bug相對而言是比較好解決的,花費在這個上面的調試代價不是很大,但是在系統集成后的bug往往是難以定位的bug(最好方式是打樁,通過打樁可以初步鎖定出錯的位置,如:進入函數前打印日志,離開時再次打印日志)。而這些難以定位的bug基本分為2類:內存錯誤和并非問題。

1、內存泄露
如果在堆棧上分配的內存使用完成后沒有釋放就會造成內存泄露。少量的內存泄露不至于讓程序崩潰,但是大量的內存泄露就會導致內存耗盡,后續內存分配失敗,從而導致程序崩潰。長時間運行軟件,即使只有一兩處泄露,同樣會導致程序崩潰。所以有當出現內存泄露請檢查是否釋放了資源。

2、內存越界訪問
內存越界訪問有兩種:一種是讀越界,即讀了不屬于自己的數據,如果所讀的內存地址是無效的,程序就立即崩潰。如果所讀的內存地址是有效的,在讀的時候不會出現問題,但是由于讀到的數據是隨機的,他會產生不可預料的后果,另一種是寫越界,又叫緩沖區溢出。所寫的數據是隨機的,他也會產生不可預料的后果。

內存越界訪問造成的后果非常嚴重,是引起程序不穩定的主要原因之一,最主要的是它造成的后果是隨機的,表現出來的癥狀和時機也是隨機的,讓bug的現象和本質看似沒有什么聯系,這給bug定位帶來了極大的困難。所以在時機開發過程中,對于外部傳入的參數要仔細檢查。

3、野指針
釋放掉的內存會被內存管理器重新分配。此時野指針指向的內存已經被賦予新的意義。對野指針指向的內存訪問,無論是有意的還是無意的,都會為此付出巨大代價,因為它造成的后果,如果越界訪問一樣是不可預料的。解決野指針最好的方法:釋放內存后立即把對應指針置為空值。

4、訪問空指針
在訪問指針指向的內存時,確保指針不是空指針。訪問空指針指向的內存,通常會導致程序崩潰,或者不可預料的錯誤。

5、引用未初始化的變量
未初始化變量的內容是隨機的,使用這些數據會造成不可預料的后果,調試這樣的bug也非常困難。最好的解決辦法:在聲明變量的時候就對它進行初始化。

6、不清楚的指針運算
如:int *p=....;
p+n等價于(size_t)p+n*sizeof(*p);

7、結構體成員順序變化引發的錯誤

8、結構體大小變化引發的錯誤

9、分配釋放不配對

10、返回指向臨時變量的指針
棧里面的變量時臨時的,當前函數執行完成時,先關的臨時變量和參數都被清除了。不能把指向這些臨時變量的指針返回給調用這,這樣的指針執行的數據是隨機的,會給程序造成不可預料的后果。

11、試圖修改常量
如:char *p="1234";
*p='1';

12、誤解傳值和傳引用

13、重名符號
關于重名問題可以參考:C++重定義解決方法總結

14、棧溢出

15、誤用sizeof
C++通常是按值傳遞參數,而數組則是例外,在傳遞數組參數時,數組退化為指針(及按引用傳遞),此時用sizeof是無法獲取數據的大小。

16、字節對齊
字節對齊主要目的是提高內存訪問效率,在某些平臺上,就不僅僅是效率問題,如果不對齊得到的數據是錯誤的。大多數情況下編譯器會保值全局變量和臨時變量按照正確的方式對齊。內存管理器會保證動態按照正確的方式對齊。要注意的是:在不同的類型的變量之間轉換時要小心。
字節對齊也會造成結構體大小的變化,在程序內部用sizeof來取的結構的大小就可以了。若數據要在不同的機器間傳遞時,在通信協議中要規定對齊的方式,避免對齊方式不一致引發的問題。
關于字節對齊問題請參考:關于C++內存中字節對齊問題的詳細介紹

17、字節順序
字節順序歷來是設計跨平臺最頭痛的問題。字節順序是關于數據在物理內存中的布局問題,最常見的字節順序有兩種:大端模式和小端模式
大端模式:高位字節數據存放在低地址處,低位字節數據存放在高地址處。
小端模式:低位字節數據存放在內存低地址處,高字節字節數據存放在內存高地址處

如:long n=0x11223344
模式第1字節 第2字節第3字節? 第4字節
大端模式0x110x220x330x44?
小端模式0x440x330x220x11

在普通軟件中,字節順序問題并不引人注目。而在開發與網絡通信和數據交換有關的軟件時,字節順序就要多注意了。

18、多線程共享變量沒有用valotile修飾
valotile作用:告訴編譯器不要把變量優化到寄存器中。在開發多線程的程序是,如果這些線程共享一些全局變量,這些全局變量最好使用valotile修飾。這樣可以避免因為編譯器優化而引起的錯誤。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/458779.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/458779.shtml
英文地址,請注明出處:http://en.pswp.cn/news/458779.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

UWP開發細節記錄:判斷文件類型

StorageFile.ContentType 屬性,是 string 類型,用來表示文件內容的 MIME 類型。例如,音樂文件可能有 "audio/mpeg" MIME 類型。(MSDN) MIME 類型的定義可以下面的鏈接找到: MIME Types - http://blogs.msdn.com/b/jaime…

Creating Apps With Material Design —— Creating Lists and Cards

轉載請注明 http://blog.csdn.net/eclipsexys 翻譯自Developer Android。時間倉促,有翻譯問題請留言指出,謝謝創建Lisst和Cards在你的應用程序創建復雜的清單,并與材料設計風格卡。您能夠使用RecyclerView和CardView部件。 創建RecyclerView …

計算機考研自命題院校雙非,計算機考研408——951211院校匯總

眾所周知,計算機考研408計算機學科基礎綜合難度與一些頂尖985自命題相比也是不落下風的,號稱最難工科專業課(請忽略912這種殿堂級別的),難度大、知識點龐雜也是前些年眾多高校紛紛脫離408統考的原因。19年的計算機類考研火到爆炸,…

Could not get lock /var/lib/apt/lists/lock - open (11: Resource temporarily unavailable)

第一次鼓搗Docker,- - ! 報錯: serverubuntu1987:~$ sudo apt-get update E: Could not get lock /var/lib/apt/lists/lock - open (11: Resource temporarily unavailable) E: Unable to lock directory /var/lib/apt/lists/ 轉載于:https://www.cnblo…

新手學Struts(一)----JSP+Servlet講解MVC實現原理

MVC基本原理一個簡單的例子改良的例子Struts基本流程的實現最近在學SSH(Struts HibernateSpring),這也算是一個比較經典的框架了,之前都是看人家大牛說這個框架,那個框架,說的真溜,自己也是佩服的五體投地啊…

中國首臺千萬億次超級計算機,中國首臺千萬億次超級計算機首批設備開始試用...

新華社天津1月13日電(記者 周潤健 羅捷)記者13日從國家超級計算天津中心獲悉,中國首臺千萬億次超級計算機“天河一號”首批設備調試工作結束,具備向客戶提供服務的條件,“天河一號”…

Outlook Express 錯誤代碼表

錯誤碼 意義 一般 0x800C01310x800C013E 可能是 Folders.dbx 檔案屬性錯誤或損壞. 0x800CCC00 身份驗證(Authentication)未載入 0x800CCC01 認證(Certificate)內容錯誤 0x800CCC02 認證日期錯誤 0x800CCC03 使用者已聯機 0x800CCC…

USB設備枚舉過程

(1)集線器檢測新設備 (集線器的英文稱為“Hub”)主機集線器監視著每個端口的信號電壓,當有新設備接入時便可覺察。(集線器端口的兩根信號線的每一根都有15kΩ的下拉電阻,而每一個設備在D都有一個…

windows下apache+php+mysql 環境配置方法

轉自:http://www.jb51.net/article/30128.htm 一 準備 1 下載apache http://httpd.apache.org/download.cgi#apache24 httpd-2.2.22-win32-x86-openssl-0.9.8t.msiopenssl表示帶有openssl模塊,利用openssl可給Apache配置SSL安全鏈接 2 下載php http://wi…

計算機工作原理 公開課,《計算機的基本工作原理》公開課材料(11頁)-原創力文檔...

《計算機系統的組成》教學設計教師:吳軍一、學習者分析初一的學生,具有活潑好動的特點,懷著對初中生活的憧憬來到一個新的環境里,對每樣事物都充滿著好奇,都想去探個究竟。隨著社會的進步, 計算機的使用范圍…

USB枚舉過程分析

1. 枚舉是什么? 枚舉就是從設備讀取一些信息,知道設備是什么樣的設備,如何進行通信,這樣主機就可以根據這些信息來加載合適的驅動程序。調試USB設備,很重要的一點就是USB的枚舉過程,只要枚舉成功了,那么就…

linux -- read(), write()

read()函數 2011-03-23 16:28:37| 分類&#xff1a; linux | 標簽&#xff1a; |字號大中小 訂閱 read函數從打開的設備或文件中讀取數據。 #include <unistd.h> ssize_t read(int fd, void *buf, size_t count); 返回值&#xff1a;成功返回讀取的字節數&…

jquery的$.extend、$.fn.extend、 jQuery.extend( target, object1, [objectN])作用及區別

jQuery為開發插件提拱了兩個方法&#xff0c;分別是&#xff1a; jQuery.fn.extend();jQuery.extend(); 雖然 javascript 沒有明確的類的概念&#xff0c;但是用類來理解它&#xff0c;會更方便。 jQuery便是一個封裝得非常好的類&#xff0c;比如我們用 語句 $("#btn1&…

CATia對計算機配置要求,【2人回答】求CATIA對電腦的詳細配置要求-3D溜溜網

回答&#xff1a;1、內存要求在32G和64G之間。2、硬盤要求選擇7200轉機械硬盤&#xff0c;4k以上分辨&#xff0c;就選擇SSD固態硬盤。3、CPU要求睿頻在4.1GHZ以上&#xff0c;核心在6和8核之間。4、顯卡要求顯存在6GB和11GB之間&#xff0c;位寬要求在192bit和384bit之間。5、…

如何制作自動更新程序?

原文出自&#xff1a;http://blog.csdn.net/metaphysis/article/details/18866631 如何制作自動更新程序&#xff1f; [版權所有 邱秋 2014 metaphysisyeah.net, 轉載請注明出處] 最近為單位寫了一個C/S結構的軟件&#xff0c;這個軟件是工作在單位的局域網內的。為了減輕為程序…

包含JS交互的混淆出錯

2019獨角獸企業重金招聘Python工程師標準>>> 小上司離職&#xff0c;我接手他負責的項目&#xff0c;進行版本更新的時候&#xff0c;在生成jar包測試的時候&#xff0c;點擊按鈕沒有反應&#xff0c;頁面是webview&#xff0c;按鈕則是與js交互&#xff0c;logcat打…

計算機常用代碼大全,常用電腦命令大全【圖文】

導語 &#xff1a;電腦&#xff0c;這個在前幾年貌似還離我們非常遙遠的詞匯&#xff0c;現在隨著信息化社會的不斷發展&#xff0c;已經走進了我們的千家萬戶。現在每一家新 裝修 &#xff0c;它都作為一種必備的家用電器來使用。由此可見電腦對我們 現代 人的重要性。但電腦畢…

細數技術指標-[轉載]

技術指標類別龐雜&#xff0c;要一一學全&#xff0c;基本不可能&#xff0c;也沒有這個必要。我們只要掌握幾個常用的指標&#xff0c;了解它們的原理&#xff0c;從而舉一反三&#xff0c;就足夠了。其實任何一種技術指標都是從形態、價格、量、時間這四項出發的&#xff0c;…

[javaSE] 看博客學習java并發編程

共享性 多線程操作同一個數據&#xff0c;產生線程安全問題 新建一個類ShareData 設計一個int 型的成員變量count 設計一個成員方法addCount()&#xff0c;把count變量 在main函數中開啟多個線程操作這個成員變量&#xff0c;在main函數里 獲取ShareData對象&#xff0c;new 出…

GetProcAddress() LoadLibrary() DLL

GetProcAddress函數檢索指定的動態鏈接庫(DLL)中的輸出庫函數地址。 函數原型&#xff1a; FARPROC GetProcAddress( HMODULE hModule, // DLL模塊句柄 LPCSTR lpProcName // 函數名 ); 參數&#xff1a; hModule [in] 包含此函數的DLL模塊的句柄。LoadLibrary、AfxLoadLibrary…