數(shù)組和指針的區(qū)別深入剖析
更新時間:2012年11月16日 15:43:19 作者:
在C/C++中,指針和數(shù)組在很多地方可以互換使用,這使得我們產(chǎn)生一種錯覺,感覺數(shù)組和指針兩者是完全等價的,事實上數(shù)組和指針是有很大的區(qū)別的
在C/C++中,指針和數(shù)組在很多地方可以互換使用,這使得我們產(chǎn)生一種錯覺,感覺數(shù)組和指針兩者是完全等價的,事實上數(shù)組和指針是有很大的區(qū)別的。
1.兩者在含義上的區(qū)別。
數(shù)組對應(yīng)著一塊內(nèi)存區(qū)域,而指針是指向一塊內(nèi)存區(qū)域。其地址和容量在生命期里不會改變,只有數(shù)組的內(nèi)容可以改變;而指針卻不同,它指向的內(nèi)存區(qū)域的大小可以隨時改變,而且當(dāng)指針指向常量字符串時,它的內(nèi)容是不可以被修改的,否則在運行時會報錯。
如:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(void)
{
char*s1="123456789";
char*s2="123456";
strncpy(s1,s2,6);
printf("%s %s\n",s1,s2);
return0;
}
在編譯時不會報錯,但是在運行時會報錯,原因在于企圖改變s1的內(nèi)容,由于s1,s2指向的是常量字符串,其內(nèi)容是不可修改的,因此在運行時不會通過。而下面這個程序是可以運行通過的:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(void)
{
char s1[10]="123456789";
char s2[10]="123456";
strncpy(s1,s2,6);
printf("%s %s\n",s1,s2);
return0;
}
在VC++ 6.0上可以編譯運行通過,原因在于數(shù)組的內(nèi)容是可以被修改的,這就充分體現(xiàn)了指針和數(shù)組的區(qū)別,并不是完全等價的。
2.計算內(nèi)存容量的區(qū)別。
用運算符sizeof可以計算出數(shù)組的容量(字節(jié)數(shù)),而用sizeof卻無法計算指針所指內(nèi)存的容量,用sizeof(p)得到的結(jié)果永遠是4或者2(即指針變量所占內(nèi)存單元的字節(jié)數(shù),一般情況下指針變量占2個或4個字節(jié)的內(nèi)存單元)。在進行參數(shù)傳遞時,數(shù)組會自動退化為同類型的指針。
看下面這段代碼和運行結(jié)果:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void function(int a[])
{
printf("%d\n",sizeof(a));
}
int main(void)
{
int a[10]={1,2,3,4,5,6,7};
int*p=a;
printf("%d %d\n",sizeof(a),sizeof(p));
function(a);
return0;
}
1.兩者在含義上的區(qū)別。
數(shù)組對應(yīng)著一塊內(nèi)存區(qū)域,而指針是指向一塊內(nèi)存區(qū)域。其地址和容量在生命期里不會改變,只有數(shù)組的內(nèi)容可以改變;而指針卻不同,它指向的內(nèi)存區(qū)域的大小可以隨時改變,而且當(dāng)指針指向常量字符串時,它的內(nèi)容是不可以被修改的,否則在運行時會報錯。
如:
復(fù)制代碼 代碼如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(void)
{
char*s1="123456789";
char*s2="123456";
strncpy(s1,s2,6);
printf("%s %s\n",s1,s2);
return0;
}
在編譯時不會報錯,但是在運行時會報錯,原因在于企圖改變s1的內(nèi)容,由于s1,s2指向的是常量字符串,其內(nèi)容是不可修改的,因此在運行時不會通過。而下面這個程序是可以運行通過的:
復(fù)制代碼 代碼如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(void)
{
char s1[10]="123456789";
char s2[10]="123456";
strncpy(s1,s2,6);
printf("%s %s\n",s1,s2);
return0;
}
在VC++ 6.0上可以編譯運行通過,原因在于數(shù)組的內(nèi)容是可以被修改的,這就充分體現(xiàn)了指針和數(shù)組的區(qū)別,并不是完全等價的。
2.計算內(nèi)存容量的區(qū)別。
用運算符sizeof可以計算出數(shù)組的容量(字節(jié)數(shù)),而用sizeof卻無法計算指針所指內(nèi)存的容量,用sizeof(p)得到的結(jié)果永遠是4或者2(即指針變量所占內(nèi)存單元的字節(jié)數(shù),一般情況下指針變量占2個或4個字節(jié)的內(nèi)存單元)。在進行參數(shù)傳遞時,數(shù)組會自動退化為同類型的指針。
看下面這段代碼和運行結(jié)果:
復(fù)制代碼 代碼如下:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void function(int a[])
{
printf("%d\n",sizeof(a));
}
int main(void)
{
int a[10]={1,2,3,4,5,6,7};
int*p=a;
printf("%d %d\n",sizeof(a),sizeof(p));
function(a);
return0;
}
相關(guān)文章
Vscode Remote Development遠程開發(fā)調(diào)試的實現(xiàn)思路
這篇文章主要介紹了Vscode Remote Development遠程開發(fā)調(diào)試的相關(guān)資料,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04關(guān)于C++類的成員初始化列表的相關(guān)問題
下面小編就為大家?guī)硪黄P(guān)于C++類的成員初始化列表的相關(guān)問題。小編覺得挺2016-05-05C++實現(xiàn)LeetCode(171.求Excel表列序號)
這篇文章主要介紹了C++實現(xiàn)LeetCode(171.求Excel表列序號),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08C++調(diào)用EasyX庫實現(xiàn)嫦娥奔月小游戲
這篇文章主要為大家詳細介紹了C++如何調(diào)用EasyX庫編寫一個簡單的嫦娥奔月小游戲,文中的示例代碼講解詳細,感興趣的小伙伴可以參考一下2023-09-09