- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c语言程序设计(王勇)第8章 指针讲义教材.ppt
第八章 指针; 取变量地址;直接访问与间接访问
直接访问:按变量地址存取变量值
间接访问:通过存放变量地址的变量去访问变量;8.2 指针变量的定义和指针变量的基类型;8.3 指针变量的赋值;例 main( )
{ int i=10;
int *p;
*p=i;
printf(“%d”,*p);
};例 输入两个数,并使其从大到小输出;main()
{int *p1,*p2,*p, i1=10,i2=20;
p1=i1,p2=i2;
printf(“%d,%d\n”,*p1,*p2);
p=p1; p1=p2; p2=p;
printf(“%d,%d\n”,*p1,*p2);
};零指针与空类型指针
零指针:
定义:指针变量值为零
表示: int * p=0; ;指针变量的赋值运算
p=a; (将变量a地址?p)
p=array; (将数组array首地址?p)
p=array[i]; (将数组元素地址?p)
p1=p2; (指针变量p2值?p1)
不能把一个整数?p,也不能把p的值?整型变量;指针的算术运算:
p++, p--, p+i, p-i, p+=i, p-=i等
p1与p2指向同一数组,p1-p2=两指针间元素个数
p1+p2 无意义;指针变量的关系运算
若p1和p2指向同一数组,则
p1p2 表示p1指的元素在前
p1p2 表示p1指的元素在后
p1==p2 表示p1与p2指向同一元素
若p1与p2不指向同一数组,比较无意义
p==NULL或p!=NULL;例 void main()
{ int a []={5,8,7,6,2,7,3};
int y,*p=a[1];
y=(*--p)++;
printf(“%d ”,y);
printf(“%d”,a[0]);
} ;main()
{ int i,*p,a[7];
p=a;
for(i=0;i7;i++)
scanf(%d,p++);
printf(\n);
for(i=0;i7;i++,p++)
printf(%d,*p);
};swap(int x,int y)
{ int temp;
temp=x;
x=y;
y=temp;
}
main()
{ int a,b;
scanf(%d,%d,a,b);
if(ab) swap(a,b);
printf(\n%d,%d\n,a,b);
};swap(int *p1, int *p2)
{ int p;
p=*p1;
*p1=*p2;
*p2=p;
};swap(int *p1, int *p2)
{ int p;
p=*p1;
*p1=*p2;
*p2=p;
}
main()
{ int a,b;
int *p1,*p2;
scanf(%d,%d,a,b);
p1=a; p2=b;
if(ab)swap(p1,p2);
printf(\n%d,%d\n,a,b);
};swap(int *p1, int *p2)
{ int *p;
*p=*p1;
*p1=*p2;
*p2=*p;
}
main()
{ int a,b;
int *p1,*p2;
scanf(%d,%d,a,b);
p1=a; p2=b;
if(ab) swap(p1,p2);
printf(\n%d,%d\n,a,b);
};swap(int x,int y)
{ int t;
t=x; x=y; y=t;
}
main()
{ int a,b;
int *p1,*p2;
scanf(%d,%d,a,b);
p1=a; p2=b;
if(ab) swap(*p1,*p2);
printf(\n%d,%d\n,a,b);
};传指针并交换指针指向
文档评论(0)