蔡子恒 + 原创作品转载请注明出处 + 《软件工程(C编码实践篇)》MOOC课程http://mooc.study.163.com/course/USTC-1000002006
实验报告链接
实验五:用callback增强链表模块来实现命令行菜单小程序V2.8
课程学习总结
课程一
开通代码仓库,熟悉实验楼环境,初步了解代码规范,回顾linux基本命令,cd、ls、mkdir,vim,模式切换,复制,markdown的书写,包括标题、插入链接、插入图片、插入代码,完成实验报告。
课程二
代码规范:缩进4个空格,变量命名采用lowCamel风格,类型/类/函数名用Pascal风格,类型/类/变量名用名词或名词组合,函数名用动词或动宾短语,括号清楚地表示逻辑优先级,所有{和}独占一行,且成对对齐,不要把多个语句和多个变量定义放在同一行,注释、文件名、路径等用英文ASCII字符,不要用中文和特殊字符,不要解释程序如何工作(How),要解释程序做什么(What),为什么这么做(Why)。
课程三
将程序内部进行模块化,设置接口,使程序更加逻辑清楚;KISS(keep it simple and stupid):一个函数或一个方法,只做一件事。扩展开来,在设计上,一个系统、一个子系统、一个模块、一个类等也只做一件事;Using design to frame the code 设计与实现保持一致;不要和陌生人说话(Law of Demeter):一个对象应当对其他对象有尽可能少的了解;运用Control Structure和Data Structure简化代码;一定要有错误处理。
课程四
可重用模块的接口设计(天王盖地虎,宝塔镇河妖),简单地说就是造轮子,要求达到高内聚低耦合的设计目标,方便重复使用;常见接口设计规范有:参数化上下文,生死相依原则,移除前置条件,简化后置条件等,还需编写开发者指南,供用户阅读使用;关于接口通用,并不是越通用越好,因为过于通用需要考虑很多情况,导致模块臃肿、效率低下,因此应该not too specific, not too general。
课程五
用callback函数实现linktable,设计接口能够方便地实现多态,使接口更加通用而避免考虑许多情况,用户使用起来也更简洁。但callback的做法是把某些实现丢给了用户,也算造成了一些不必要的麻烦,应该尽量少用。注意信息隐藏,一般地说,定义和实现需要隐藏,而声明和接口暴露给用户。
课程六
可重入函数:可以由多于一个任务并发使用,而不必担心数据错误。相反,不可重入(non-reentrant)函数不能由超过一个任务所共享,除非能确保函数的互斥(或者使用信号量,或者在代码的关键部分禁用中断)。可重入函数可以在任意时刻被中断,稍后再继续运行,不会丢失数据。可重入函数要么使用本地变量,要么在使用全局变量时保护自己的数据。
线程安全:在代码中使用一个互斥量实现线程安全。注意:可重入的函数不一定是线程安全的;不可重入的函数一定不是线程安全的。
课程七
将menu设计为可以重用的子系统,利用命令行参数argc/argv来处理命令参数,由于menu函数是提供给用户使用的,它只需要向外提供一个执行命令的方法和一个初始化方法。通过将其中的两个功能变成函数放在menu.c中,然后在test.c中使用函数添加节点,很好的实现了可重用。
makefile:非常好用,直接make即可,不用gcc。不过要注意里面不能用空格,需要用tab键。
go语言一些特性
组成:包声明,引入包,函数,变量,语句 & 表达式,注释。第一行代码package main定义了包名,下一行import "fmt"告诉 Go 编译器这个程序需要使用 fmt 包等等;文件名以.go结尾,不需要gcc编译,直接go run即可运行;没有.h头文件,也没有makefile文件,在将c语言代码转化为go语言代码时要注意这些。
学习心得总结
最大收获
这半学期,跟随孟宁老师的MOOC高级软件工程课程,学习到了许多的软件工程方面的知识。从最初的hello world小程序来熟悉实验环境与过程,到最后实现一个可重用的menu小程序,一步一步跟随孟宁老师的讲解进行代码书写实际操作,不仅学习了代码书写的规范,还了解到了许多代码书写的原则,这些对我之后的学习和实践都有着深刻的指导意义。
线下的实验是进行go语言代码的书写,将线上实验的功能进行go语言的转换。这又相当于重新学习了一门新的语言。所以为了完成实验,自己在网上找教程,搭环境,了解go语言的基本特性,语法,一步一步实现想要的功能。虽然开始起步很艰难,但是完成代码跑通时还是很有成就感的。
线下的课程,老师从一篇谷歌的文章入手,从中找出很多现在流行的知识点,例如代码审查,代码仓库,调试,rup等等,通过同学分享的形式,真的从中学习到了许多,拓展了我的知识面。虽然很遗憾没有抢到知识点进行分享,但是自己也做了关于rup的ppt,学习了rup的基本知识。
学习完这门课后,我对软件开发有了更深刻的理解。一个好的程序不仅要代码规范,可读性强,还有就是要可重用。在动手写一个程序之前,我们要先进行设计,重点考虑怎样可以让这个程序既实现功能,又美观,可读性强,同时功能发生变化时可以进行最少量的代码更改。我现在意识到,软件高于程序,这使我受益匪浅。
最大遗憾
对我来说,最大的遗憾就是课时太短,没有进行更深入的了解。课程结束后我会进行更深入的学习。
最后,感谢孟宁老师线上线下的课程带给我的巨大收获,感谢助教检查实验以及给我的建议与指导。