#include <iostream> #include <cstring> #include <string> using namespace std; int main() { int* str = new int[1]; str[2] = 1; cout << str[2] << endl; return 0; }
为什么这段代码可以正常运行哦?str不是指向的一个大小的内存吗?
闭关修行中......
C的數組標識符,裡面並沒有包含該數組長度的信息,只包含地址信息,所以語言本身無法檢查,只能通過編譯器檢查,而早期的C語言編譯器也不對數組越界進行檢查,只能由程式設計師自己檢查確保。以及在早期的CRT函數中也不對字串指標或陣列進行越界檢查,都是要求程式設計師確保空間足夠,因此也才有了在VS2005之後微軟提供的安全的CRT函數版本。即使越界也能正常編譯通過,試著擴大一下範圍,同時輸出地址,可以看出,確實是訪問了越界的地址
#include <iostream> #include <cstring> #include <string> using namespace std; int main() { int* str = new int[1]; str[10000] = 1; cout << str << endl; cout << &str[10000] << endl; cout << str[10000] << endl; return 0; }
0x1005000000x100509c401Program ended with exit code: 0
不是沒有問題,只是剛好沒出現錯誤而已。 你造訪了一個不屬於你的空間,而那個空間剛好沒人在使用,所以看起來沒問題。
C的數組標識符,裡面並沒有包含該數組長度的信息,只包含地址信息,所以語言本身無法檢查,只能通過編譯器檢查,而早期的C語言編譯器也不對數組越界進行檢查,只能由程式設計師自己檢查確保。以及在早期的CRT函數中也不對字串指標或陣列進行越界檢查,都是要求程式設計師確保空間足夠,因此也才有了在VS2005之後微軟提供的安全的CRT函數版本。即使越界也能正常編譯通過,試著擴大一下範圍,同時輸出地址,可以看出,確實是訪問了越界的地址
0x100500000
0x100509c40
1
Program ended with exit code: 0
不是沒有問題,只是剛好沒出現錯誤而已。
你造訪了一個不屬於你的空間,而那個空間剛好沒人在使用,所以看起來沒問題。