C++數(shù)組的定義詳情
上一篇講解了類型,通過類型來開始本篇的學(xué)習(xí);
int a[10];
上述代碼中的a是什么類型呢?
相信很多人都知道是一個(gè)數(shù)組類型,具體來說是一個(gè)int[10]的類型;
1.數(shù)組概念
定義:將一到多個(gè)相同對(duì)象串連到一起,所組成的類型;
初始化方式:
- 缺省初始化:
int x[5]; - 聚合初始化:
int x[] = {1,2,3};
注意:
- 不能用
auto來聲明數(shù)組類型; - 數(shù)組不能復(fù)制,也不能賦值;
2.數(shù)組的復(fù)雜聲明
指針數(shù)組的聲明:
int *i[5];
大家思考下i的類型是什么?
指針數(shù)組表示數(shù)組內(nèi)的每個(gè)元素都是int*類型,所以i的類型為int *[5];
數(shù)組指針的聲明:
int (*x)[5];
大家思考下x的類型是什么?
這里a是一個(gè)指針,類型為int(*)[5];
3.數(shù)組到指針
- 使用數(shù)組對(duì)象時(shí),通常會(huì)產(chǎn)生數(shù)組到指針的隱式轉(zhuǎn)換;
- 可通過引用聲明來避免隱式轉(zhuǎn)換;
int a[3] = {1, 2, 3};
auto b = a; // b的類型為int*
auto &b = a; // b的類型為int(&) [3]
數(shù)組和指針的轉(zhuǎn)換關(guān)系圖

