- 1、本文档共19页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* * * #includestdio.h void swap(int , int ); void main(){ int a=3,b=8; printf(a=%d b=%d\n,a,b); swap(a,b); printf(a=%d b=%d,a,b); } void swap(int a, int b){ int temp=a; a=b; b=temp; } * * * #includestdio.h typedef struct studentStruct{ int num; float score; }student; void main(){ student a,*ps; student ra = a; ps=a; a.num=106; (*ps).num=106; ps-num=106; a.score = 120; printf(Student-num = %d ;Student-score = %f,a.num,ra.score); } * 数据结构 --C 语言补充与复习 授课人:卫文学 信息科学与工程学院 采用四个例子讨论两个问题 1、程序在内存中的区域 --加深对函数调用、递归调用的理解 2、引用 -- 加深对引用参数作用的理解 1、程序在内存中的区域 一个程序将操作系统分配给其运行的内存块分为四个区域: (1)代码区:存放程序的代码,即程序中的各个函数代码块。 (2)全局数据区:存放程序的全局数据和静态数据。 (3)堆区:存放程序的动态数据。 (4)栈区:存放程序的局部数据,即各个函数中的数据。 代码区Code area 全局数据区data area 堆区heap area 栈区stack area 程序内存空间 静态分配策略在编译时对所有对象分配固定的存储单元,且在运行时始终不变。 动态分配策略在运行时把存储器作为一个栈进行管理,运行时,每当调用一个函数,它所需要的空间就动态分配于栈顶,一旦退出,它所占用的空间就予以释放。 堆式动态分配策略在运行时把存储器组织堆结构。凡申请者从堆中分给一块,凡释放者退回给堆。 int f(int n){ if(n==1) return(1); else return(n*f(n-1)); } Void main(){ int m=0,a=3; m=f(a); …… } 代码区 栈区 Main() F(3) n=3 F(2) n=2 F(1) n=1 例1、值参-普通变量做参数 通过对函数的调用,函数返回一值。然而在很多情形下,希望函数返回不止一个值。如下面是想通过swap( )函数调用来交换两个数值的程序: void swap(int, int)main( ) { int a=3, b=8; printf(“a=%d b=%d”,a,b); swap(a,b); printf(“a=%d b=%d”,a,b); }void swap(int a, int b) {int temp=a; a=b; b=temp; } 运行结果为:a=3 b=8 a=3 b=8 2002 3000 3 main a b 8 swap 返回地址 a b temp 3 8 3 栈 2004 调用函数运行状态 例2、址参-指针变量作参数 结论:利用指针变量作参数,可将主调函数中某变量的地址传递被调函数,在被调函数通过地址间接访问,改变了主调函数中变量的值。但指针的灵活性是以破坏函数的黑盒特性为代价的。 void swap(int *, int *)main( ) { int a=3, b=8; printf(“a=%d b=%d”,a,b); swap(a, b); printf(“a=%d b=%d”,a,b); }void swap(int * a, int * b) {in
文档评论(0)