欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java程序员应该遵守的10条纪律

程序员文章站 2024-03-05 19:23:31
有哪些“纪律”是java程序员所要遵守的? 1. 为代码添加注释(add comments to your code). – 每个人都知道这一点,但不是每个人都会这么做。...

有哪些“纪律”是java程序员所要遵守的?

1. 为代码添加注释(add comments to your code). – 每个人都知道这一点,但不是每个人都会这么做。你有多少次“忘记”添加注释了?确实,注释不会为你的程序增加任何函数功能。但是,有多少次,看到2周前写的代码,你都记不起它是干什么的?你很幸运,那些未注释的代码是你自己写的,你脑海中还会有残存的印象。非常不幸,大多时候,代码是别人写的,并且那个人很可能已经离开公司了。有句谚语说的好:“有来有往,互惠互利”,因此程序员应该体谅彼此(还有你自己),给你的代码加上注释。

2. 不要把简单事情复杂化(do not complicate things). – 我曾经这么做过,我相信你也一样。开发者都倾向于采用复杂方式解决简单问题。我们在一个只有5个用户的系统中引入ejb,为一个并不需要框架的应用实现一套框架,采用属性文件、采用面向对象解决方案、使用线程,而这些根本用不着。为什么会这么做?一些人可能不知道有更好的解决方案,但另一些人可能故意这样做来学习新知识,或仅仅是因为有趣。对那些不知道更好解决方案的人,要多听有经验程序员的建议。对于那些纯粹出于个人目的而将设计复杂化的人,我建议你要更加专业一点。

3. 记住 - “越少越好”并非总是如此(keep in mind – "less is more" is not always better). – 高效率的代码是件好事,但很多情况下,并非代码行数越少效率就越高。看下面这个“简单”的例子:

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条件是什么有多困难?再设想一下,写这段代码的人并没遵循第1条 - 为代码添加注释。

把if条件分解成2个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和2个大括号;但是代码确实更加易读、更加容易理解了!

4. 不要“硬编码"(no hard coding please). – 由于时间紧迫,开发者总是会忘记或故意忽略这一条。然而另一种可能是,遵循这条戒律,我们就不会陷入“时间紧迫”的困境。定义一个static final 变量,增加一行代码,又能花多长时间呢?譬如:

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 即可,而不必记住它本身是什么。对这个常量的修改也非常方便,改一个地方即可,而不必在全部代码中查找。

5. 不要发明你自己的框架(do not invent your own frameworks). – 不夸张地讲,已经有几千个框架存在了,大多数还是开源的。很多框架都是极完美的解决方案,并已被用到成千的系统中。我们只要关注最新的流行的框架,至少表面上要熟悉一下。一个最成功的、也是被广泛使用的例子是struts框架,这个开源的web框架是建立web系统的极佳选择,不要试图构造你自己的struts版本,会累死的。但你必须记住第2条(译注:原文是“第3条”,显然不对)戒律 —— 不要把简单事情复杂化。如果你要开发的系统只有3个界面,就不要用struts. 对于这样一个系统,没有足够的需要被“控制”的东西(译注:struts将界面做mvc划分,c即controller,所以作者说there isn't much "controlling" required)。

6. 对print行或字符串说不(say no to print lines and string concatenations). – 我知道为了调试方便,程序员喜欢到处用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 s. 作为对比,calculationwithprint() 方法居然需要令人难以置信的10.52 s来执行!

Java程序员应该遵守的10条纪律

(若你想知道怎么做一个这样的表,请阅读另一篇文章"java profiling with wsad" java profiling with wsad )

为了避免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); 
    } 
} 

字符串(string)连接是另一种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 s 而使用string 连接需要0.08 s,选择哪种应该很明显了。

Java程序员应该遵守的10条纪律

7. 注意图形用户界面(pay attention to the gui). – 无论听上去多荒谬,但有一点我注意过多次了:图形用户界面(gui)对于商业用户而言与程序功能及执行效率一样重要。gui对于应用程序的成功至关重要。 it管理者(译注:这里应该是指程序开发方的it management)常常忽略gui的重要性,很多公司为了省钱而不雇佣web设计人员,而这些设计人员有足够的经验来设计“用户友好”的应用软件。 java程序员不得不依赖他们有限的hmtl知识。我见过非常多对“计算机友好”而非对“用户友好”的应用程序,同时精通软件开发和用户界面开发的开发者非常少见。 如果你是一位不幸被指派做界面开发的java程序员,你要遵循下面3条规则:

a.不要重新发明*。去看那些类似应用系统的界面。
b.首先建立一个原型。这一步非常关键。客户喜欢提前看到他们要用的东西。同样你可以得到他们的反馈,而不是你辛辛苦苦做出来一个客户不喜欢的东西。
c.试戴用户的帽子。换句话说,站在用户的角度查看需求。譬如,一个统计的界面可以分页,也可以不分页。作为开发者,很可能会忽略分页,因为这会减少很多麻烦;而站在客户角度,这就不是一个好的方案,因为数据可能多达几百行。
8. 提前准备需求文档(always prepare document requirements). – 每项业务需求都记入文档。这在童话故事中可能实现,而现实中很难做到。无论时间多么紧迫,无论截止日期如何迫近,你必须确保业务需求被记录下来。(译注:这条明显悖于敏捷开发的观念,大家要独立思考,甄别是非)

9. 单元测试,单元测试,单元测试 (unit-test. unit-test. unit-test). – 我不准备讨论如何单元测试的细节,我只是想说这必须要做。这是编程中最基本的规则了,尤其不能忽略。如果你同事能为你的代码创建一个测试计划,那就再好不过了;如果不能,那就要自己做。做单元测试计划时,遵循下面原则:

a.编码前就写单元测试
b.保留单元测试的注释
c.对任何“有趣的”公共方法都要做单元测试(“有趣的”是指除了像最常见的getter/setter这类方法外的方法,但包含有自己内容的getter/setter 方法)
10. 记住:质量,而非数量(remember – quality, not quantity). - 不要待的太晚(除非有必要)。我知道有时因为产品问题,截止期限或其他突发事件,不能按时下班。但经理不会因为你为一般问题待的太晚而感激或奖励你;他们会为有质量的工作而感激你。如果你遵循上面的列的原则,你就会写更健壮的、少bug的程序。这才是你最应该做的。

本文中总结了java程序员最应注意的10项守则。仅仅知道是不够的,还要遵循它们。希望这些守则能让我们做更加专业的程序员。