人的记忆力会随着岁月的流逝而衰退,写作可以弥补记忆的不足,将曾经的人生经历和感悟记录下来,也便于保存一份美好的回忆。那么我们该如何写一篇较为完美的范文呢?下面是小编为大家收集的优秀范文,供大家参考借鉴,希望可以帮助到有需要的朋友。
《程序员修炼之道》篇一
亲耳听到过不少大牛的演讲,见到过项目中的神人在键盘上运指如飞的编程速度,当时就
被震撼了。当编程越来越成体力活,我们还能有自己的思想,还能修炼为java系统级别的
程序员嘛?学习与修炼以下知识与技能,帮你早日达成愿望。
一:java语言学习
对线程(thread),串行化,反射,网络编程,jni技术,容器(map,list, iterator), 类加载器
(classloader),输入输出流,垃圾回收机制,有比较深入的了解,最起码做过项目应用。有
过java项目的性能优化经验,最起码掌握一种性能监视工具的使用,熟悉jvm参数,最起
码知道可以在jvm启动时指定不同垃圾回收机制,以及不同垃圾回收机制之间的
差别,熟悉jvm参数优化。
二:j2ee方面
最好知道jdbc规范是怎么回事情,面对oracle数据库如果告诉你jdbc驱动不能用了,你
还知道有oci驱动可以。掌握常见的sql语句,熟悉jms,jndi等组件,掌握一套web开
发模式,从前台到后台,有能力整合好这样的框架。理解并掌握mvc思想,像ssh已经实
现了mvc的分层,几乎不需要你自己再实现,假设你开发一个简单的swing程序,你能mvc
就说明你真的掌握了mvc的精髓。有能力在j2ee前端开发中构建自己的mvc模式,知道
什么是web2.0,知道什么是soa,saas,saap等含义
三:理解并能合理运用设计模式,uml建模
知道并理解设计模式中蕴含的几种基本原则如:里氏替换原则,开闭原则,合成复用原则,依赖倒置原则有很好的理解,并能举例说明。对常用的设计模式如工厂模式,单例模式,观
察者模式,责任链模式,桥接模式等知道灵活运用,明白什么是回调(callback)。最后用一位
高人话来总结设计模式,它是为了让软件更容易被别人读懂,更容易维护而产生,设计模
式本质是程序员之间的交流,如果a用工厂模式设计一个模块b来接替,a只要说该模块是
工厂模式实现,b维护起来应该容易得多,所以设计模式是关于交流,不关于代码。切忌滥
用设计模式。学会使用uml建模工具至少熟悉一种url建模工具。
四:注重用户体验,掌握kiss原则,知道欧卡姆剃刀原则
顾客就是上帝这个口号我们已经喊了n年了,程序员的劳动成果最终也需要转换为服务提
供给客户,用户体验至关重要,常常看到的场景是功能实现了,软件很难使用,程序员有个
很充足的理由我不是美工,其实注重用户体验跟美工八杆子也打不到一起,foxmail的成功
在很大程度是用户体验的成功,友好,清晰的用户提示,强的容错与纠错设计是获得好的
用户体验的不二法门。傻瓜相机顾名思义傻子都会使用,这个就著名的kiss原则(keep it
simple and stupid)意思是ui设计要简单明了,傻子一看就知道怎么用,想想我们做出来的
东西,对照说明书都不知道怎么用。另外一个就是最著名的例子iphone手机外观设计,是 典型的欧卡姆剃刀设计原则来完成人机交互。
五:自动测试与软件配置管理(scm)实现
知道什么是软件配置管理,知道hudson微机原理闹危机,汇编语言不会变,实变函数学
十遍。计算机基础知识被大家普遍忽视。从今天开始好好学习吧……
十一:java代码反编译与代码保护
java编译产生字节码,因而可以被轻松的逆向工程(反编译),微软的c#生产的dll也一样可
以被轻松反编译。正式由于这个原因产生了许多java开源的代码保护工具,而proguard是
其中佼佼者,已经被google集成在android之中用于java代码保护,访问这里了解更多:
http:///
十二:努力成为某个行业或者领域骨干
面对漫长的职业生涯,要想不被淘汰,必须具备一招鲜吃遍天下的能力,选择自己感兴趣的
方向,努力而深入的研究,计算机技术发展到今天已经细分很细,努力研究一种java开源
框架或者开源http服务器源码或者研究过网络爬虫源码或者webkit内核,不愁没有人要
你。如果你是非常了解金融,企业erp,证券,保险,移动应用行业的应用开发业务的人,一样不用愁工作。这些知识不随语言而改变,努力做一个有核心竞争力的java程序员。
十三:提高语言与书面表达能力,掌握基础的项目管理知识
文档与语言表达能力是最好的向外界展现自己能力的方式,很多程序员编程能力很高,表达
能力一般,linux能够成功,除了归功于网络社区的力量之外,也得益于linux作者本人给各
大基金会写信,宣传推广,试想如果没有良好的书面语言表达能力,即使linux系统再优秀,却无法被准确表达,失去各大基金会的支持,linux还会像今天这么好的局面嘛。所以重视
文档,重视提升沟通与表达能力,才有可能成为java系统程序员。掌握基本的2/8原则,学
会将模块细化分配给不同的人,预见并控制项目风险,把握项目进度,优化流程,合理的时
间管理,了解tdd,熟悉敏捷开发模式,常规软件开发模式。
十四:掌握英语,良好的读写能力
英语是计算机的母语,掌握好英语对于阅读英文资料学习新技术大有帮助,我的建议是尽量
读英文原版书,如果是算法方面的可能会困难一点,但是其它像设计模式,软件工程,oo
编程思想等尽量读原版,提高自己的英文水平,多多访问开发者,code project,程序员天堂,pc-magazine等英文it网站。英语绝对是你必须修炼与提高的技能。此外英语好在外资企业
尤其重要,只有外语足够好才可能在外资企业中突破职业瓶颈,向上发展。
《程序员修炼之道》篇二
找其他开发人员合作开发。我们正处在科技历史上第一个绝好的时代,你几乎不用在意在哪工作、为谁工作。只要你有一个还过得去的网络,你就可以和另外一个在世界任何角落里的人一起来完成某段程序。我知道,越来越多的有经验的开发人员开始把他们的一部分时间投入到这种知识共享里。我的朋友evan light特地留出了时间来开发一个帮助ruby爱好者合作行动的网站。我从事这样的事情也有一段时间了。你想开发一些floss程序吗?发邮件给我,我们会帮你准备些东西。
阅读经典著作:《代码大全(第二版)》,《程序员修炼之道》,《程序设计实践》,《设计模式》等。阅读wikiwiki(有时也被称作wardswiki)。这一条怎么强调也不为过。经常我会感觉到所有我学到的真正关于编程的知识都是在浏览这些网站的过程中慢慢的学到的。学习别人的代码。github万岁!如果你会一点ruby,想从别人整理好的现成经验入手,你可以读一下《best of ruby quiz》。参与开发者论坛。如果没有这样的网站,创建一个。讨论问题。我不在意你认为自己是一个多么菜的菜鸟。没有任何一种形式能比通过讨论一个问题来学习这个问题更有效的方法了。写博客。不要在意是否是原创。互联网上很多非常有用的博客都是广泛的搜集程序员的经验和错
误,以及如何克服这些问题的博客。反省是学习过程中最重要的一件事情,写博客能帮助你反省。会出乎你的意料,你不久就会收到你的读者的反馈。
我相信你之前听说过这一条:参与开源项目,修改其中的bug或捐献代码。丢硬币。是头像就选择vim,否则选择emacs。学习使用这些编辑器。应该让这两种编辑器伴随你余下的编程生涯。强大灵活的编辑器会让好程序员更好。多学习几种编程语言。但起初应该先学一种语言。你应学习一种重要的语言,它能让你对编程语
言有个大致的认识,让你第一天就爱上编程,你需要花大量的时间去学习这种语言中的各种知识,否则你漏掉知识点或不久就会忘记。一旦你掌握了这种语言,你需要学习新的语言来验证在第一种语言中学到的知识。尽量选择风格迥异的语言。我曾看过seven languages in seven weeks这本书,它让我认识了各种各样的编程模式,很好的书。
具。订阅跟你使用的语言和平台相关的邮件新闻。人们有时会忘了,在各种博客,hacker news,以及twitter里,还有一个精彩的充满讨论的世界。邮件列表是一个很通用、很有用的来比较各种讨论观点的工
stackoverflow是你的朋友。不要花太多的时间去研究所谓的“最好的“工具。我曾经愚蠢的花上数天或数周去为某个项目找出
一种”最好“的框架来提高开发效率。不要落入这种陷阱。当你还是一个不太熟练的程序员时,选一种大家都在用的语言和框架。重要的是当你遇到瓶颈是你知道如何处理。之后你才可以去寻找一种完美的…
寻找实习机会。以及最基本的:练习,练习,练习。在班上练,在家里练。锻炼编程基本功。编程跟其它技术一
样:最终,一切归结于练习。
《程序员修炼之道》篇三
程序员修身之道
第一章:
关于编程的各种话题:个人责任,曳光弹开发,调式策略,源程序设计,按合约设计,重构,无情测试。
编程是一种技艺,一种需要用心学习的技艺。
在所有的弱点中,最大的弱点就是害怕暴露弱点。
注重实效的程序员对他或她的职业生涯负责,并且不害怕承认无知和错误。
我们可以为我们的能力自豪,但是对于我们的缺点-----还有我们的无知和我们的错误----我们必须诚实。
破窗户的故事
一扇破窗户,只要那么一段时间不修理,就会渐渐给建筑的居民带来一种废弃感-------一种职权部门不关心这座建筑的感觉。于是又一扇窗户破了。人们开始乱扔垃圾。出现了乱涂乱画。严重的结构损坏开始了。在相对较短的一段时间里,建筑就被毁得超出了业主愿意修理的程度,而废弃感变成了现实。(不要容忍破窗户(低劣的设计、错误的决策、或是糟糕的代码))
不做井里之蛙,更不做锅里之蛙。(井里之蛙看不到外面的世界,锅里之蛙被慢慢煮熟却还不知道怎么死的)
早起的鸟儿有虫吃,但是早起的虫呢?
简单而得体地阻止你的问题。记住你是在请求帮助,不要显得好像是在要求对方回答。除非你能够与他人交流,否则就算你拥有最好的主意、最漂亮的代码、或者是最注重实效的想法,最终会毫无结果。没有有效的交流,一个好想法就只会是一个无人关心的孤儿。
鼓励大家通过提问来交谈,或是让他们总结你告诉他们的东西。
盘书焱 第 1 页 2014/1/3
《程序员修炼之道》篇四
才智尚招聘网
中国it程序员长生不老之道
大学里学完计算机专业后,毕业后从事了近20年的it。这期间每次大学同学聚会都会听到这样的诘问:“还在写代码哪?”似乎毕业后一直在写代码是一件丢人的事情。这个月参加了大学同学毕业20年的聚会,到会的14位计算机系的老同学,有做测试的,有做硬件维修的,有做售前的,有做售后的,有做金融的,有做国企高管的,就是没有一个还在做编程的。虽然就我一个做软件开发顾问,还在写点代码,但已经没有一个真正意义上的程序员了。可以这样说,在中国,无论是企业还是个人,都普遍认为程序员是吃青春饭的,程序员的职业生涯是很短暂的,一般也就是10年之内。
相比之下,美国就不是这样。一个美国人,出生于1961年,从23岁开始做程序员,39岁做软件咨询师,43岁做公司董事,49岁做首席科学家,从50岁(即2011年1月)开始至今在facebook做程序员,开发和优化一个用于处理消息传输的c++的服务器。他就是发明极限编程xp和测试驱动开发tdd的美国程序员kent beck。
才智尚招聘网
是什么力量驱使kent beck在做过了公司董事之后,还在50多岁的高龄继续做程序员呢?这个问题还是等找机会我问问kent本人吧。另外一方面,即使kent回答了这个问题,对于我们的帮助也很有限,因为他是美国人,咱们是中国人,文化不同,观念不同,环境不同,无法效仿。
那么,在中国这样的环境下,中国程序员就不能像kent那样能保持程序员职业生涯“长生不老”吗?
7岁的儿子喜欢听小布丁里单田芳爷爷讲的评书《西游记》,其中有一段美猴王寻访长生不老之道的一段,在《西游记》第一回中,原文如下:
美猴王享乐天真,何期有三五百载。一日,与群猴喜宴之间,忽然忧恼,堕下泪来。众猴慌忙罗拜道:“大王何为烦恼?”猴王道:“我虽在欢喜之时,却有一点儿远虑,故此烦恼。”众猴又笑道:“大王好不知足!我等日日欢会,在仙山福地,古洞神州,不伏麒麟辖,不伏凤凰管,又不伏人间王位所拘束,自由自在,乃无量之福,为何远虑而忧也?”猴王道:“今日虽不归人王法律,不惧禽兽威服,将来年老血衰,暗中有
才智尚招聘网
阎王老子管着,一旦身亡,可不枉生世界之中,不得久住天人之内?”众猴闻此言,一个个掩面悲啼,俱以无常为虑。
只见那班部中,忽跳出一个通背猿猴,厉声高叫道:“大王若是这般远虑,真所谓道心开发也!如今五虫之内,惟有三等名色,不伏阎王老子所管。”猴王道:“你知那三等人?”猿猴道:“乃是佛与仙与神圣三者,躲过轮回,不生不灭,与天地山川齐寿。”猴王道:“此三者居于何所?”猿猴道:“他只在阎浮世界之中,古洞仙山之内。”猴王闻之,满心欢喜,道:“我明日就辞汝等下山,云游海角,远涉天涯,务必访此三者,学一个不老长生,常躲过阎君之难。”噫!这句话,顿教跳出轮回网,致使齐天大圣成。
你看,在中国传统文化里,有三种人是能长生不老的,他们分别是“佛”、“仙”和“神圣”,分别对应着“释”、“道”和“儒”。
中国的程序员们,如果能够按照儒释道阐释的方法,在自己的程序员职业生涯中,不断修行软件开发的心法和手法,最后达到“佛”、“仙”和“神圣”的境界,不就成为像kent beck那样长生不老的程序员了吗?
《程序员修炼之道》篇五
《程序员修炼之道》读后感
编程技术就是程序员的手艺,你的程序就是你的艺术品。时刻关注自己的技艺,保持热情、保持好奇,争取做到富有专长而又多才多艺。
看似朴素的道理,实际是若干经验的总结,就像这本书的自序所讲的,这是一本包含有许多朴素的经验,写给注重实效的程序员的一本“演员的自我修养”。
简单和朋友们分享几点:
怎样提出你的问题
1:确切地知道你想要问什么,并尽量明确具体;
2:小心而得体地组织你的问题,记住你是在请求帮助;
3:发邮件时请使用有意义的主题;
4:坐回椅子上,耐心等候
破窗
团队不能容忍破窗(产品的不完善的地方),需要指定人修复,不能一直放着不管。当你看到糟糕的设计、错误的决策和糟糕的代码时,修正它们。在工作中,很容易对源源不断的bug不耐烦,或许被自己说服侥幸绕过,以后就会有更多的直至难以修复。破窗户讲的故事是一个小区的一扇窗户没有及时维修导致整个小区陷入被更多破坏的现实,人们再想起维修时,代价巨大,治安特别好的地区也对破窗严格治理。
不要恐慌
做一次深呼吸,思考什么可能是bug的原因。记得刚入团队时,我时常会对难以捉摸,尤其是不能复现的bug感到恐惧,但细细寻找,你还是能看到蛛丝马迹。
温水煮青蛙
个人和团队假如一直在一个假设的环境或者需求或者条件下继续下去,就很可能像那只可怜的青蛙一样,或者定时的检测下环境或条件或需求是否变化,或者团队里面专门有人来检测
重复的危害
不要在系统各处对知识进行重复。作为程序员,我们收集、组织、维护和利用知识。我们在规范中记载知识、在运行的代码中使其活跃起来并将其用于提供测试过程中所需的检查。遗憾的是,知识并不稳定。所有这些不稳定都意味着我们要把很大一部分时间花在维护上,重新组织和表达我们的系统中的知识。程序员须持续不断地维护。我们的理解逐日变化,当我们设计或编码时,出现了新的需求。环境或许变了。不管原因是什么,维护都不是时有时无的活动,而是整个开发过程中的例行事务。可靠地开发软件、并让我们的开发更易于理解和维护的惟一途径,是遵循我们称之为dry的原则:系统中的每一项知识都必须具有单一、无歧义、权威的表示。
正交性
不要把任何一项知识分散在多个系统组件中。在计算技术中,该术语用于表示某种不相依赖性或是解耦性。如果两个或更多事物中的一个发生变化,不会影响其他事物,这些事物就是正交的。非正交的例子:直升机驾驶操作的各个控制器之间就是相互影响的,不是正交的。
正交的好处就是为了可以局部修正(local fix)。
何时使用异常
将异常用于异常的问题。例如:文件读写,例程返回值,各种状态异常检测,服务器超时等异常情况,都需要使用异常,通常为异常分等级,可以抛出异常,或者将异常写入日志。
交流
我们不是活在真空世界,需要花大量时间与人交流。只有当你是在传达信息时,你才是在交流。
有效交流的几种方法:知道你想要说什么,了解你的听众,选择时机,选择风格,让文档美观,让听众参与,做倾听者,回复他人。
定期为你的知识资产投资
让学习成为习惯。编程语言、技术日新月异,小伙伴们都感受至深,幸运的是我们的知识获得比任何行业都更加容易和方便,大量的社区,教程和热心的作者。书中也给程序员提了几点建议,每年学习一门新的语言,每个季度阅读一本技术书籍等。
让复用变得容易
如果复用很容易,人们就会去复用。创造一个支持复用的环境。将相同的功能抽离出来,可能会大量用到的方法使用静态关键字。
在你的作品上签名
过去时代的会陷入自我欣赏中,他其实还有一个作用,我对代码负责,我测试过并确保他的良手艺人为能在他们的作品上签名而自豪。你也应该如此。坦白的说,签名之后再看这段代码会非常愉悦,有时还好运行,也是一种自我监督吧。
“我的源码让猫吃了”,想想作为程序员的我们,是不是经常会帮自己解脱,向领导,测试,客户推卸责任,其实对于他们仿佛也就好比听“我的源码让猫吃了”这句话,是不是很讽刺?不管我们某个人基础再扎实,解决问题的能力再强,如果缺失了对自己的软件的责任,一定不会有好的工作成果。
很多很多,这些不是做过一次两次就说明已经掌握了,需要一个持续的过程去注意,实践,直到他们成为你的习惯,这样,你才能成为一个“专家程序员”。
来源:网络整理 免责声明:本文仅限学习分享,如产生版权问题,请联系我们及时删除。
【本文地址:http://www.pourbars.com/zuowen/1077297.html】