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