C++中new的越界拜訪成績。本站提示廣大學習愛好者:(C++中new的越界拜訪成績)文章只能為提供參考,不一定能成為您想要的結果。以下是C++中new的越界拜訪成績正文
明天敲代碼的時刻發明了一個BUG和年夜家分享一下,願望年夜家下次不要犯和我一樣的毛病。
假如犯了和我一樣的錯,也能曉得本身錯在哪裡! <(^-^)>
函數以下:(斐波那契數列的完成)
long long FibonacciSeq( int n) { long long *fib=new long long[n+1]; fib[0] = 0; fib[1] = 1; for (int i = 2;i <=n; i++) { fib[i] = fib[i - 1] + fib[i - 2]; } long long ret = fib[n]; delete[] fib; return ret; }
下面的法式有BUG,假如傳給函數的參數是0,法式就會由於觸發一個斷點而瓦解。
單步驟試,依據內存窗口就會發明成績地點!
fib指向的內存初始化完成後,其的內存情形如上圖,我們可以不雅察到這塊內存的前後都有 fd fd fd fd ,0xFD為初始化受掩護的內存(debug版在靜態分派內存的前後參加掩護內存以避免越界拜訪),而fib[1] = 1;正好把fd fd fd fd 和它前面的四個字節改成了01 00 00 00 00 000000,以下圖:
法式運轉到delete[] fib;時只找到了“受掩護的內存標記”的肇端地位,別的一個“受掩護的內存標記”找不到了,所以法式運轉會掉敗!
其實很簡略,也就是產生了越界拜訪!我只new了一塊空間,卻存了兩個變量,固然不可了!