1. int (*p)[3] 与 int *p[3]的区别:
int (*p)[3]:这是一个数组指针,p是一个指针,指向了一个含有3个元素的数组。
int *p[3]: 这是一个指针数组,p是一个数组,含3个元素,类型是int *。
2. int *const p 与 const int *p的区别:
int *const p:const指针,指针的值不能改变,但指针所指向的内容可变。
const int *p:指向const对象的指针,指针指向可变,内容不可变。
3. 利用指针调用函数的两种方法:
void *p ; //p是void型指针
void (*q)(); //q是void型函数指针
p = (void*)Test_UartAFC_Tx; //可理解为函数指针强制转换成void型指针。Test_UartAFC_Tx是函数
q=Test_UartAFC_Tx;
((void(*)(void))p)(); //(void(*)())也是个强制转换,是把void型指针转化为函数指针。
//void是返回类型,(*)(void)是函数指针
(*q)();//所用的方法:给((void(*)(void))p)()加括号和改变void类型未int等,最终发现(*)(void)在一块即
((*)(void))时,编译器不报错。
4. p+i; 计算行指针
*(p+i); 具体的行,是一个指针,指向改行首元素地址
*(p+i)+j; 得到具体元素地址
*(*(p+i)+j); 得到元素的值
void *p ; //p是void型指针
void (*q)(); //q是void型函数指针
p = (void*)Test_UartAFC_Tx; //可理解为函数指针强制转换成void型指针。Test_UartAFC_Tx是函数
q=Test_UartAFC_Tx;
((void(*)(void))p)(); //(void(*)())也是个强制转换,是把void型指针转化为函数指针。
//void是返回类型,(*)(void)是函数指针
(*q)();//所用的方法:给((void(*)(void))p)()加括号和改变void类型未int等,最终发现(*)(void)在一块即
((*)(void))时,编译器不报错。
4. p+i; 计算行指针
*(p+i); 具体的行,是一个指针,指向改行首元素地址
*(p+i)+j; 得到具体元素地址
*(*(p+i)+j); 得到元素的值
基于上述原理,我们可以通过分配一个指针数组,再对指针数组的每一个元素分配空间实现动态分配二维数组。
int n, i, j;
double **p;
printf("输入矩阵的行数:");
scanf("%d", &n);
p=(double **)malloc(sizeof(double *) *n);
for( i=0; i<n; i++)
*(p+i)=(double *)malloc(sizeof(double) *n);
printf("输入矩阵中各数:\n");
for(i=0; i<n; i++)
for(j=0; j<=n; j++)
{scanf("%d", &p[i][j]);}
Gauss(p,n);
return 0;