接着上次的继续搞
void main()
{
int i = 0, j = 0, tmp = 0;
int a[5] = {3,4,5,6,2};
// myarray数组首元素的地址
// myarray是一个常量指针
// myarray是一个数组指针
int myarray[3][5];
// 直接定义一个数组指针
int (*p)[5] = &a;
for(; i < 5; i++)
{
printf("%d\n", (*p)[i]);
}
// &a的步长 5 * 4 = 20;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 5; j++)
{
myarray[i][j] = tmp++;
}
}
printf("myarray:%d myarray + 1:%d\n", myarray, myarray + 1);
printf("&a:%d &a + 1:%d\n", &a, &a + 1);
p = myarray;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 5; j++)
{
p[i][j] = tmp++;
printf("%d \n", p[i][j]);
}
}
system("pause");
}
2、多为数组做函数参数,二维数组勉强能表达出来,单三维数组,四维数组。。。。就表达不出来了。
结论:指针做函数参数,有效内存参数,只到2级。如果看到三级指针,四级指针,他表示的不是内存的维数
void printf2Array(int *a, int num)
{
int i = 0;
for (; i < num; i++)
{
printf("%d ", a[i]);
}
}
void main()
{
int i = 0, j = 0, tmp = 0;
int a[5] = {3,4,5,6,2};
// myarray数组首元素的地址
// myarray是一个常量指针
// myarray是一个数组指针
int myarray[3][5];
// 直接定义一个数组指针
int (*p)[5] = &a;
for(; i < 5; i++)
{
printf("%d\n", (*p)[i]);
}
// &a的步长 5 * 4 = 20;
//for (i = 0; i < 3; i++)
//{
// for (j = 0; j < 5; j++)
// {
// myarray[i][j] = tmp++;
// }
//}
printf("myarray:%d myarray + 1:%d\n", myarray, myarray + 1);
printf("&a:%d &a + 1:%d\n", &a, &a + 1);
p = myarray;
for (i = 0; i < 3; i++)
{
for (j = 0; j < 5; j++)
{
p[i][j] = tmp++;
printf("%d \n", p[i][j]);
}
}
printf2Array(p,15);
system("pause");
}
// 一维数组做函数参数的三种写法
void printf1Array(char buf[64]);
void printf1Array(char buf[]);
void printf1Array(char *buf);
// 二维数组做函数参数的三种写法
void printf2Array_1(char buf[10][30], int num)
{
int i = 0;
for (; i < num; i++)
{
printf("%s \n", buf[i]);
}
}
void printf2Array_2(char buf[][30], int num)
{
int i = 0;
for (; i < num; i++)
{
printf("%s \n", buf[i]);
}
}
void printf2Array_3(char (*buf)[30], int num)
{
int i = 0;
for (; i < num; i++)
{
printf("%s \n", buf[i]);
}
}
void main()
{
char myarray[5][30] = {"aaaaaa","ccccccc","vvvvvvvv","bbbbbbbb","dsads"};
printf2Array_1(myarray, 5);
printf2Array_2(myarray, 5);
printf2Array_3(myarray, 5);
system("pause");
}
下列代码的内存图为
// 指针数组
char *p1[] = {"123", "456", "789"};
// 二维数组
char p2[3][4] = {"123", "456", "789"};
// 手工二维内存
char **p3 = (char **)malloc(3 * sizeof(char*));
for (i = 0; i < 3; i++)
{
p3[i] = (char *)malloc(10*sizeof(char));
sprintf(p3[i], "%d%d%d", i);
}
// 指针数组的用法
// 求关键字在表中的位置
int searcheKeyTable(const char* table[], const int size, const char* key, int *pos)
{
int i = 0;
int ntmp = 0;
if (table == NULL || pos == NULL || key == NULL)
{
return -1;
}
// 注意这里求出的ntmp为1,因为二维指针数组做参数时候会退化为指针
// 在主调函数中去求字节数,那时候参数还没有退化
ntmp = sizeof(table) / sizeof(*table);
for (i = 0; i < size; i++)
{
if (strcmp(key, table[i]) == 0)
{
*pos = i;
return 1;
}
}
return -1;
}
#define DIM(array) (sizeof(array) / sizeof(*array))
void main()
{
int nPos = 0;
int a[10];
int i = 0;
char* c_keyword[] = {
"while",
"case",
"static",
"do"
};
searcheKeyTable(c_keyword, DIM(c_keyword), "do", &nPos);
printf("pos:%d\n", nPos);
system("pause");
}