前言
个人学习笔记,部分内容摘自c语言程序设计现代方法第二版。
一、基础知识
指针变量声明
int *p;
double *q;
char *r;
取地址运算符(&)
int *p=&i;
//same as int *p;
//p=&i;如果在p前加上*,p的对象内容会替换为i的地址,造成不可控后果
间接寻址运算符(*)
int *p=&i;// 需要初始化指针变量后使用p的值
i=1;//此时*p的值为1
p=2;//此时i的值为2
注:只要p指向i,*p就是i的别名,*p和i的值会同时改变。
指针赋值
int i,j,*p,*q;
p=&i;
q=p;//q points to where p points to
*q=*p;
/*the value of where q points to
is now equal to where p points to*/
指针作为参数
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;//a[0]=5;
p+=6;//p=&a[6];
i=p-q;//i=5;
i=q-p;//i=-5;
//comparation
//p<=q is 0
//p>=q is 1
int *p = (int []){3,0,4,3,1};
/*p points to the first element in this array*/
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语言中指针的第一部分啦,求三连,求关注呜呜呜。。。