在JAVA语言里,面向对象思想能够让并发编程变得更简单。
可以从封装共享变量,识别共享变量间的约束条件和执行并发访问策略这三个方面下手。
封装共享变量
将共享变量作为对象属性封装在内部,对所有公共方法指定并发访问策略。
对于不用发生变化的共享变量(如银行卡号,身份证号),建议使用final关键字修饰。
public class Counter { private long value; synchronized long get(){ return value; } synchronized long addOne(){ return ++value; } }
识别共享变量间的约束条件
/** * AtomicLong 是线程安全的 */ public class SafeWM { // 库存上限 private final AtomicLong upper = new AtomicLong(0); // 库存下限 private final AtomicLong lower = new AtomicLong(0); // 设置库存上限 void setUpper(long v){ //检查参数合法性 if(v < lower.get()){ throw new IllegalArgumentException(); } upper.set(v); } // 设置库存下限 void setLower(long v){ //检查参数合法性 if(v > upper.get()){ throw new IllegalArgumentException(); } lower.set(v); } // 省略其他业务代码 }
制定并发访问策略
写出健壮的并发程序的原则