亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++教程之array數(shù)組使用示例詳解

 更新時間:2023年03月08日 15:21:47   作者:月下西樓  
這篇文章主要為大家介紹了C++教程之array數(shù)組使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

背景

上一篇文章我們介紹了C++中的迭代器,這篇文章將會介紹C++中數(shù)組的概念,數(shù)組是一種和vector類似的數(shù)據結構,但是其在性能和靈活性上的權衡中選擇了性能而放棄了一定的靈活性,其與vector相同的地方是,它們都是同一類型的對象的容器,也都可以通過下標訪問。其不同點是數(shù)組的大小是固定的,所以無法向一個數(shù)組添加元素,也正是因為其大小固定,所以其在運行時有更好的性能。

定義和初始化數(shù)組

數(shù)組是一個復合類型,可以通過類似a[d]的形式定義,其中a是數(shù)組名,d是數(shù)組的容量,d必須要大于0,數(shù)組的容量是數(shù)組類型的一部分,其導致數(shù)組容量必須要在編譯時就已知,這要求數(shù)組容量必須是常量表達式,以下提供了數(shù)組聲明的幾種形式:

unsigned cnt = 42; //不是一個常量表達式
constexpr unsigned sz = 42; //是常量表達式

int arr[10]; //聲明一個容量為10的整型數(shù)組
int *parr[sz]; //42個指向整形指針的數(shù)組
string bad[cnt]; //這是個錯誤聲明,因為cnt不是常量表達式

默認情況下,數(shù)組里面的元素都會被默認初始化。

我們可以通過列表初始化一個數(shù)組,通過這種方式我們在定義時可以忽略數(shù)組的容量,如果我們指定了數(shù)組容量,那么在列表初始化時初始化的元素數(shù)量不能超過設置的容量值,如果少于設置的數(shù)組的數(shù)量,沒有指定值的元素會使用默認初始化的值,例子如下:

const unsigned sz = 3;
int a1[sz] = {0, 1, 2};
int a2[] = {0, 1, 2}; //可以忽略數(shù)組的容量
int a3[5] = {0, 1, 2}; //等價于{0, 1, 2, 0, 0}
string a4[3] = {"hi", "bye"}; //等價于{"hi", "bye", ""}
int a5[2] = {0, 1, 2}; //錯誤

字符數(shù)組的定義

字符數(shù)組有一個額外的初始化方式,就是可以通過一個字符還去初始化字符數(shù)組,但是需要注意的是string是以null字符結尾的,所以在定義數(shù)組容量時要考慮null字符:

char a1[] = "C++"; //其等價于{'C', '+', '+', '\0'}
char a2[6] = "Daniel" //錯誤,其未考慮到null字符

?需要注意的是一些編譯器是不支持數(shù)組的拷貝,如果直接通過一個數(shù)組去初始化另一個數(shù)組可能會報錯?

理解復雜的數(shù)組聲明

正如vector,array也可以容納所有的類型,例如指針的數(shù)組,由于數(shù)組是一個對象,所以可以定義指向數(shù)組的指針和引用,,定義指向數(shù)組的指針或者引用可以通過以下方式:

int *ptre[10]; //ptre是一個數(shù)組,其中的元素是10個指向整型的指針
int (*parray)[10] = &arr; //parray是一個指針,其指向的對象是一個容量為10的整型數(shù)組
int (&arrRef)[10] = arr; //arrRef是一個引用,其指向的是一個容量為10的整型數(shù)組

?在理解聲明時可以按照從左到右,從內到外的順序。?

指針與數(shù)組

在C++中指針和數(shù)組關系是很近的,一般來說,當我們使用一個數(shù)組,編譯器會自動將其轉化為一個指針,一般來說我們是通過地址操作符來獲取一個對象的指針的,但是對于數(shù)組而言,當我們使用數(shù)組時,編譯器將會自動獲取一個指針指向數(shù)組的第一個元素:

