C語言 詳細(xì)講解數(shù)組參數(shù)與指針參數(shù)
一、C語言中的數(shù)組參數(shù)退化為指針的意義
C 語言中只會(huì)以值拷貝的方式傳遞參數(shù)
當(dāng)向函數(shù)傳遞數(shù)組時(shí):
- 將整個(gè)數(shù)組拷貝一份傳入函數(shù) ×
- 將數(shù)組名看做常量指針傳數(shù)組首元素地址 √
C 語言以高效作為最初設(shè)計(jì)目標(biāo):
- a) 參數(shù)傳遞的時(shí)候如果拷貝整個(gè)數(shù)組執(zhí)行效率將大大下降。
- b) 參數(shù)位于棧上,太大的數(shù)組拷貝將導(dǎo)致棧溢出。
二、二維數(shù)組參數(shù)
二維數(shù)組參數(shù)同樣存在退化的問題
- 二維數(shù)組可以看做是一維數(shù)組
- 二維數(shù)組中的每個(gè)元素是一維數(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])
三、等價(jià)關(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] |
四、被忽視的知識(shí)點(diǎn)
C 語言中無法向一個(gè)函數(shù)傳遞任意的多維數(shù)組
必須提供除第一維之外的所有維長度
- 第一維之外的維度信息用于完成指針運(yùn)算
- N 維數(shù)組的本質(zhì)是一維數(shù)組,元素是 N-1 維的數(shù)組
- 對于多維數(shù)組的函數(shù)參數(shù)只有第一維是可變的
下面看一個(gè)傳遞與訪問二維數(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 語言中只會(huì)以值拷貝的方式傳遞參數(shù)
- C 語言中的數(shù)組參數(shù)必然退化為指針
- 多維數(shù)組參數(shù)必須提供除第一維之外的所有維長度
- 對于多維數(shù)組的函數(shù)參數(shù)只有第一維是可變的
到此這篇關(guān)于C語言 詳細(xì)講解數(shù)組參數(shù)與指針參數(shù)的文章就介紹到這了,更多相關(guān)C語言 數(shù)組參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)例真題講解數(shù)據(jù)結(jié)構(gòu)中單向環(huán)形鏈表
鏈表可以說是一種最為基礎(chǔ)的數(shù)據(jù)結(jié)構(gòu)了,而單向鏈表更是基礎(chǔ)中的基礎(chǔ)。鏈表是由一組元素以特定的順序組合或鏈接在一起的,不同元素之間在邏輯上相鄰,但是在物理上并不一定相鄰。在維護(hù)一組數(shù)據(jù)集合時(shí),就可以使用鏈表,這一點(diǎn)和數(shù)組很相似2022-04-04