MILY: 宋體">我們可以看到Purify的報告中有兩個內存錯誤,一個是ABR(Array Bounds Read)——數組越界讀,一個是12個字節的Memory Leaked,展開小三角符號,我們可以看到更為詳細報告:
purify4.jpg" align=baseline border=0>
展開ABR錯誤后,我們可以看到,ABR錯誤的產生是由printf產生的,而產生錯誤的內存是mystr。通過觀察,我們馬上可以發現為會什么會出現ABR錯誤,原因是C/C++中的字符串都是以“\0”結尾的,而我們分配字符串時,應該要比實際長度多一,以存放結束符,而我們以后面調用的strncpy只拷貝了字符串的有效內容,并沒有在字符串最后加上一個結束符。而系統調用printf輸出字符串內容直至遇到結束符,所以當其訪問到12個長度時,還沒有發現結束,于是繼續向下訪問,于是就出現了ABR錯誤。
好了,讓我們再來看看Memory Leaked的報告信息:
我們可以看到,Purify指出了那塊內存出現了內存泄露,泄露了多少個字節。通過Purify的報告,再加上我們對C/C++基礎的了解,我們立馬知道mystr是在堆上分配的內存,所以必須要我們自己手動釋放,查看程序,我們發現我們忘了free ( mystr )。
文章來源于領測軟件測試網 http://www.kjueaiud.com/