8种常见的Java不规范代码

本文分享了一位开发者在清理现有Java项目代码过程中发现的一些常见问题,包括如何优化代码结构、提高可读性和性能等方面的方法。
在工作上,我最近对一个现有的Java项目代码进行了清理。完成之后,我发现了一些反复出现的不规范代码。所以,我把它们整理成了一个列表出来分享给我的同行希望能引起注意并改善代码的质量和可维护性。
这个列表不区分顺序,全部来自一些代码质量检查工具,如 CheckStyle, FindBugsPMD

在Eclipse中格式化源代码并管理import语句
Eclipse提供了自动格式化源代码和管理import语句的功能(并移除未使用的语句)。你可以使用下面的快捷键来使用这些功能。
  • Ctrl + Shift + F– 格式化源代码。
  • Ctrl + Shift + O– 管理import语句并移除未使用的语句。
除了手动执行这两个功能外,你还可以让Eclipse在保存文件的时候自动格式化源代码并自动管理import语句。要做到这个,在Eclipse中,到 Window -> Preferences -> Java -> Editor -> Save Actions并启用 Perform the selected actions on save,选中 Format source code和 organize imports。

避免在方法中出现多个return语句(退出点):
在你的方法中,确保只有一个 退出点。不要在一个方法中使用多于一个return语句。

如,下面的代码是 不推荐的,因为它有多个退出点(return语句)。
1 privatebooleanisEligible(intage){
2 if(age >18){
3 returntrue;
4 }else{
5 returnfalse;
6 }
7 }

上面的代码可以这么写(当然,下面的代码还可以改进,后面再说)。
1 privatebooleanisEligible(intage){
2 booleanresult;
3 if(age >18){
4 result =true;
5 }else{
6 result =false;
7 }
8 returnresult;
9 }

简化if-else方法:
我们写了一些只要一个参数的工具方法,检查一些条件并根据条件返回一个值。如,在上面见到的 isEligible方法。
1 privatebooleanisEligible(intage){
2 booleanresult;
3 if(age >18){
4 result =true;
5 }else{
6 result =false;
7 }
8 returnresult;
9 }

可以只使用一个return语句来重写此方法。
1 privatebooleanisEligible(intage){
2 returnage >18;
3 }

不要为Boolean,Integer或String创建新的实例:
避免创建新的Boolean,Integer,String等实例。使用Boolean.valueOf(true)代替new Boolean(true)。两种写法效果差不多但却可以改善性能。

在代码块周围使用大括号:
永远不要忘记在块类型语句(如:if,for,while)周围使用大括号。这可以减少代码歧义并且避免在你修改代码块的时候产生新的bug。
不推荐
1 if(age >18)
2 returntrue;
3 else
4 returnfalse;

推荐
1 if(age >18){
2 returntrue;
3 }else{
4 returnfalse;
5 }

把方法的参数声明为final类型:
总是在所有兼容的地方把把方法的参数声明为final。这样做的话,当你无意中修改了参数的值,编译时会得到警告,并且编译生成的字节码也会得到优化。
推荐
1 privatebooleanisEligible(finalintage){ ... }

用大写命名public static final类型成员变量:
总是使用大写命名用public static final类型变量。这样可以让你很容易区分常量和本地变量。
不推荐
1 publicstaticfinalString testAccountNo ="12345678";

推荐
1 publicstaticfinalString TEST_ACCOUNT_NO ="12345678";

把多个if语句合并成一个:
下面的代码
1 if(age >18){
2 if( voted ==false){
3 // eligible to vote.
4 }
5 }

可以使用一个if语句改写为:
1 if(age >18&& !voted){
2 // eligible to vote
3 }

别忘了给switch添加default语句:
总是给switch添加一个default语句。

避免重复使用同样的字符串,创建一个常量吧:
如果你需要在多个地方使用同一个字符串,那就创建一个字符串常量来使用吧。
下面的代码:
1 privatevoidsomeMethod(){
2 logger.log("My Application"+ e);
3 ....
4 ....
5 logger.log("My Application"+ f);
6 }

可以创建一个常量代替字符串"My Application":
1 publicstaticfinalString MY_APP ="My Application";
2
3 privatevoidsomeMethod(){
4 logger.log(MY_APP + e);
5 ....
6 ....
7 logger.log(MY_APP + f);
8 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值