網站首頁 編程語言 正文
數組(array)是由一系列類型相同的元素構成。
一般形式:
類型? ? ?數組名? [常量表達式]
一,一維數組
1.創建和初始化
創建一堆相同元素的集合,以整型為例:
//創建大小為8的整型數組 int arr1[8]; // []里面應放常量,因此若: int num=8; //則有: arr2[num]; num為變量,創建失敗 // 此時 arr1 != arr2
初始化就是合理賦值,有多種方式,合理即可:
//指定大小的初始化 int arr1[3]={1,2,3}; //不指定大小的初始化 int arr2[]={1,2,3}; //指定大小的不完全初始化 int arr3[3]={1,2};
這里創建字符數組時應注意這種情況:
char arr1[] = {"abcdef"}; char arr2[] = {'a','b','c','d','e','f'};
這兩種初始化看著內容相同,但 arr1 不等同于 arr2,這里我們用 strlen函數 分別求他們的字符串長度:
arr1是我們能想到的,但是arr2卻超出預料,原因是strlen遇到字符'\0'?('\0'為結束標志)結束讀取,且打印出的個數里不算字符'\0'.
arr1字符串末尾f后面默認有結束標志,而arr2字符f后面無結束標志,為隨機值,strlen必須讀取到'\0'才會結束讀取,因此讀取到的為隨機數。
//改寫arr2為: char arr2[] = {'a','b','c','d','e','f','\0'};
那么結果:
2.使用下標訪問
數組是用 [] 來進行下標訪問的,數組下標從0開始。
? ?如:? ? ? ?arr1[3]={1,2,3};
則數據的下標為:? 0 1 2? ? ? ? 一一對應
寫個栗子,分別打印 int arr2[5]={1,2,3,4,5};
的每個元素
注:int sz = sizeof(arr2) / sizeof(arr2[0]);
? //通過字節計算元素個數,確定判斷條件 因為已經知道了元素個數里可省略 直接令 i<5.
#include <stdio.h> int main() { int i = 0; int arr2[5] = { 1, 2, 3, 4, 5 }; //創建數組arr2并初始化 int sz = sizeof(arr2) / sizeof(arr2[0]); //通過字節計算元素個數,確定判斷條件 for (i = 0; i < sz; i++) { printf("%d ",arr2[i]); 下標從0開始,依次訪問每個元素 } return; }
3.在內存中的存儲
由上面的栗子我們直接打印數組每個元素的內存:
觀察不難發現每個元素間相差四個字節,且地址由低到高。
得到結論:數組在內存中是連續存放的。
二,二維數組?
1.創建和初始化
一般形式:
類型? ? ?數組名? [常量表達式][常量表達式]
//數組創建 int arr[3][4]; //三行四列 char arr[3][6]; //三行六列
一維是單行,這里可將二維理解為行列
初始化也與一維數組沒多少差別:
//指定大小的初始化 int arr1[3][4]={1,2,3,4,5,6,7,8,9,10,11,12}; //不指定大小的初始化,(行可不指定,但列不可省略,必須指定) int arr2[][6]={1,2,3}; int arr3[][4]={{1,2},{3,4},5,6,7,8,9}; //賦值中{}里面的{}可代表一行的內容 //指定大小的不完全初始化 int arr4[3][2]={1,2,3};
不完全初始化的值為0
2.使用下標訪問
二維數組的訪問就很有意思? ?將二維數組看成行列 用坐標來訪問
以? int arr1[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
? ?三行四列? 為例:
注:列和行的下標都是從0開始
比如我們想打印6,那么應該是arr1[1][1],而不是arr1[2][2].
3.在內存中的存儲
繼續以arr1為例:
地址依舊是連續的,由低地址到高地址。
三,越界問題
例如:
創建一個數組? int arr1[3][4]={1,2,3,4,5,6,7,8,9,10,11,12};
? 訪問時行不能<0 或 >=3,列不能<0 或 >=4,否則就是數組越界。
編譯代碼時,越界不一定會報錯,注意自己檢查。
原文鏈接:https://blog.csdn.net/weixin_53316121/article/details/121198747
相關推薦
- 2022-03-24 聊一聊redis奇葩數據類型與集群知識_Redis
- 2022-11-24 詳解Linux中atime,mtime,ctime的使用場景_linux shell
- 2023-01-29 python缺失值填充方法示例代碼_python
- 2022-06-29 Python?高級教程之線程進程和協程的代碼解析_python
- 2022-03-06 SQLServer批量插入數據的三種方式及性能對比_C#教程
- 2023-07-22 JVM的類加載機制和垃圾回收機制
- 2022-10-26 Google?Kubernetes?Engine?集群實戰詳解_云其它
- 2022-08-24 使用chrome控制臺作為.Net的日志查看器_實用技巧
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支