string nums = {"one", "two", three}; 
string *p = &nums[0]; //p指向nums的第一個元素
string *p2 = nums //等價于string *p = &nums[0];

?在大多數(shù)表達式中,我們使用數(shù)組對象,我們其實是獲取一個指針指向數(shù)組的第一個元素?

由于這個影響,我們對于數(shù)組的操作其實絕大多數(shù)都是對于指針的操作,其中一個比較明顯的是當我們使用auto和數(shù)組去初始化一個變量時,其實是聲明了一個指針而不是數(shù)組:

int ia[] = {0, 1, 2, 3, 4};
auto ia2(ia); //ia2是一個整形指針,指向ia的第一個元素
ia2 = 43 //錯誤,不可以將int賦值給一個指針
auto ia3(&ia[0]) //這樣看起來更清楚,ia3是整型指針

需要注意的是當我們使用之前提到的decltype時不會發(fā)生這種轉化, decltype(ia)返回的類型是10個整型的數(shù)組:

decltype(ia) ia3 = {0, 1, 2, 3, 4};
ia3 = p; // 錯誤,不可以將一個整型指針賦值給一個數(shù)組
ia3[4] = i; //正確,可以對數(shù)組的元素賦值

指針是迭代器

指針也是迭代器,指向數(shù)組元素的指針同樣支持我們之前提到的vector和string中迭代器的操作,例如可以通過自增操作實現(xiàn)從一個元素移動到下一個元素:

int arr[] = [0, 1, 2, 3, 4, 5];
int *p = arr; //現(xiàn)在p指向arr[0]
++p; //現(xiàn)在p指向arr[1]

正如我們可以使用迭代器遍歷vector中的元素,我們也可以使用指針去遍歷數(shù)組中的元素,我們可以通過上面的方式獲取數(shù)組的第一個元素的指針,那么我們又該如何獲取數(shù)組最后一個元素之后的不存在的元素呢,我們可以通過以下方式:

int *e = &arr[6];

我們只可以獲取最后一個元素的下一個元素的地址

for (int *b = arr; b != e; ++b)
    cout<< *b<<endl

雖然我們可以通過上述方式獲取數(shù)組的第一個元素的地址和最后一個元素的下一個地址,但是這并不是一個好的方法,在新的規(guī)范中已經提供了新的函數(shù)begin和end可以獲取數(shù)組的第一個元素的地址和最后一個元素的下一個地址:

int ia[] = {0, 1, 2, 3, 4};
int *beg = begin(ia);
int *last = end(ia);

指針的算術運算

指向數(shù)組元素的指針可以使用我們之前在迭代器的文章中提到的所有的迭代器的操作,當我們使用指針加上或者減去一個整型的值時我們將會獲得一個新的指針,這個指針指向原來數(shù)組元素前或者后幾個位置的元素,具體的位置取決于加或者減的值:

constexpr size_t sz = 5;
int arr[sz] = {1, 2, 3, 4, 5};
int *p1 = arr; //等價于*p1 = &arr[0]
int *p2 = p1 + 4; //p2指向arr[4]

當我們用數(shù)組加上sz時,編譯器會把arr轉化為指向數(shù)組第一個元素的指針,所以如下p就是指向數(shù)組最后一個元素的下一個元素,如果相加結果超出數(shù)組的范圍則會發(fā)生錯誤:

int *p = arr + sz; //小心使用,沒有解引用
int *p3 = arr + 10; //錯誤,數(shù)組只有5個元素,雖然編譯器可能無法檢測到這個錯誤

和迭代器一樣,兩個指針相減其結果是兩個指針之間的距離,其前提是這兩個指針式同一個數(shù)組中的元素:

auto n = end(arr) - begin(arr);

解引用和指針的算術運算

通過上面的介紹我們已經知道了指針也有算數(shù)運算,那么如何判斷是指針的算術運算還是元素的算術運算呢,可以和之前復雜的指針對應,都是先從括號內部開始:

int ia = {0, 2, 4, 6, 8};
int last = *(ia + 4); //先看括號內,所以這是指針的元素暗,last = ia[4] = 8
int last2 = *ia + 4; //ia指向ia[0], 所以last2 = ia[0] + 4 = 4

下標與指針

我們可以看到數(shù)組其實就是一個指向數(shù)組第一個元素的指針,所以對于數(shù)組的下標操作其實就是對于指針的算數(shù)元運算,ia[2]等價于*(ia + 2):

int ia = {0, 2, 4, 6, 8};
int *p = &ia[2]; //p指向ia[2]的指針
int j = p[-2]; p[-2]等價于*(p - 2), 所以j = ia[0]

最后

這篇文章主要講述的是C++數(shù)組相關的內容,更多關于C++ 數(shù)組教程的資料請關注腳本之家其它相關文章!

相關文章

  • 淺談C語言編程中程序的一些基本的編寫優(yōu)化技巧

    淺談C語言編程中程序的一些基本的編寫優(yōu)化技巧

    這篇文章主要介紹了C語言編程中程序的一些基本的編寫優(yōu)化技巧,文中涉及到了基礎的C程序內存方面的知識,非常推薦!需要的朋友可以參考下
    2016-02-02
  • C++ 位運算的具體實現(xiàn)

    C++ 位運算的具體實現(xiàn)

    位運算直接對內存數(shù)據進行操作,不需要轉換成十進制,因此處理速度非???本文主要介紹了C++ 位運算的具體實現(xiàn),具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • C++實現(xiàn)模板中的非類型參數(shù)的方法

    C++實現(xiàn)模板中的非類型參數(shù)的方法

    這篇文章主要介紹了C++實現(xiàn)模板中的非類型參數(shù)的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • C語言編程中常見的五種錯誤及對應解決方案

    C語言編程中常見的五種錯誤及對應解決方案

    這篇文章主要給大家分享的是C語言編程中常見的五種錯誤及對應解決方案,詳細內容就請跟小編一起進入下面的文章內容吧
    2021-10-10
  • visual studio2019的安裝以及使用圖文步驟詳解

    visual studio2019的安裝以及使用圖文步驟詳解

    這篇文章主要介紹了visual studio2019的安裝以及使用圖文步驟詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • C++超詳細探究new/delete的使用

    C++超詳細探究new/delete的使用

    這篇文章主要介紹了C++中new與deleted關鍵字的使用,new在動態(tài)內存中為對象分配空間并返回一個指向該對象的指針;delete接受一個動態(tài)對象的指針, 銷毀該對象, 并釋放與之關聯(lián)的內存
    2022-07-07
  • c++中STL庫隊列詳細介紹

    c++中STL庫隊列詳細介紹

    大家好,本篇文章主要講的是c++中STL庫隊列詳細介紹,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • Matlab實現(xiàn)極坐標堆疊柱狀圖的繪制

    Matlab實現(xiàn)極坐標堆疊柱狀圖的繪制

    極坐標堆疊圖也是風玫瑰圖的常用形式,MATLAB的bar繪制的條形圖可以繪制成堆疊形式,但是并沒有一個自帶函數(shù)可以繪制極坐標堆疊圖。本文將為大家提供Matlab繪制極坐標堆疊柱狀圖的示例代碼,需要的可以參考一下
    2022-08-08
  • c語言讀取txt文件內容簡單實例

    c語言讀取txt文件內容簡單實例

    在本篇文章里小編給大家整理的是關于c語言如何讀取txt文件內容,需要的朋友們可以參考下。
    2020-03-03
  • C++高級數(shù)據結構之優(yōu)先隊列

    C++高級數(shù)據結構之優(yōu)先隊列

    這篇文章主要介紹了C++高級數(shù)據結構之優(yōu)先隊列,文章圍繞主題的相關資料展開詳細介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-05-05

最新評論