欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++數(shù)組的定義詳情

 更新時(shí)間:2022年01月24日 16:47:43   作者:一個(gè)熱愛(ài)學(xué)習(xí)的深度渣渣  
這篇文章主要介紹了C++數(shù)組的定義詳情,上一篇文章我們學(xué)習(xí)了類(lèi)型,接下倆我們九在類(lèi)型的基礎(chǔ)上展開(kāi)本篇內(nèi)容數(shù)組的常用方法以及C++標(biāo)準(zhǔn)庫(kù)提供的一些關(guān)于數(shù)組的容器,需要的朋友可以參考一下,希望對(duì)你有所幫助

上一篇講解了類(lèi)型,通過(guò)類(lèi)型來(lái)開(kāi)始本篇的學(xué)習(xí);

int a[10];

上述代碼中的a是什么類(lèi)型呢?

相信很多人都知道是一個(gè)數(shù)組類(lèi)型,具體來(lái)說(shuō)是一個(gè)int[10]的類(lèi)型;

1.數(shù)組概念

定義:將一到多個(gè)相同對(duì)象串連到一起,所組成的類(lèi)型;

初始化方式:

  • 缺省初始化int x[5];
  • 聚合初始化int x[] = {1,2,3};

注意:

  • 不能用auto來(lái)聲明數(shù)組類(lèi)型;
  • 數(shù)組不能復(fù)制,也不能賦值;

2.數(shù)組的復(fù)雜聲明

指針數(shù)組的聲明:

int *i[5];

大家思考下i的類(lèi)型是什么?

指針數(shù)組表示數(shù)組內(nèi)的每個(gè)元素都是int*類(lèi)型,所以i的類(lèi)型為int *[5];

數(shù)組指針的聲明:

int (*x)[5];

大家思考下x的類(lèi)型是什么?

這里a是一個(gè)指針,類(lèi)型為int(*)[5];

3.數(shù)組到指針

  • 使用數(shù)組對(duì)象時(shí),通常會(huì)產(chǎn)生數(shù)組到指針的隱式轉(zhuǎn)換;
  • 可通過(guò)引用聲明來(lái)避免隱式轉(zhuǎn)換;
int a[3] = {1, 2, 3};
auto b = a;  // b的類(lèi)型為int*
auto &b = a; // b的類(lèi)型為int(&) [3]

數(shù)組和指針的轉(zhuǎn)換關(guān)系圖

指向數(shù)值開(kāi)頭的指針很好獲得,比如a、&(a[0])、std::begin(a);

獲取指向數(shù)組結(jié)尾的指針(上圖指向80):a+3、&(a[3])、std::end(a);

使用標(biāo)準(zhǔn)庫(kù)獲取開(kāi)頭和結(jié)尾指針的方法在別的數(shù)據(jù)類(lèi)型也適用;

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í),不推薦;

方法一類(lèi)型需要自己傳入,適用性差,不推薦;

推薦用方法二;

4.2使用for循環(huán)遍歷數(shù)組(C++11開(kāi)始支持)

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ù)中定義的類(lèi)模板;

與內(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ù)中的beginend函數(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è)類(lèi)模板特化別名,用于內(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]的值,說(shuō)明數(shù)組底層也是指針實(shí)現(xiàn),第二行中加一表示首地址地址移動(dòng)類(lèi)型大小的字節(jié);

6.2以下代碼能夠編譯通過(guò)嗎?

int a[2] = {1, 2};
std::cout << a[100] << std::endl;

這個(gè)數(shù)組越界在C++中是可以編譯通過(guò)的,會(huì)輸出一個(gè)毫無(wú)關(guān)系的值,編譯器不會(huì)有邊界檢查,需要特別注意!

6.3在另一個(gè)文件中定義了數(shù)組,如何在該文件中定義?

test.cpp:

int arr[3] = {1, 2, 3};

main.cpp:

extern int arr[];

上述聲明稱為不完整類(lèi)型的聲明,可以在main.cpp中找到test.cpp定義的數(shù)組;

總結(jié):

