簡單分析C語言中指針數(shù)組與數(shù)組指針的區(qū)別
首先來分別看一下,指針數(shù)組的一個小例子:
#include <stdio.h>
#include <string.h>
int lookup_keyword(const char*key, const char* table[], const int size)
{
int ret = -1;
int i = 0;
for(i=0; i<size; i++)
{
if (strcmp(key, table[i]) == 0)
{
ret = i;
break;
}
}
return ret;
}
#define DIM(array) (sizeof(array)/sizeof(*array))
int main()
{
const char* keyword[] = {
"do",
"for",
"if",
"register",
"switch",
"while",
"case",
"static",
};
printf("%d\n", lookup_keyword("static", keyword, DIM(keyword)));
return 0;
}
數(shù)組指針:
#include <stdio.h>
int main()
{
int i;
int* pI = &i; //普通類型
typedef int(AINT5)[5];
AINT5* p1;
int array[5];
p1 = &array; //數(shù)組指針1
int (*p2)[5] = &array; //數(shù)組指針2(不建議這樣寫)
int (*p3)[4] = &array; // X 數(shù)組指針3(不建議這樣寫)
return 0;
}
這兩個名字不同當(dāng)然所代表的意思也就不同。我剛開始看到這就嚇到了,主要是中文太博大精深了,整這樣的簡稱太專業(yè)了,把人都繞暈了。從英文解釋或中文全稱看就比較容易理解。
指針數(shù)組:array of pointers,即用于存儲指針的數(shù)組,也就是數(shù)組元素都是指針
數(shù)組指針:a pointer to an array,即指向數(shù)組的指針
還要注意的是他們用法的區(qū)別,下面舉例說明。
int* a[4] 指針數(shù)組
表示:數(shù)組a中的元素都為int型指針
元素表示:*a[i] *(a[i])是一樣的,因?yàn)閇]優(yōu)先級高于*
int (*a)[4] 數(shù)組指針
表示:指向數(shù)組a的指針
元素表示:(*a)[i]
注意:在實(shí)際應(yīng)用中,對于指針數(shù)組,我們經(jīng)常這樣使用:
typedef int* pInt; pInt a[4];
這跟上面指針數(shù)組定義所表達(dá)的意思是一樣的,只不過采取了類型變換。
代碼演示如下:
#include <iostream>
using namespace std;
int main()
{
int c[4]={1,2,3,4};
int *a[4]; //指針數(shù)組
int (*b)[4]; //數(shù)組指針
b=&c;
//將數(shù)組c中元素賦給數(shù)組a
for(int i=0;i<4;i++)
{
a[i]=&c[i];
}
//輸出看下結(jié)果
cout<<*a[1]<<endl; //輸出2就對
cout<<(*b)[2]<<endl; //輸出3就對
return 0;
}
注意:定義了數(shù)組指針,該指針指向這個數(shù)組的首地址,必須給指針指定一個地址,容易犯的錯得就是,不給b地址,直接用(*b)[i]=c[i]給數(shù)組b中元素賦值,這時數(shù)組指針不知道指向哪里,調(diào)試時可能沒錯,但運(yùn)行時肯定出現(xiàn)問題,使用指針時要注意這個問題。但為什么a就不用給他地址呢,a的元素是指針,實(shí)際上for循環(huán)內(nèi)已經(jīng)給數(shù)組a中元素指定地址了。但若在for循環(huán)內(nèi)寫*a[i]=c[i],這同樣會出問題。總之一句話,定義了指針一定要知道指針指向哪里,不然要悲劇。
相關(guān)文章
利用C++開發(fā)一個protobuf動態(tài)解析工具
數(shù)據(jù)庫中存儲的protobuf序列化的內(nèi)容,有時候查問題想直接解析查看內(nèi)容。很多編碼在網(wǎng)上很容易找到編解碼工具,但protobuf沒有找到編解碼工具,可能這樣的需求比較少吧,那就自己用C++實(shí)現(xiàn)一個,感興趣的可以了解一下2023-01-01
C語言深入講解動態(tài)內(nèi)存分配函數(shù)的使用
這篇文章主要介紹了C語言動態(tài)內(nèi)存分配,C語言內(nèi)存管理相關(guān)的函數(shù)主要有realloc、calloc、malloc、free、柔性數(shù)組等,下面這篇文章帶大家了解一下2022-05-05
C語言中遞歸的實(shí)際應(yīng)用與經(jīng)典問題
函數(shù)以及函數(shù)的遞歸調(diào)用是學(xué)習(xí)C語言必須要掌握的內(nèi)容,且遞歸作為經(jīng)典的算法思想被廣泛應(yīng)用于程序設(shè)計(jì)中,下面這篇文章主要給大家介紹了關(guān)于C語言中遞歸的實(shí)際應(yīng)用與經(jīng)典問題的相關(guān)資料,需要的朋友可以參考下2021-09-09
使用C語言實(shí)現(xiàn)珠璣妙算Mastermind小游戲
這篇文章主要介紹了使用C語言實(shí)現(xiàn)珠璣妙算Mastermind小游戲,這是一款益智類多人游戲游戲,非常有趣,需要的朋友可以參考下2023-03-03
C語言詳盡圖解函數(shù)棧幀的創(chuàng)建和銷毀實(shí)現(xiàn)
我們知道c語言中函數(shù)都是被調(diào)用的,main函數(shù)里面能調(diào)用其他函數(shù),其實(shí)main函數(shù)也是被別的函數(shù)調(diào)用的,下面通過本文給大家分享c語言函數(shù)棧幀的創(chuàng)建和銷毀過程,一起看看吧2022-05-05
C++11/14 線程的創(chuàng)建與分離的實(shí)現(xiàn)
這篇文章主要介紹了C++11/14 線程的創(chuàng)建與分離的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
C++利用函數(shù)動態(tài)創(chuàng)建二維數(shù)組
這篇文章主要為大家詳細(xì)介紹了C++利用函數(shù)動態(tài)創(chuàng)建二維數(shù)組,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09

