C和C++都沒(méi)有辦法傳數(shù)組,只能傳“指針”,指針和數(shù)組的差別就在于函數(shù)內(nèi)無(wú)法檢測(cè)數(shù)組的尺寸
深州網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)公司!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)公司公司2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專(zhuān)注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)公司。
c語(yǔ)言中、數(shù)組在函數(shù)中的傳遞可以數(shù)組元素的傳遞!還有就是數(shù)組名的傳遞!其實(shí)、數(shù)組名的傳遞類(lèi)似指針!就是把數(shù)組的元素的首地址傳到形參的!
C語(yǔ)言如果給函數(shù)傳遞二維數(shù)組作為參數(shù)
先看一個(gè)傳遞二維數(shù)組的例子:
編譯:
程序看著沒(méi)有任何問(wèn)題,但是編譯器通不過(guò),報(bào)錯(cuò)在處理二維數(shù)組參數(shù)a的時(shí)候,類(lèi)型不兼容。
C語(yǔ)言里面對(duì)二維數(shù)組的存儲(chǔ)是按照一維數(shù)組來(lái)處理的,二維數(shù)組按照行展開(kāi)的方式按順序存儲(chǔ),例如在上面的例子中:
二維數(shù)組a的定義:
它等同于一維數(shù)值的定義:
因?yàn)樗麄兊目臻g存儲(chǔ)分配一樣的。
所以在利用二維數(shù)組作為參數(shù)傳遞時(shí),必須指定二維數(shù)組的列數(shù),否則函數(shù)無(wú)法勾畫(huà)出二維數(shù)組的組織形式。只有有了列長(zhǎng)度,通過(guò)下標(biāo)a[i][j]時(shí)才能得到正確的下標(biāo)地址,即:
我們改一下上面的額foo函數(shù)定義:
編譯運(yùn)行:
這下就正常了。
參數(shù)如上所列。
我們看到,函數(shù)的參數(shù)聲明改成了:
這個(gè)聲明的含義是:
不過(guò)此時(shí)還是需要指定二維數(shù)組的列長(zhǎng)度,不然函數(shù)內(nèi)部還是無(wú)法使用二維下標(biāo)去訪問(wèn)數(shù)組:
編譯:
原因同前面方法1一致,如果要訪問(wèn)二維數(shù)組,必須指定列的長(zhǎng)度,否則無(wú)法計(jì)算出該元素的地址,a[i][j]=a [ (i-1)*COLNUM + j ],如果沒(méi)有COLNUM,那么這個(gè)地址無(wú)法計(jì)算出來(lái)。從形參的聲明來(lái)說(shuō),a就是一個(gè)指針,指向一維數(shù)組的指針,而不是一個(gè)二維數(shù)組。
這里要注意的是指針的指針,和二維數(shù)組的差異;二維數(shù)組的地址是連續(xù)的,所有成員按順序排序;而指針的指針只要求指針地址連續(xù),而不要求指針的指針地址連續(xù)。
然后作為實(shí)參傳遞時(shí),也不能直接使用a傳遞,因?yàn)轭?lèi)型不匹配,必須定義新的變量p,然后把a(bǔ)的值賦給p,再傳遞給foo函數(shù)。
很簡(jiǎn)單的,數(shù)組作為函數(shù)參數(shù)傳遞的時(shí)候只要是數(shù)組名就可以了,因?yàn)閿?shù)組名本身就是數(shù)組的首地址 .給個(gè)程序看看
#includestdio.h
#define N 3
int array[N][N];
void main()
{
//在主函數(shù)內(nèi)聲明被調(diào)函數(shù)
void convert(int array[][3]);
int i,j;
printf("輸入數(shù)組:\n");
for(j=0;jN;j++)
for(i=0;iN;i++)
scanf("%d",array[i][j]);
printf("\n");
for(j=0;jN;j++)
{
for(i=0;iN;i++)
printf("%d\t",array[i][j]);
printf("\n");
}
//調(diào)用矩陣轉(zhuǎn)置函數(shù)
convert(array);
printf("\n");
for(i=0;iN;i++)
{
for(j=0;jN;j++)
printf("%d\t",array[i][j]);
printf("\n");
}
}
void convert(int array[][3])
{
int i,j,t;
for(i=0;iN;i++)
for(j=0;jN;j++)//設(shè)置數(shù)組中轉(zhuǎn)置矩陣元素交換
{
t=array[i][j];
array[i][j]=array[j][i];
array[j][i]=t;
}
}