您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關C語言如何實現數組越界的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
數組的下標是有范圍限制的。
數組的下規定是從0開始的,如果數組有n個元素,最后一個元素的下標就是n-1。
所以數組的下標如果小于0,或者大于n-1,就是數組越界訪問了,超出了數組合法空間的訪問。
C語言本身是不做數組下標的越界檢查,編譯器也不一定報錯,但是編譯器不報錯,并不意味著程序就是正確的,
二維數組的行和列也可能存在越界。
所以程序員寫代碼時,最好自己做越界的檢查
#include <stdio.h> int main() { int i = 0; int arr[] = {1,2,3,4,5,6,7,8,9,10}; for(i=0; i<=12; i++)//在這里數組越界訪問了,但這是主要問題嗎? { arr[i] = 0; printf("haha\n"); } return 0; }
讓我們公布答案吧!
這段代碼的bug是死循環
很抱歉滿屏的haha吵到了你的眼睛(手動狗頭)
是不是難以想象?請帶著疑惑看看下文解釋
有以下幾個規則:
i和arr是局部變量
局部變量是放在棧區上的
棧區上內存的使用習慣是:先使用高地址處空間再使用地地址處空間
數組隨著下標的增長,地址由低到高變化
示意圖如下
“由低到高”和“由高到低”相遇了。
arr [12] = 0; 間接改變了i,相當于i = 0;
這樣一來i又從0依次變大再回歸0,實現了死循環的局面
至于空白格子代表的局部變量儲存時相間隔的的字節個數是如何確定的, 這得看不同編譯器了。vs編譯器是空兩格,其他編譯器是什么樣的,感興趣可以自己探索哦。
感謝各位的閱讀!關于“C語言如何實現數組越界”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。