您好,登錄后才能下訂單哦!
今天小編給大家分享一下C++的原生數(shù)組是什么的相關(guān)知識點,內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
數(shù)據(jù)類型 數(shù)組變量名稱[數(shù)組元素個數(shù)]{初始化值, 初始化值...}
int a[10]{};
變量類型 數(shù)組名[]{初始化, 初始化...}
int a []{1, 2, ,3};//編譯器會自動將a聲明為一個有3個元素的數(shù)組
數(shù)組的本質(zhì)是按照所申請的數(shù)據(jù)類型,向操作系統(tǒng)申請了一段連續(xù)的內(nèi)存空間。兩個特征:
連續(xù)的有序的
int studentId[]{101, 102, 103, 104, 105, 106}; //數(shù)組遍歷 for (int i = 0; i < sizeof(studentId) / sizeof(int); i++) std::cout << studentId[i] << std::endl;
for(變量類型 變量名稱:數(shù)組)
循環(huán)內(nèi)容;
for (int i : studentId) std::cout << i << std::endl; //i 不再是索引,而是數(shù)組內(nèi)的元素;
for(auto 變量名稱:數(shù)組)
循環(huán)內(nèi)容;
for (auto i : studentId) std::cout << i << std::endl; //i 不再是索引,而是數(shù)組內(nèi)的元素;
類型 變量名稱[元素個數(shù)][元素個數(shù)]...[元素個數(shù)]{};
int studentId[3][5]{};
多維數(shù)組的初始化:
int studentId[3][5] { {101, 102, 103, 104, 105, 106}, {201, 202, 203, 204, 205, 206}, {301, 302, 303, 304, 305, 306} };
int studentId[3][5]{ {1, 2, 3, 4, 5}, {11, 12, 13, 14, 15}, {21, 22, 23, 24, 25} }; for (int x = 0; x < 3; x++) { int count{}; for (int y: studentId[x]) { count++; std::cout << x + 1 << "班第" << count << "個同學(xué)的學(xué)號是" << y << std::endl; } }
由于數(shù)組的本質(zhì)是向操作系統(tǒng)申請了一塊內(nèi)存,因此越界的數(shù)組將會訪問到不該訪問的地址,這種越界將會造成程序奔潰,BUG,錯誤,更可怕的是,數(shù)組越界漏洞,可能會讓攻擊著拿到操作系統(tǒng)的控制權(quán)。
以上就是“C++的原生數(shù)組是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。