數(shù)組名是數(shù)組首元素的地址锯岖。很多情況下數(shù)組名字等價于一個指針统求,比如 ar[i]和*(ar+1)這兩個表達式都是等價的。**argv 和 *argv[] 也是等價的奔害。
數(shù)組和指針也有不同的地方炉旷,比如數(shù)組申請的長度是數(shù)組長度 * 數(shù)組類型字節(jié)數(shù)签孔,而指針則只是一個指針占的大小。
下面4種原型都是等價的:
int sum(int *ar, int n);
int sum(int *, int);
int sum(int ar[], int n);
int sum(int [], int);
但是,在函數(shù)定義中不能省略參數(shù)名窘行。下面兩種形式的函數(shù)定義等價:
int sum(int *ar, int n)
{
// 其他代碼已省略
}
int sum(int ar[],
int n);
{
//其他代碼已省略
}
數(shù)組指針和指針數(shù)組
數(shù)組指針和指針數(shù)組這兩個概念饥追,以后面兩個字定義了他是什么,前面兩個字定義了他的內(nèi)容罐盔。
一下例子中的 ap 和 pa 都指向一個 3*4 的 int 數(shù)組 int array_1[3][4]
但绕。
數(shù)組指針
按照上面的理解方式,數(shù)組指針是一個指針,他的內(nèi)容是數(shù)組捏顺,即數(shù)組指針是一個指向數(shù)組的指針六孵。他又被稱為行指針,即指針指向一個二維數(shù)組的行首幅骄。
定義方式:
int (*ap)[4];
數(shù)組指針的特性都是圍繞他是一個指針的劫窒。
- 可以用 ap 表示指針的地址
- 可以使用 ap++ 指向數(shù)組的下一行,注意: ap+1 是在地址上增加了4 * sizeof(int) 即16個字節(jié)拆座。
- 但是 ap 自己的實際長度是 sizeof(ap)主巍,一版是 int 的大小。
指針數(shù)組
按照定義的方式理解挪凑,指針數(shù)組是一個數(shù)組孕索,他的內(nèi)容是指針,即指針數(shù)組是一個裝著指針的數(shù)組躏碳。二級指針 int **p 本質(zhì)上也是一個指針數(shù)組搞旭。
定義方式:
int *pa[3];
指針數(shù)組的特性都是圍繞他是一個數(shù)組的,所以指針能使用的 ++ 和 +1 操作他不能使用唐断,他只能使用數(shù)組的操作选脊,比如 pa[0] 是一個指針杭抠,值是 array_1[0]脸甘,而 pa[1] 的值是 array_1[1]。當然 pa[0] 這樣的指針是可以使用 ++ 和 +1 的偏灿,即 pa[0]+1 指向 array_1[0][1]丹诀,也可以用數(shù)組表示法 pa[0][1] 表示 array_1[0][1]。
* 和 ++ 的優(yōu)先級
注意: 自增(++)與自減(- -)運算符只能作用于變量翁垂,不能作用于常量和表達式铆遭。
* 和 ++ 同屬于第二優(yōu)先級,所以遵從從右向左結(jié)合的規(guī)則沿猜。
*p++ 等價于 *(p++)
*++p 等價于 *(++p)
++*p 等價于 ++(*p)
代碼
/**
* File Name: ptrArray_arrayPtr.c
* Author: xupeng
* Mail: xupeng@droi.com
* Created Time: 2020年01月02日 星期四 20時15分58秒
*/
#include<stdio.h>
int main(void) {
int i, j = 0;
printf("size of int is %lu\n", sizeof(i));
const char *pa[3] = {
"THIS IS POINTER ARRAY",
"this is pointer array",
"this is test"
};
printf("begin print pointer array *pa[3]:\n");
for (i=0;i<3;i++) {
printf("*pa[%d]=%s\n", i, pa[i]);
}
int array_1[3][4] = {
{1,12,13,14},
{5,53,54,55},
{9,94,95,96},
};
printf("\n");
int *pa_i[3];
for (i=0;i<3;i++) {
pa_i[i] = array_1[i];
}
printf("begin print pointer array &pa_i[3]\n");
for (i=0;i<3;i++) {
printf("pa_i[%d]=%p, array_1[%d]=%p\n", i, pa_i[i], i, array_1[i]);
for (j=0;j<4;j++) {
printf(" *pa_i[%d]+%d=%d\n", i, j, pa_i[i][j]);
}
}
for (i=0;i<3;i++) {
printf("pa_i[%d]=%p, array_1[%d]=%p\n", i, pa_i[i], i, array_1[i]);
for (j=0;j<4;j++) {
printf(" *pa_i[%d]+%d=%d\n", i, j, *pa_i[i]++);
}
}
printf("\n");
int (*ap)[4] = array_1;
ap = array_1;
printf("begin print array pointer (*ap)[4]:\n");
for (i=0;i<3;i++) {
printf("(*ap)[%d]=%p, array_1[%d]=%p\n", i, ap, i, array_1[i]);
for (j=0;j<4;j++) {
printf(" (*ap)[%d]+%d=%d\n", i, j, (*ap)[j]);
}
ap++;
}
printf("\n");
const char *cp = "world";
printf("*cp=%c, addr=%p\n", *cp, cp);
printf("*cp++=%c, ", *cp++);
printf("cp addr=%p\n", cp);
printf("*++cp=%c, ", *++cp);
printf("cp addr=%p\n", cp);
int *ip = &i;
printf("*ip=%d, addr=%p\n", *ip, ip);
printf("*ip++=%d, ", *ip++);
printf("addr=%p\n", ip);
printf("*++ip=%d, ", *++ip);
printf("addr=%p\n", ip);
ip = &i;
printf("++*p=%d, addr=%p\n", ++*ip, ip);
}
輸出結(jié)果:
size of int is 4
begin print pointer array *pa[3]:
*pa[0]=THIS IS POINTER ARRAY
*pa[1]=this is pointer array
*pa[2]=this is test
begin print pointer array &pa_i[3]
pa_i[0]=0x7ffc749ae830, array_1[0]=0x7ffc749ae830
*pa_i[0]+0=1
*pa_i[0]+1=12
*pa_i[0]+2=13
*pa_i[0]+3=14
pa_i[1]=0x7ffc749ae840, array_1[1]=0x7ffc749ae840
*pa_i[1]+0=5
*pa_i[1]+1=53
*pa_i[1]+2=54
*pa_i[1]+3=55
pa_i[2]=0x7ffc749ae850, array_1[2]=0x7ffc749ae850
*pa_i[2]+0=9
*pa_i[2]+1=94
*pa_i[2]+2=95
*pa_i[2]+3=96
pa_i[0]=0x7ffc749ae830, array_1[0]=0x7ffc749ae830
*pa_i[0]+0=1
*pa_i[0]+1=12
*pa_i[0]+2=13
*pa_i[0]+3=14
pa_i[1]=0x7ffc749ae840, array_1[1]=0x7ffc749ae840
*pa_i[1]+0=5
*pa_i[1]+1=53
*pa_i[1]+2=54
*pa_i[1]+3=55
pa_i[2]=0x7ffc749ae850, array_1[2]=0x7ffc749ae850
*pa_i[2]+0=9
*pa_i[2]+1=94
*pa_i[2]+2=95
*pa_i[2]+3=96
begin print array pointer (*ap)[4]:
(*ap)[0]=0x7ffc749ae830, array_1[0]=0x7ffc749ae830
(*ap)[0]+0=1
(*ap)[0]+1=12
(*ap)[0]+2=13
(*ap)[0]+3=14
(*ap)[1]=0x7ffc749ae840, array_1[1]=0x7ffc749ae840
(*ap)[1]+0=5
(*ap)[1]+1=53
(*ap)[1]+2=54
(*ap)[1]+3=55
(*ap)[2]=0x7ffc749ae850, array_1[2]=0x7ffc749ae850
(*ap)[2]+0=9
(*ap)[2]+1=94
(*ap)[2]+2=95
(*ap)[2]+3=96
*cp=w, addr=0x5611f3d18e67
*cp++=w, cp addr=0x5611f3d18e68
*++cp=r, cp addr=0x5611f3d18e69
*ip=3, addr=0x7ffebc51eff0
*ip++=3, addr=0x7ffebc51eff4
*++ip=-1135480704, addr=0x7ffebc51eff8
++*p=4, addr=0x7ffff67de110