【Java实战】工作中并发处理规范

45 篇文章 2 订阅 ¥59.90 ¥99.00

目录

一、前言

二、并发处理规范

1.【强制】获取单例对象需要保证线程安全,其中的方法也要保证线程安全。

2.【强制】创建线程或线程池时请指定有意义的线程名称,方便出错时回溯。

3.【强制】线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。

4.【强制】线程池使用ThreadPoolExecutor去创建

5.【强制】SimpleDateFormat 是线程不安全的类

6.【强制】必须回收自定义的 ThreadLocal 变量记录的当前线程的值

7.【强制】高并发时,同步调用应该去考量锁的性能损耗。

8.【强制】对多个资源、数据库表、对象同时加锁时,需要保持一致的加锁顺序,否则可能会造成死锁。

9.【强制】使用阻塞等待获取锁的方式中注意事项

10.【强制】在使用尝试机制来获取锁的方式中

11.【强制】并发修改同一记录时,避免更新丢失,需要加锁。

12.【强制】多线程并行处理定时任务时

13.【推荐】资金相关的金融敏感信息,使用悲观锁策略。

14.【推荐】使用 CountDownLatch 进行异步转同步操作

15.【推荐】避免 Random 实例被多线程使用

16.【推荐】将目标属性声明为 volatile 型

17.【参考】volatile面对多写场景,同样无法解决线程安全问题。

18.【参考】HashMap 在容量不够进行 resize 

19.【参考】ThreadLocal 对象使用 static 修饰,ThreadLocal 无法解决共享对象的更新问题。


一、前言

现代软件行业的高速发展对开发者的综合素质要求越来越高,因为不仅是编程知识点,其它维度的知识点也会影响到软件的最终交付质量。比如:五花八门的错误码会人为地增加排查问题的难度;数据库的表结构和索引设计缺陷带来的系统架构缺陷性能风险;工程结构混乱导致后续项目维护艰难;没有鉴权的漏洞代码容易被黑客攻击等。依据约束力强弱及故障敏感性,规约依次分为【强制】【推荐】【参考】三大类。在延伸的信息中,“说明”对规约做了适当扩展和解释;“

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡布奇诺-海晨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值