前言
个人学习笔记,部分内容摘自c语言程序设计现代方法第二版。
一、基础知识
指针变量声明
int *p;
double *q;
char *r;
取地址运算符(&)
int *p=&i;
间接寻址运算符(*)
int *p=&i;
i=1;
p=2;
注:只要p指向i,*p就是i的别名,*p和i的值会同时改变。
指针赋值
int i,j,*p,*q;
p=&i;
q=p;
*q=*p;
指针作为参数
void decompose(double x,long *int_part,double *frac_part)
{
*int_part = (long)x;
*frac_part = x - *int_part;
}
decompose(3.14159,&i,&d);
指针作为返回值
int *max(int *a,int *b){
if(*a>*b)
return a;
else
return b;
}
int *p,i,j;
p=max(&i,&j);
二、指针与数组
1.指针的算术运算
int a[10],*p,*q,i;
p=&a[0];
q=&a[1];
*p=5;
p+=6;
i=p-q;
i=q-p;
int *p = (int []){3,0,4,3,1};
2.数组处理
代码如下(示例):
int *p,a[N],sum=0;
p=&a[0];
while(p<&a[N])
sum+=*p++;
for(p=a;p<a+N;p++){
sum++*p;
}
*p=a;
for(int i=0;i<N;i++){
sum+=p[i];
}
指针和多维数组
众所周知,c语言按行主序存储二维数组。 故可使用以下代码:
int *p;
int a[nums_rows][nums_cols];
for(p=&a[0][0];p<=a[nums_rows-1][nums_cols-1];p++)
*p=0;
以此类推处理多维数组行,列的方法 列使用(*p)[i],此处p指向长度为nums_ cols的整型数组。
总结
以上就是c语言中指针的第一部分啦,求三连,求关注呜呜呜。。。
|