偶然读到这篇程序设计中的一些感悟,觉得真应该和大家一块分享

豆虫 2009-03-16 07:02:59
程序设计中的一些感悟

1)学习应该从基础打起,不要一开始就尝试最高深的技术。
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看更重要的了。
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
4)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
5)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。
6)问问题最好能带代码。
7)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。一般来说,编译是语法问题,而运行是逻辑问题。
8) 书看千遍不如做程序一遍,应该尽量尝试去写程序。
9)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计划,而每个计划都虎头蛇尾。
10)要想到你不是一个人写程序,而是和大家一起写程序。
11)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简单易读的代码。
12)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。
13)复杂的代码如果实在做不到自注释,应该给出适量的注释。
14)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。
15)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。
16)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。
17)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。
18)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。
19)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。
20)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
21)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。
22)应该尽量考虑到数据的并发控制。
23)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。
24)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。
25)对于数据量比较大的情况,应该考虑数据库。
26)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。
27)小的数据可以考虑文件,文件路径应该必须设计成相对路径。
28)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。
29)不要尝试把文件全部读到内存中,应该分次处理大文件。
30)编写程序应该提供相关的测试程序,以提供测试手段。
31)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。
...全文
240 23 打赏 收藏 转发到动态 举报
写回复
用AI写文章
23 条回复
切换为时间正序
请发表友善的回复…
发表回复
gao512008 2009-03-29
  • 打赏
  • 举报
回复
MARK
huangan0301 2009-03-28
  • 打赏
  • 举报
回复
谢谢楼主~~学习了~~~~~~~
lalayq 2009-03-28
  • 打赏
  • 举报
回复
循序渐进,挺好
谢谢分享
lizhenq_1 2009-03-28
  • 打赏
  • 举报
回复
谢谢楼主分享,受益匪浅
yangkaixin1226 2009-03-28
  • 打赏
  • 举报
回复
mark理论上是这么说
successgl 2009-03-28
  • 打赏
  • 举报
回复
学习
lhylysnet 2009-03-28
  • 打赏
  • 举报
回复
谢谢!!学习了!!!
babybabyface 2009-03-28
  • 打赏
  • 举报
回复
有一些范围不光局限写程序
BearKin 2009-03-18
  • 打赏
  • 举报
回复
1)学习应该从基础打起,不要一开始就尝试最高深的技术。

循序渐进 但不知道啥是基础

2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看更重要的了。

补充:之所以不能越过你所会的章节 原因很简单 是因为我们要遵从书中的顺序 按照书中的路线前进(尽管重复学习你已经学会的东西会让你很烦躁 甚至丧失学习下去的兴趣 但是 没办法)

3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。

先做不会的 遇到不会的自己去想这个东西大概是什么样 大概怎么做 然后看看自己能不能做 如果不能做的话 去找个比较厉害的人 跟他说说你自己的想法 然后互相交流下

5)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。
6)问问题最好能带代码。
7)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。一般来说,编译是语法问题,而运行是逻辑问题。

问别人问题的时候尽量把问题简化 而不要扯上太多的关于自己东西个性化的问题 比如说:你的JSP页面在读商品列表的时候出现了NO SESSION异常 而你不需要告诉帮助你的人:你是在读商品列表的时候出现的异常 而是应该问:什么情况会导致NOSESSION 然后逐渐的根据帮助你的人的需要 提供给他们更详细的信息

8) 书看千遍不如做程序一遍,应该尽量尝试去写程序。
写完之后要去理解这个程序为什么这么做



往下就不补充了 感觉LZ往下写跑题了
e5945 2009-03-18
  • 打赏
  • 举报
回复
感谢分享
mark了
Yookel 2009-03-18
  • 打赏
  • 举报
回复
不错,受益非前
ilibaba 2009-03-17
  • 打赏
  • 举报
回复
都是很好的经验总结啊,顶一下,学习了
白夜 2009-03-17
  • 打赏
  • 举报
回复
受益匪浅 !顶一下!!!
susoft2008 2009-03-17
  • 打赏
  • 举报
回复
有道理
liang__ 2009-03-17
  • 打赏
  • 举报
回复
貌似有用。。
我还是喜欢自己去理解这些。
real518 2009-03-17
  • 打赏
  • 举报
回复
学习应该从基础打起,不要一开始就尝试最高深的技术。
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看更重要的了。
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
4)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
5)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。

有道理!!
happydaisy1985 2009-03-17
  • 打赏
  • 举报
回复
谢谢lz分享,mark!
cswat 2009-03-17
  • 打赏
  • 举报
回复
学习下
julyarrow 2009-03-16
  • 打赏
  • 举报
回复
有些东西还是经验与习惯的养成, 强行去记没有用的. 我挺喜欢感悟...呵呵
Csdbfans 2009-03-16
  • 打赏
  • 举报
回复
8) 书看千遍不如做程序一遍,应该尽量尝试去写程序。
9)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计划,而每个计划都虎头蛇尾。
这两句话最实在,话里不深奥,但要完全做到,却非简单之事

62,615

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