指向數(shù)值開頭的指針很好獲得,比如a、&(a[0])、std::begin(a);
獲取指向數(shù)組結(jié)尾的指針(上圖指向80):a+3、&(a[3])、std::end(a);
使用標(biāo)準(zhǔn)庫(kù)獲取開頭和結(jié)尾指針的方法在別的數(shù)據(jù)類型也適用;
4.數(shù)組操作
4.1獲取數(shù)組元素個(gè)數(shù)
int x[3]; // 方法一 std::cout << sizeof(x) / sizeof(int) << std::endl; // 方法二 std::cout << std::size(a) << std::endl; // 方法三 std::cout << std::end(a) - std::begin(a) << std::endl;
方法三實(shí)際上是在運(yùn)行期才執(zhí)行的,增加程序運(yùn)行耗時(shí),不推薦;
方法一類型需要自己傳入,適用性差,不推薦;
推薦用方法二;
4.2使用for循環(huán)遍歷數(shù)組(C++11開始支持)
int a[3] = {1, 2, 3};
for (int x: a)
{
std::cout << x << std::endl;
}
5.拓展
5.1C字符串
- C字符串本質(zhì)也是數(shù)組;
- 聲明一個(gè)字符數(shù)組并打印長(zhǎng)度
#include <cstring> char a[] = "Hello"; std::cout << strlen(a) <<std::endl;
使用函數(shù)strlen需要引入頭文件cstring;
5.2vector
定義:是C++標(biāo)準(zhǔn)庫(kù)中定義的類模板;
與內(nèi)建數(shù)組相比,更側(cè)重于易用性(相對(duì)而言性能比內(nèi)建數(shù)組差),可復(fù)制,可在運(yùn)行期動(dòng)態(tài)改變?cè)貍€(gè)數(shù);
初始化與構(gòu)建
// 1、聚合初始化
std::vector<int> x = {1, 2, 3};
// 2、其他初始化方式
std::vector<int> x(3, 1); // 個(gè)數(shù)為3,并且每個(gè)元素都為1
? vector的初始化方式還有很多,可參考:https://en.cppreference.com/w/cpp/container/vector/vector
獲取元素個(gè)數(shù)
std::cout << x.size() << std::endl;
判斷為空
std::cout << x.empty() << std::endl;
尾部添加元素
x.push_back(2); // 向容器中添加一個(gè)整數(shù)2
刪除最后一個(gè)元素
x.pop_back();
打印vector中的元素
std::vector<int> x = {1, 2, 3};
x[2]; // 跟數(shù)組一樣,越界不報(bào)錯(cuò)
x.at(2); // 不可以越界
在標(biāo)準(zhǔn)庫(kù)中的begin和end函數(shù),在vector中也有同名的方法并且作用相同,返回一個(gè)迭代器;
可以使用指針引用一個(gè)vector對(duì)象的方法:
std::vector<int> x = {1, 2, 3};
std::vector<int>* p = &x;
std::cout << p->size() << std::endl;
5.3string
定義:是C++標(biāo)準(zhǔn)庫(kù)中定義的一個(gè)類模板特化別名,用于內(nèi)建字符串的替代品;
- 與內(nèi)建字符串相比,更側(cè)重易用性,可復(fù)制,可在運(yùn)行期動(dòng)態(tài)改變字符串個(gè)數(shù);
- 構(gòu)造和初始化,可參考:https://en.cppreference.com/w/cpp/string/basic_string
- 支持比較、賦值、拼接、索引、轉(zhuǎn)換為C字符串(c_str());
6.思考
6.1思考以下代碼輸出什么?
int i[3] = {1, 2, 3};
std::cout << *(a) << std::endl; // 第一行
std::cout << *(a + 1) << std::endl; // 第二行
第一行的輸出是1,第二行輸出的是2,這就相當(dāng)于a[0]和a[1]的值,說明數(shù)組底層也是指針實(shí)現(xiàn),第二行中加一表示首地址地址移動(dòng)類型大小的字節(jié);
6.2以下代碼能夠編譯通過嗎?
int a[2] = {1, 2};
std::cout << a[100] << std::endl;
這個(gè)數(shù)組越界在C++中是可以編譯通過的,會(huì)輸出一個(gè)毫無關(guān)系的值,編譯器不會(huì)有邊界檢查,需要特別注意!
6.3在另一個(gè)文件中定義了數(shù)組,如何在該文件中定義?
test.cpp:
int arr[3] = {1, 2, 3};
main.cpp:
extern int arr[];
上述聲明稱為不完整類型的聲明,可以在main.cpp中找到test.cpp定義的數(shù)組;
總結(jié):
本篇簡(jiǎn)要介紹了數(shù)組的常用方法以及C++標(biāo)準(zhǔn)庫(kù)提供的一些關(guān)于數(shù)組的容器,大家也可以從思考部分來了解數(shù)組的一些細(xì)節(jié);
到此這篇關(guān)于C++數(shù)組的定義詳情的文章就介紹到這了,更多相關(guān)C++數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談C結(jié)構(gòu)和C++結(jié)構(gòu)之間的區(qū)別
這篇文章主要介紹了淺談C結(jié)構(gòu)和C++結(jié)構(gòu)之間的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
c++11多種格式時(shí)間轉(zhuǎn)化為字符串的方法實(shí)現(xiàn)
本文主要介紹了c++11多種格式時(shí)間轉(zhuǎn)化為字符串的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
C++ stack與queue模擬實(shí)現(xiàn)詳解
這篇文章主要給大家介紹了關(guān)于c++stack與queue模擬實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08
C語(yǔ)言實(shí)現(xiàn)的bitmap位圖代碼分享
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)的bitmap位圖代碼分享,位圖(bitmap)是一種非常常用的結(jié)構(gòu),在索引、數(shù)據(jù)壓縮等方面有廣泛應(yīng)用,需要的朋友可以參考下2014-08-08
Qt實(shí)現(xiàn)小功能之圓形進(jìn)度條的方法詳解
在Qt自帶的控件中,只有垂直進(jìn)度條、水平進(jìn)度條兩種。在平時(shí)做頁(yè)面開發(fā)時(shí),有些時(shí)候會(huì)用到圓形進(jìn)度條,比如說:下載某個(gè)文件的下載進(jìn)度。本文就來實(shí)現(xiàn)一個(gè)圓形進(jìn)度條,需要的可以參考一下2022-10-10
C++實(shí)現(xiàn)LeetCode(108.將有序數(shù)組轉(zhuǎn)為二叉搜索樹)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(108.將有序數(shù)組轉(zhuǎn)為二叉搜索樹),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C語(yǔ)言用指針函數(shù)尋找數(shù)組中的最大值與次大值
這篇文章主要給大家介紹了關(guān)于C語(yǔ)言用指針函數(shù)尋找數(shù)組中的最大值與次大值的相關(guān)資料,該代碼通過定義一個(gè)名為L(zhǎng)argestTow的函數(shù)來找出數(shù)組中的最大值和次大值,并將結(jié)果分別存入指針?biāo)赶虻膬?nèi)存單元中,需要的朋友可以參考下2024-11-11

