有许多标准和实践准则可适用于Java开发者,但此处要说的,是每个Java开发者需坚守的基本原则。
一、为代码加注释。虽然每个人都知道这点,但有时却不自觉忘了履行,今天你“忘了”加注释了吗?虽然注释对程序的功能没什么“贡献”,但过一段时间,比如说两星期之后或者更长,回过头来看看自己的代码,说不定已经记不住它是干什么的了。如果这些代码是你个人的,那还算是走运了,不幸的是,当然了,大多数时候都是别人的不幸,很多时候大家都是在为公司写代码,写代码的人也许早已经离开了公司,但别忘了一句古话,有来有往嘛,为他人,也为我们自己,请为你的代码加上注释。
二、不要让事情复杂化。程序员有时候总是对简单问题想出复杂的解决方案,比如说,在只有五个用户的程序中引入EJB、对程序实现了并不需要的框架(framework),之类的还有属性文件、面向对象解决方案、多线程等等。为什么要这样做呢?也许我们并不知道是否这样会更好,但这样做也许可以学到一些新东西,或者让自己更感兴趣一些。如果是不知道为什么这样做,建议多请教经验丰富的程序员,如果是为了个人的目的,麻烦让自己更专业一点。
三、始终牢记——“少即是好(Less is more)并不总是对的”。代码效率虽然很重要,但在许多解决方案中,编写更少的代码并不能改善这些代码的效率,请看下面这个简单的例子:
if(newStatusCode.equals("SD") && (sellOffDate == null ||
todayDate.compareTo(sellOffDate)<0 || (lastUsedDate != null &&
todayDate.compareTo(lastUsedDate)>0)) ||
(newStatusCode.equals("OBS") && (OBSDate == null ||
todayDate.compareTo(OBSDate)<0))){
newStatusCode = "NYP";
}
能看明白if条件语句是干什么的吗?能想出来是谁写的这段代码吗?如果把它分成两段独立的if语句,是不是更容易理解呢,下面是修改后的代码:
if(newStatusCode.equals("SD") && (sellOffDate == null ||
todayDate.compareTo(sellOffDate)<0 || (lastUsedDate != null &&
todayDate.compareTo(lastUsedDate)>0))){
newStatusCode = "NYP";
}else
if(newStatusCode.equals("OBS") && (OBSDate == null ||
todayDate.compareTo(OBSDate)<0))
{
newStatusCode = "NYP";
}
是不是读起来容易多了呢,在此只是多加了一个if和两个花括号,但代码的可读性与可理解性就一下子提高了一大截。
四、请不要硬编码。开发者经常有意“忘记”或忽略掉这点,因为有些时候开发日程逼得实在太紧。其实,多写一行定义静态变量的代码能花多少时间呢?
public class A {
public static final String S_CONSTANT_ABC = "ABC";
public boolean methodA(String sParam1){
if (A.S_CONSTANT_ABC.equalsIgnoreCase(sParam1)){
return true;
}
return false;
}
}
现在,每次需要将“ABC”与其他变量进行比较时,不必记住实际代码,直接引用A.S_CONSTANT_ABC就行了,而且在今后需要进行修改时,也可在一处修改,不会翻遍整个源代码逐个修改了。
五、不要“创造”自己的框架(framework)。确切来说,有数以千计的各种框架存在,而且大多数是开源的,这些框架都是优秀的解决方案,可用于日常程序开发中,我们只需使用这些框架的最新版本就行了,至少表面上要跟上形势吧。被大家广为接受的最为明显的一个例子就是Struts了,这个开源web框架非常适合用在基于web的应用程序中。是不是想开发出自己的Struts呢,还是省点力气吧,回头看看第二条——不要让事情复杂化。另外,如果正在开发的程序只有3个窗口,就不要使用Struts了,对这种程序来说,不需要那么多的“控制”。
六、不要使用println及字符串连接。通常为了调试方便,开发者喜欢在可能的所有地方都加上System.out.println,也许还会提醒自己回过头来再来删除,但有些时候,经常会忘了删除或者不愿意删除它们。既然使用System.out.println是为了测试,那么测试完之后,为什么还要留着它们呢,因为在删除时,很可能会删除掉真正有用的代码,所以不能低估System.out.println危害啊,请看下面的代码:
public class BadCode {
public static void calculationWithPrint(){
double someValue = 0D;
for (int i = 0; i <10000; i++) {
System.out.println(someValue = someValue + i);
}
}
public static void calculationWithOutPrint(){
double someValue = 0D;
for (int i = 0; i < 10000; i++) {
someValue = someValue + i;
}
}
public static void main(String [] n) {
BadCode.calculationWithPrint();
BadCode.calculationWithOutPrint();
}
}
从测试中可以发现,方法calculationWithOutPrint()执行用了0.001204秒,作为对比,方法calculationWithPrint()执行可是用了10.52秒。
要避免浪费CPU时间,最好的方法是引入像如下的包装方法:
public class BadCode {
public static final int DEBUG_MODE = 1;
public static final int PRODUCTION_MODE = 2;
public static void calculationWithPrint(int logMode){
double someValue = 0D;
for (int i = 0; i < 10000; i++) {
someValue = someValue + i;
myPrintMethod(logMode, someValue);
}
}
public static void myPrintMethod(int logMode, double value) {
if (logMode > BadCode.DEBUG_MODE) { return; }
System.out.println(value);
}
public static void main(String [] n) {
BadCode.calculationWithPrint(BadCode.PRODUCTION_MODE);
}
}
另外,字符串连接也是浪费CPU时间的一个大头,请看下面的示例代码:
public static void concatenateStrings(String startingString) {
for (int i = 0; i < 20; i++) {
startingString = startingString + startingString;
}
}
public static void concatenateStringsUsingStringBuffer(String startingString) {
StringBuffer sb = new StringBuffer();
sb.append(startingString);
for (int i = 0; i < 20; i++) {
sb.append(sb.toString());
}
}
在测试中可发现,使用StringBuffer的方法只用了0.01秒执行完毕,而使用连接的方法则用了0.08秒,选择显而易见了。
七、多关注GUI(用户界面)。再三强调,GUI对商业客户来说,与程序的功能及效率同等重要,GUI是一个成功程序的最基本部分,而很多IT经理往往都没注意到GUI的重要性。在现实生活中,许多公司可能为了节省开支,没有雇用那些有着设计“用户友好”界面丰富经验的网页设计者,此时Java开发者只能依赖他们自身的HTML基本功及在此领域有限的知识,结果,很多开发出来的程序都是“计算机友好”甚于“用户友好”。很少有开发者同时精通软件开发及GUI设计,如果你在公司“不幸”被分配负责程序界面,就应该遵守下面三条原则:
1、 不要再发明一次轮子,即不做无用功。现有的程序可能会有类似的界面需求。
2、 先创建一个原型。这是非常重要一步,用户一般想看到他们将使用的东西,而且可以先利用这个原型征求用户的意见,再慢慢修改成用户想要的样子。
3、 学会换位思考。换句话来说,就是从用户的角度来审查程序的需求。举例来讲,一个汇总的窗口可以跨页或者不跨页,作为一个软件开发者,可能会倾向于不跨页,因为这样简单一些。但是,从用户的角度来看,可能不希望看到上百行数据都挤在同一页上。
八、文档需求不放松。每个商业需求都必须记录在案,这可能听上去像童话,似乎在现实生活中很难实现。而我们要做的是,不管开发时间多紧迫,不管最终期限多临近,对每个商业需求都必须记录在案。
九、单元测试、单元测试、单元测试。关于什么是单元测试的最好方法,在此不便细说,只是强调,单元测试一定要完成,这也是编程中最基本的原则。当然了,如果有人帮你做单元测试自然是最好,如果没有,就自己来做吧,当创建一个单元测试计划时,请遵守以下三条最基本的原则:
1、 先于编写类代码之前编写单元测试。
2、 记录单元测试中的代码注释。
3、 测试所有执行关键功能的公有方法,这里不是指set和get方法,除非它们是以自己独特方式执行set和get方法。
十、质量,而不是数量。有些时候因为产品问题、期限紧迫、或一些预料之外的事情,导致常常不能按时下班,但一般而言,公司不会因为雇员经常加班而对之表扬和奖励,公司只看重高质量的工作。如果遵守了前九条原则,你会发现自己写出的代码bug少且可维护性高,无形中质量提高了一大步。
- 浏览: 53866 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
啊哈小小勇:
找一个好老师,自己勤动手!
有理想的程序员必须知道的15件事 -
showzh:
...
hibernate 数据源配置汇总 (jdbc,jndi+dbcp, proxool ,c3p0) -
Frederic:
兄弟,callback是在spring中的!
hibernate中使用原生sql语句 -
fucktianya:
垃圾方法,还不如用callback呢
hibernate中使用原生sql语句 -
Frederic:
仅此而已 写道方法过时, 不推荐使用。那你推荐使用哪种方式使用 ...
hibernate中使用原生sql语句
发表评论
-
充分使用HTML5特性进行搜索引擎优化(SEO)
2014-03-14 15:02 878随着越来越多的网站和应用采用HTML5方式编写,如何和海量信 ... -
Perl、PHP、ASP、JSP技术进行比较
2014-03-14 14:48 1415很多人在刚开始学 ... -
可预判的超链接打开方式
2012-08-26 20:51 1150不知道博友们有没有这么一种需求,或是一个隐性需求--“可预判的 ... -
eclipse启动出现 An internal error occurred during: "Refreshing external folders".
2012-08-16 15:20 2454这是一个eclipse的bug,如果各位遇到如下图情况 问题 ... -
开源许可证GPL、BSD、MIT、Mozilla、Apache和LGPL的区别
2013-08-28 21:55 1489首先借用有心人士的一张相当直观清晰的图来划分各种协议:以下是上 ... -
Java编程中“为了性能”要注意的几点
2012-04-06 00:10 10761. 尽量在合适的场合使用单例 使用单例可以 ... -
Jsp或JS获取用户来源
2012-03-05 13:32 1672Jsp或JS获取用户来源 问题描述 ... -
android实例收藏
2012-02-20 23:52 1194分享45个android实例源码 ... -
权限管理基本分类
2012-02-20 16:55 1719权限有三种最基本分类 1、登录权限 该账户是否有登 ... -
郁闷的win7 断电 +东芝笔记本L600-59R
2011-06-04 10:45 1715症状:断电后win7不能正常启动,修复黑屏,安全模式无法进入 ... -
有理想的程序员必须知道的15件事
2011-05-11 22:47 986作为程序员,要取 ... -
泄露你的JavaScript技术很烂的五个表现
2011-05-11 22:42 938Javascript在互联网上名声 ... -
javaee 操作数据库乱码
2011-03-03 11:35 1897检查你的数据库使用的是什么编码?上篇也有详细说明,这里 ... -
hibernate 数据源配置汇总 (jdbc,jndi+dbcp, proxool ,c3p0)
2011-03-03 11:32 4495汇总 Hibernate 与 jdbc,jndi+db ... -
java Context(上下文)释义
2011-02-20 16:53 15008最近学习中经常看到Context,没能明白中文含义,一 ... -
struts2 No result defined for action那些事
2011-02-19 21:47 1524注意:下面红色字体为关键部分。 问题: 兄弟们在使用str ... -
字符串操作集锦(更新中...)
2011-01-25 15:41 1067以下字符串的操作,多用于自己用jdbc写o/r mapping ... -
java 中聚合与组合以及has a、is a关系说明
2011-01-25 12:30 4964概念 聚合:表示两个对象之间是整体和部分的弱关系,部分的生 ... -
“切客”,未来之趋势
2010-11-03 09:16 1010先来说说概念概念: ...
相关推荐
内容概要:本书为Java开发者提供了详细的指南,介绍了如何利用OpenAI的ChatGPT和其他API(如Whisper、DALL·E)进行自然语言处理和多模态应用。书中详细讲解了从基本的概念到实际的应用,包括创建聊天机器人、文本...
Java 的产品叫JDK(Java Development Kit: Java开发者工具包),必须安装JDK才能使用java。目前比较稳定的版本为 JDK17. 我这个是JDK17.0.9这个版本
Java开发者在开发过程中遵循的规范和指南
Java API文档是Java开发者的重要参考资料,它包含了Java开发工具包(JDK)中的所有类、接口、方法和常量的详细说明。这份中文网页版的Java API文档为中国的开发者提供了便利,无需通过英文版本来学习和查找API信息,...
读书笔记:《阿里巴巴java开发者手册》嵩山版
Java开发者文档,分享日常学习的一些小知识点。 前端,后端,测试,运维等。
适合java开发者的Oracle 的一些常用的sql,按着上面的顺序一个一个敲打即可,快速入门Oracle,黑马课程
本项目是IntelliJ IDEA的插件,能帮助java开发者自动生成javadoc文档注释
本资源提供了 Java 简历的自我评价,旨在帮助 Java 开发者编写简历和准备面试。该资源涵盖了 Java 简历的自我评价、技能概况、工作经验、项目经验、教育背景、技能特长、语言能力、团队领导能力、项目管理能力、金融...
本项目是IntelliJ IDEA的插件,能帮助java开发者自动生成javadoc文档注释
Java开发者文档,分享日常学习的一些小知识点。 前端,后端,测试,运维等。
JDK_API_1_6_zh_CN,JavaTM 2 Platform Standard Edition 6,是JAVA开发者的必备资料!
这个压缩包包含的是一系列JavaCV所需的jar包,这些库使得Java开发者能够轻松地进行图像处理、视频分析以及计算机视觉相关的任务。以下是对这些知识点的详细说明: 1. **JavaCV**: JavaCV 是一个开源项目,由...
本文将详细探讨Java开发者的岗位职责以及为满足这些职责所需具备的技能。 首先,Java开发者的职责可以从软件开发生命周期的各个阶段来理解。在项目开始阶段,Java开发者需要与项目经理和其他团队成员一起,理解项目...
以下将详细介绍"开发者必须掌握的基础"这一主题,包括与Java相关的基础知识。 首先,我们需要了解计算机基础。"computer-basic.pdf"这个文件很可能包含了计算机系统的基本构成,如硬件(CPU、内存、硬盘等)和软件...
Java API文档是Java开发者的重要参考资料,它包含了Java开发工具包(JDK)中的所有类、接口、方法和常量的详细说明。这份中文网页版的Java API文档为中国的开发者提供了便利,无需通过英文版本来学习和查找API信息,...
Java 简历模板是 Java 开发者在求职时的重要工具,以下是 Java 简历模板的详细解释和知识点总结: 个人信息 在简历中,个人信息是非常重要的,包括姓名、性别、照片、出生日期、籍贯、手机、电子邮件、个人主页等...
Java语言的基本语法是学习Java的第一步,了解Java语言的基本语法可以帮助开发者更好地掌握Java语言。 2. Java面向对象编程:Java语言支持面向对象编程(OOP),它可以模拟现实世界中的对象和关系。面向对象编程的...
Java进阶必备,适合有一定基础的Java开发者。Java进阶必备,适合有一定基础的Java开发者。
《疯狂Java程序员的基本修养》随书光盘的内容涵盖了成为一名优秀Java程序员所需掌握的诸多关键知识点。这份资源旨在帮助开发者全面提升其在Java领域的专业素养,包括但不限于编程基础、面向对象设计原则、异常处理、...