C語言深入分析數(shù)組指針和指針數(shù)組的應(yīng)用
一、數(shù)組類型
- C語言中的數(shù)組有自己特定的類型
- 數(shù)組的類型由元素類型和數(shù)組大小共同決定
例:int array[5] 的類型為 int[5]
二、定義數(shù)據(jù)類型
C語言中通過 typedef 為數(shù)組類型重命名:typedef type(name)[size];
數(shù)組類型:
typedef int(AINT5)[5];
typedef float(AFLOAT10)[10];
數(shù)組定義:
AINT5 iArray;
AFLOAT10 fArray;
三、數(shù)組指針
- 數(shù)組指針用于指向一個(gè)數(shù)組
- 數(shù)組名是數(shù)組首元素的起始地址,但并不是數(shù)組的起始地址
- 通過將取地址符 & 作用于數(shù)組名可以得到數(shù)組的起始地址
- 可通過數(shù)組類型定義數(shù)組指針:ArrayType* pointer;
- 也可以直接定義:type(*pointer)[n];
pointer 為數(shù)組指針變量名,type 為指向的數(shù)組的元素類型,n 為指向的數(shù)組的大小
下面看一個(gè)數(shù)組指針的示例:
#include <stdio.h> typedef int(AINT5)[5]; typedef float(AFLOAT10)[10]; typedef char(ACHAR9)[9]; int main() { AINT5 a1; float fArray[10]; AFLOAT10* pf = &fArray; ACHAR9 cArray; char(*pc)[9] = &cArray; char(*pcw)[4] = cArray; int i = 0; printf("%d, %d\n", sizeof(AINT5), sizeof(a1)); for (i = 0; i < 10; i++) { (*pf)[i] = i; // ==> fArray[i] = i; } for(i = 0; i < 10; i++) { printf("%f\n", fArray[i]); } printf("%p, %p, %p\n", &cArray, pc + 1, pcw + 1); return 0; }
輸出結(jié)果如下:
注意char(*pcw)[4] = cArray;
是不對(duì)的,cArray 數(shù)組名代表的地址是首元素的地址,類型為 char* ,而 pcw 指針類型為 char[4],所以這樣就不合法。
四、指針數(shù)組
- 指針數(shù)組是一個(gè)普通的數(shù)組
- 指針數(shù)組中每個(gè)元素為一個(gè)指針
- 數(shù)組的定義:
type* pArray[n];
type*為數(shù)組中每個(gè)元素的類型,pArray為數(shù)組名,n 為數(shù)組大小
例如:
下面看一個(gè)指針數(shù)組的應(yīng)用:
#include <stdio.h> #include <string.h> #define DIM(a) (sizeof(a) / sizeof(*a)) int lookup_keyword(const char* key, const char* table[], const int size) // const char* table[] <==> const char** table { int ret = -1; int i = 0; for (i = 0; i < size; i++) { if(strcmp(key, table[i]) == 0) { ret = i; break; } } return ret; } int main() { const char* keyword[] = { "do", "for", "if", "register", "return", "switch", "while", "case", "static" }; printf("%d\n", lookup_keyword("return", keyword, DIM(keyword))); printf("%d\n", lookup_keyword("main", keyword, DIM(keyword))); return 0; }
輸出結(jié)果如下:
注意const char* table[ ] <==> const char** table
,兩種寫法都可以,只是 const char* table[ ]
更直觀
五、小結(jié)
- 數(shù)組的類型由元素類型和數(shù)組大小共同決定
- 數(shù)組指針是一個(gè)指針,指向?qū)?yīng)類型的數(shù)組
- 指針數(shù)組是一個(gè)數(shù)組,其中每個(gè)元素都為指針
- 數(shù)組指針遵循指針運(yùn)算法則
- 指針數(shù)組擁有C語言數(shù)組的各種特性
到此這篇關(guān)于C語言深入分析數(shù)組指針和指針數(shù)組的應(yīng)用的文章就介紹到這了,更多相關(guān)C語言 數(shù)組指針內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言線性表的鏈?zhǔn)奖硎炯皩?shí)現(xiàn)詳解
線性表的鏈?zhǔn)酱鎯?chǔ)特點(diǎn)則是用一組任意的存儲(chǔ)單元存儲(chǔ)線性表的數(shù)據(jù)元素。這組存儲(chǔ)單元既可以是連續(xù)的,也可以是不連續(xù)的。本文將詳解一下C語言線性表的鏈?zhǔn)奖硎炯皩?shí)現(xiàn),感興趣的可以了解一下2022-07-07c++ 虛函數(shù)與純虛函數(shù)的區(qū)別(深入分析)
本篇文章是對(duì)c++中虛函數(shù)與純虛函數(shù)的區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
這篇文章主要介紹了C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例,并且轉(zhuǎn)換后會(huì)統(tǒng)計(jì)二進(jìn)制1的個(gè)數(shù),實(shí)例簡(jiǎn)單明了,需要的朋友可以參考下2014-06-06vc中SendMessage自定義消息函數(shù)用法實(shí)例
這篇文章主要介紹了vc中SendMessage自定義消息函數(shù)用法,以實(shí)例實(shí)行詳細(xì)講述了SendMessage的定義、原理與用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10C++零基礎(chǔ)精通數(shù)據(jù)結(jié)構(gòu)之帶頭雙向循環(huán)鏈表
帶頭雙向循環(huán)鏈表:結(jié)構(gòu)最復(fù)雜,一般用在單獨(dú)存儲(chǔ)數(shù)據(jù)。實(shí)際中使用的鏈表數(shù)據(jù)結(jié)構(gòu),都是帶頭雙向循環(huán)鏈表。另外這個(gè)結(jié)構(gòu)雖然結(jié)構(gòu)復(fù)雜,但是使用代碼實(shí)現(xiàn)以后會(huì)發(fā)現(xiàn)結(jié)構(gòu)會(huì)帶來很多優(yōu)勢(shì),實(shí)現(xiàn)反而簡(jiǎn)單2022-03-03C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子最小操作數(shù)示例
這篇文章主要為大家介紹了C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子所需最小操作數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12C語言實(shí)現(xiàn)簡(jiǎn)易版掃雷的完整過程
這篇文章主要給大家介紹了關(guān)于利用C語言如何實(shí)現(xiàn)簡(jiǎn)易版掃雷的完整過程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12