本篇簡(jiǎn)要介紹了數(shù)組的常用方法以及C++標(biāo)準(zhǔn)庫(kù)提供的一些關(guān)于數(shù)組的容器,大家也可以從思考部分來(lái)了解數(shù)組的一些細(xì)節(jié);

到此這篇關(guān)于C++數(shù)組的定義詳情的文章就介紹到這了,更多相關(guān)C++數(shù)組內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++ Struct結(jié)構(gòu)體用法淺析

    C++ Struct結(jié)構(gòu)體用法淺析

    前邊我們所定義的類(lèi),均是使用struct關(guān)鍵字來(lái)定義,但是C++中真正用于定義類(lèi)的關(guān)鍵字為class,因?yàn)橐狢++兼容C,所以保留struct關(guān)鍵字,struct與class的用法完全相同
    2023-03-03
  • OpenCV輪廓檢測(cè)之boundingRect繪制矩形邊框

    OpenCV輪廓檢測(cè)之boundingRect繪制矩形邊框

    在進(jìn)行文本檢測(cè)時(shí),我們常常會(huì)用矩形邊框?qū)z測(cè)到的內(nèi)容框除。這篇文章主要為大家介紹的是OpenCV中能實(shí)現(xiàn)這一效果的函數(shù):boundingRect,感興趣的同學(xué)可以學(xué)習(xí)一下
    2021-12-12
  • C++詳解Primer文本查詢程序的實(shí)現(xiàn)

    C++詳解Primer文本查詢程序的實(shí)現(xiàn)

    這個(gè)程序還是比較復(fù)雜的,把這句話作為文章的開(kāi)頭可以看出它的真實(shí)性.....這篇文章主要介紹了文本查詢程序的實(shí)現(xiàn),下面我們一起來(lái)看看
    2022-06-06
  • C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理系統(tǒng)開(kāi)發(fā)

    C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理系統(tǒng)開(kāi)發(fā)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理系統(tǒng)開(kāi)發(fā),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C語(yǔ)言中free函數(shù)的使用詳解

    C語(yǔ)言中free函數(shù)的使用詳解

    free函數(shù)是釋放之前某一次malloc函數(shù)申請(qǐng)的空間,而且只是釋放空間,并不改變指針的值。下面我們就來(lái)詳細(xì)探討下
    2017-05-05
  • OpenSSL使用AES實(shí)現(xiàn)文件加解密功能

    OpenSSL使用AES實(shí)現(xiàn)文件加解密功能

    AES是一種對(duì)稱加密算法,它是目前廣泛使用的加密算法之一,意味著加密和解密使用相同的密鑰,這就要求密鑰的安全性非常重要,因?yàn)槿魏螕碛忻荑€的人都能進(jìn)行加密和解密操作,本文給大家介紹了OpenSSL如何使用AES實(shí)現(xiàn)文件加解密功能,需要的朋友可以參考下
    2023-11-11
  • C++實(shí)現(xiàn)簡(jiǎn)單推箱子小游戲

    C++實(shí)現(xiàn)簡(jiǎn)單推箱子小游戲

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單推箱子小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • c++重載運(yùn)算符時(shí)返回值為類(lèi)的對(duì)象或者返回對(duì)象的引用問(wèn)題

    c++重載運(yùn)算符時(shí)返回值為類(lèi)的對(duì)象或者返回對(duì)象的引用問(wèn)題

    這篇文章主要介紹了c++重載運(yùn)算符時(shí)返回值為類(lèi)的對(duì)象或者返回對(duì)象的引用問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C++線程同步實(shí)例分析

    C++線程同步實(shí)例分析

    這篇文章主要介紹了C++線程同步實(shí)例分析,以實(shí)例的形式較為深入的分析了C++的線程同步問(wèn)題,是一個(gè)較為經(jīng)典的線程同步問(wèn)題,需要的朋友可以參考下
    2014-10-10
  • C++如何實(shí)現(xiàn)廣義表詳解

    C++如何實(shí)現(xiàn)廣義表詳解

    廣義表是非線性結(jié)構(gòu),其定義是遞歸的。那么下面跟著小編一起看看如何用C++實(shí)現(xiàn)廣義表,有需要的可以參考借鑒。
    2016-08-08

最新評(píng)論