for循环中b[k++]=s[i][j];为什么不是 *b[k++]=*s[i][j];单纯的b和s不是代表地址吗? 有点混乱!!!
#include <stdio.h>
void fun (int (*s)[10], int *b, int *n, int mm, int nn)
{
int i,j,k=0,c=0;
for(i=0;i<mm;i++)
{
for(j=0;j<nn;j++)
{
b[k++]=s[i][j];//这里为什么不是 *b[k++]=*s[i][j];
c++;
}
}
*n=c;
}
void main()
{
FILE *wf;
int w[10][10]={{33,33,33,33},{44,44,44,44},{55,55,55,55}}, i, j;
int a[100]={0},n=0 ;
printf("The matrix:\n");
for (i=0; i<3; i++)
{for (j=0;j<4;j++)
printf("%3d",w[i][j]);
printf("\n");
}
fun(w,a,&n,3,4);
printf("The A array:\n");
for(i=0; i<n; i++)
printf("%3d",a[i]);
printf("\n\n");
/******************************/
wf=fopen("out.dat","w");
for(i=0; i<n; i++)
fprintf(wf,"%3d",a[i]);
fclose(wf);
/*****************************/
}
数组名代表数组的首地址,没错。但你的b[k++]、s[i][j]有下标是代表数组元素,不是数组地址,也不是指针,不需要解引用。你可以简单看成
int arr[5] = {1,2,3,4,5};
int *p = arr;
arr[1] == *(p+1) == p[1];
因为数组本身就是地址,再加*号就重复定义了
b[a] 等于 (*b)+a
因为这个特性,c数组越界也不会立刻报错,只有计算的地址处于未分配的内存时才会报错
数组名是地址 但是数组名+下标的就是元素
int arr[3]={1,2,3};
int *p=arr;
arr是数组名,是数组中第一个元素的地址
arr[2] 是元素 ,是数组中的第三个元素
p是指针,是指向数组名,也就是数组中第一个元素的地址
*p 是元素,是数组中的第一个元素