阿里巴巴开发手册解析个人笔记(七)流程控制

注释规范为纯记忆,不再说明

1. 【强制】在一个 switch 块内,每个 case 要么通过 break/return 等来终止,要么注释说明程
序将继续执行到哪一个 case 为止; 在一个 switch 块内,都必须包含一个 default 语句并且
放在最后,即使空代码。

实例程序

public class MainTest {
	public static void main(String[] args) {
		switch (1) {
		case 1:
			System.out.println("你好");
		case 2:
			System.out.println(" 我是");
		case 3:
			System.out.println(" switch");
		case 4:
			System.out.println(" 程序的");
		default:
			System.out.println("小例子");
		}
	}
}

这个很容易想明白,因为case没碰到break会运行下去,而没有defult流程会不完成。

2. 【强制】在 if/else/for/while/do 语句中必须使用大括号。 即使只有一行代码,避免采用
单行的编码方式: if (condition) statements;

实例程序


public class MainTest {
	public static void main(String[] args) {
		int i=2;
		while (i==2) 
			i=1;
			if ( i==1){
				i=2;
			}
	}
}

以为是死循环,结果运行一次结束。

3. 【强制】在高并发场景中,避免使用”等于”判断作为中断或退出的条件。
解析:
解析来自:https://blog.csdn.net/zxm1306192988/article/details/59701101
实例程序

package ClassFiveDotFive;

/*
 * 一、用于解决多线程安全问题的方式:
 * synchronized:隐式锁
 * 1、同步代码块
 * 2、同步方法
 * jdk 1.5后
 * 3、同步锁 Lock  
 * 注意:是一个显式锁,通过lock()方式上锁,必须通过unlock()方法释放锁
 */
public class TestLock {
	public static void main(String[] args) {
		Ticket ticket = new Ticket();
		new Thread(ticket, "1号窗口").start();
		new Thread(ticket, "2号窗口").start();
		new Thread(ticket, "3号窗口").start();
	}
}

class Ticket implements Runnable {
	private int tick = 100000;

	@Override
	public void run() {
		while (true) {
			--tick;
			System.out.println(Thread.currentThread().getName() + "剩余票数:" + tick);
			if (tick == 0) {
				break;
			}

		}
	}

}

并发异常的一个例子

2号窗口剩余票数:25
2号窗口剩余票数:0
1号窗口剩余票数:1
3号窗口剩余票数:15
4. 【推荐】 表达异常的分支时, 少用 if-else 方式, 这种方式可以改写成:
if (condition) {
...
return obj;
}
// 接着写 else 的业务逻辑代码;
说明: 如果非得使用 if()...else if()...else...方式表达逻辑,【强制】 避免后续代码维
护困难, 请勿超过 3 层。
正例: 超过 3 层的 if-else 的逻辑判断代码可以使用卫语句、策略模式、状态模式等来实现,
其中卫语句示例如下:
public void today() {
		if (isBusy()) {
			System.out.println("change time.");
			return;
		}
		if (isFree()) {
			System.out.println("go to travel.");
			return;
		}
		System.out.println("stay at home to learn Alibaba Java Coding Guidelines.");
		return;
	}

解析

多余三个表达式会导致业务理解维护困难

下一个

5. 【推荐】除常用方法(如 getXxx/isXxx)等外,不要在条件判断中执行其它复杂的语句,将
复杂逻辑判断的结果赋值给一个有意义的布尔变量名,以提高可读性。
说明: 很多 if 语句内的逻辑相当复杂,阅读者需要分析条件表达式的最终结果,才能明确什么
样的条件执行什么样的语句,那么,如果阅读者分析逻辑表达式错误呢?
正例:
// 伪代码如下
final boolean existed = (file.open(fileName, "w") != null) && (...) || (...);
if (existed) {
...
}
反例:
if ((file.open(fileName, "w") != null) && (...) || (...)) {
...
}

解析

多于两个条件,我觉的即可使用
6. 【推荐】循环体中的语句要考量性能,以下操作尽量移至循环体外处理,如定义对象、变量、
获取数据库连接,进行不必要的 try-catch 操作(这个 try-catch 是否可以移至循环体外)。

解析:
trycatch 会增加字节码的运行量,减弱性能。

下一个

7. 【推荐】避免采用取反逻辑运算符。
说明: 取反逻辑不利于快速理解,并且取反逻辑写法必然存在对应的正向逻辑写法。
正例: 使用 if (x < 628) 来表达 x 小于 628。
反例: 使用 if (!(x >= 628)) 来表达 x 小于 628。

解析:不用了

下一个

8. 【推荐】接口入参保护,这种场景常见的是用作批量操作的接口。
9. 【参考】 下列情形,需要进行参数校验:
1) 调用频次低的方法。
2) 执行时间开销很大的方法。 此情形中, 参数校验时间几乎可以忽略不计,但如果因为参
数错误导致中间执行回退,或者错误,那得不偿失。
3) 需要极高稳定性和可用性的方法。
4) 对外提供的开放接口,不管是 RPC/API/HTTP 接口。
5) 敏感权限入口。
10.【参考】 下列情形, 不需要进行参数校验:
1) 极有可能被循环调用的方法。但在方法说明里必须注明外部参数检查要求。
2) 底层调用频度比较高的方法。毕竟是像纯净水过滤的最后一道,参数错误不太可能到底
层才会暴露问题。一般 DAO 层与 Service 层都在同一个应用中,部署在同一台服务器中,所
以 DAO 的参数校验,可以省略。
3) 被声明成 private 只会被自己代码所调用的方法,如果能够确定调用方法的代码传入参
数已经做过检查或者肯定不会有问题,此时可以不校验参数。

解析

controller层做代码校验,service和dao层不需要,除非执行开销比较打
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值