C語言 詳細講解數(shù)組參數(shù)與指針參數(shù)
一、C語言中的數(shù)組參數(shù)退化為指針的意義
C 語言中只會以值拷貝的方式傳遞參數(shù)
當(dāng)向函數(shù)傳遞數(shù)組時:
- 將整個數(shù)組拷貝一份傳入函數(shù) ×
- 將數(shù)組名看做常量指針傳數(shù)組首元素地址 √
C 語言以高效作為最初設(shè)計目標(biāo):
- a) 參數(shù)傳遞的時候如果拷貝整個數(shù)組執(zhí)行效率將大大下降。
- b) 參數(shù)位于棧上,太大的數(shù)組拷貝將導(dǎo)致棧溢出。
二、二維數(shù)組參數(shù)
二維數(shù)組參數(shù)同樣存在退化的問題
- 二維數(shù)組可以看做是一維數(shù)組
- 二維數(shù)組中的每個元素是一維數(shù)組
二維數(shù)組參數(shù)中第一維的參數(shù)可以省略
void f(int a[5]) <--> void f(int a[ ]) <--> void f(int* a)
void g(int a[3][3]) <--> void g(int a[ ][3]) <--> void g(int(*a)[3])
三、等價關(guān)系
| 數(shù)組參數(shù) | 等效的指針參數(shù) |
| 一維數(shù)組:float a[5] | 等效的指針參數(shù):float* a |
| 指針數(shù)組:int* a[5] | 指針的指針:int** a |
| 二維數(shù)組:char a[3][4] | 數(shù)組的指針:char (*a)[4] |
四、被忽視的知識點
C 語言中無法向一個函數(shù)傳遞任意的多維數(shù)組
必須提供除第一維之外的所有維長度
- 第一維之外的維度信息用于完成指針運算
- N 維數(shù)組的本質(zhì)是一維數(shù)組,元素是 N-1 維的數(shù)組
- 對于多維數(shù)組的函數(shù)參數(shù)只有第一維是可變的
下面看一個傳遞與訪問二維數(shù)組與三維數(shù)組的示例:
#include <stdio.h>
void access(int a[][3], int row)
{
int col = sizeof(*a) / sizeof(int);
int i = 0;
int j = 0;
printf("sizeof(a) = %d\n", sizeof(a));
printf("sizeof(*a) = %d\n", sizeof(*a));
for(i=0; i<row; i++)
{
for(j=0; j<col; j++)
{
printf("%d\n", a[i][j]);
}
}
printf("\n");
}
void access_ex(int b[][2][3], int n)
{
int i = 0;
int j = 0;
int k = 0;
printf("sizeof(b) = %d\n", sizeof(b));
printf("sizeof(*b) = %d\n", sizeof(*b));
for(i = 0; i < n; i++)
{
for(j = 0; j < 2; j++)
{
for(k = 0; k < 3; k++)
{
printf("%d\n", b[i][j][k]);
}
}
}
printf("\n");
}
int main()
{
int a[3][3] = {{0, 1, 2}, {3, 4, 5}, {6, 7, 8}};
int aa[2][2] = {0};
int b[1][2][3] = {0};
access(a, 3);
//access(aa, 2);
access_ex(b, 1);
//access_ex(aa, 2);
return 0;
}
輸出結(jié)果如下:

五、小結(jié)
- C 語言中只會以值拷貝的方式傳遞參數(shù)
- C 語言中的數(shù)組參數(shù)必然退化為指針
- 多維數(shù)組參數(shù)必須提供除第一維之外的所有維長度
- 對于多維數(shù)組的函數(shù)參數(shù)只有第一維是可變的
到此這篇關(guān)于C語言 詳細講解數(shù)組參數(shù)與指針參數(shù)的文章就介紹到這了,更多相關(guān)C語言 數(shù)組參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實例真題講解數(shù)據(jù)結(jié)構(gòu)中單向環(huán)形鏈表
鏈表可以說是一種最為基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)了,而單向鏈表更是基礎(chǔ)中的基礎(chǔ)。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護一組數(shù)據(jù)集合時,就可以使用鏈表,這一點和數(shù)組很相似2022-04-04

