- 1、本文档共96页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言程序设计-函数-刘解析
在设计函数时要注意: 函数功能的设计:结合模块独立性原则,函数的功能要单一,一个模块一个功能,不要设置多用途的函数,否则会降低模块的聚合度。对于多处使用的同一个计算或操作过程,应当将其设计成一个独立的函数,达到一处定义、多处使用的目的,避免功能间的重复。 函数规模设计:函数的规模要小,尽量控制代码行数,使得函数更易于阅读、理解、调试和维护。 函数接口的设计:结合模块独立性的原则,函数的接口包括函数的参数(入口)和返回值(出口),不要设计过于复杂的接口,合理选择、设置、控制参数的数量,尽量不要使用全局变量,否则会增加模块的耦合度。采用定义局部变量作为函数的临时工作单元,使用参数和返回值作为函数与外部进行数据交换的方式。只有当确实需要多个函数共享的数据时,才定义其为全局变量。 THE END * * 4.4.4递归函数的效率分析 递归函数如果很缓慢地逼近到递归结束条件,会使性能大大下降。 递归增加了系统开销,时间上,执行调用与返回的额外工作要占用CPU时间。空间上,随着每递归一次,栈内存就多占一块,即要分配相应的存储空间,并完成参数的传递、函数的返回等,在程序的执行效率和所消耗的存储空间上,和非递归相比没有任何优势。 一般的递归都可以通过相应的方法转化为非递归的,所以不推荐使用递归,特别是不推荐使用递归层次较多的递归。 4.5 C局部变量、全局变量与变量作用域 4.5.1导例:富翁与骗子 4.5.2导例:简易库存存取货管理 4.5.3局部变量和全局变量 4.5.4变量的作用域和生存期 分别输入2个复数的实部与虚部,用函数实现计算2个复数之和与之积。 分析 若2个复数分别为: c1=x1+y1i , c2=x2+y2i, 则: c1+c2 = (x1+x2) + (y1+y2)i c1*c2 = (x1*x2-y1*y2) + (x1*y2+x2*y1)i 复数运算 #includestdio.h float result_real, result_imag; /* 全局变量,用于存放函数结果 */ int main(void) { float imag1, imag2, real1, real2; /* 两个复数的实、虚部变量 */ /* 函数声明 */ void complex_prod(float real1, float imag1, float real2, float imag2); void complex_add(float real1, float imag1, float real2, float imag2); printf(Enter 1st complex number(real and imaginary): ); scanf(%f%f, real1, imag1); /* 输入第一个复数 */ printf(Enter 2nd complex number(real and imaginary): ); scanf(%f%f, real2, imag2); /* 输入第两个复数 */ complex_add(real1, imag1, real2, imag2); /* 求复数之和 */ printf(addition of complex is %f+%fi\n, result_real, result_imag); complex_prod(real1, imag1, real2, imag2); /* 求复数之积 */ printf(product of complex is %f+%fi\n, result_real, result_imag); return 0; } 运行结果 Enter 1st complex number(real and imaginary):1 1 Enter 2nd complex number(real and imaginary):-2 3 addition of complex is -1.000000+4.000000i product of complex is -5.000000+1.000000i void complex_add(float real1, float imag1, float real2, float imag2) { result_real = real1 + real2; result_imag = imag1 + imag2; } void complex_prod(float real1, float imag1, float real2, float imag2) { result_real = re
文档评论(0)