线程相关整理

本文介绍了Java中常用的线程同步机制,如synchronized、ReentrantLock、volatile、CAS以及ThreadLocal,同时讨论了实际编程中遇到的问题,如notify的使用规则、线程安全集合和死锁。作者还提到如何监控线程异常和确定线程重要性以优化应用性能。
摘要由CSDN通过智能技术生成

一 常用的线程手段


1 synchronized 有方法,和方法块,新的java版本 内部实现已经包含了多种方案,并动态调整方案,因此不是特别需求的化,建议直接用此方式
2 reentrantlock 可以构造公平锁
以上两种 代码片段应该是没得选择。
3 volatile 可见性 和 有序性--简单的读取与赋值操作是原子性的,如果只是简单读写一个共享变量,可以用volatile保证可见性和有序性就可以了
4 cas 保证原子性:AtomicBoolean,AtomicInteger,AtomicReference
  简单的读取与赋值操作是原子性的,将一个变量赋给另外一个变量的操作不是原子性的,因此AtomicReference可以保证引用的赋值的原子性
5 threadlocal 就是空间换时间。  
懂当然都懂,每次看每次都懂,
实际使用的时候,还是各种问题,应该及时总结下来,忘完了

二 实际问题记录
 

1 notify的时候,自己的代码块要先执行完,无论notify后有多少代码都要先只需完,新的拿到锁的线程才能执行
2 同步锁对象,不要变动,不然会出问题
3 之前通过一个变量值来控制线程的退出
  但该变量值改动后,有时候却没有退出(要保证可见性)
4 集合罗列:
ArrayList线程不安全,Vector线程部分安全CopyOnWriteArrayList 线程安全
HashMap线程不安全,ConcurrentHashMap和ConcurrentSkipListMap.线程安全(hashtable不再用)
stringBuilder线程不安全,StringBuffer线程安全
5 线程死锁:线程a 同步访问了线程b的代码,而线程b的代码也直接或间接的同步访问了这个共享资源,且锁不是同一把,就会死锁
 

三 后续持续加入中

1 可以通过设置默认的线程异常处理类来监控多线程下的线程崩溃问题:Thread.getDefaultUncaughtExceptionHandler();(try catch只能抓当前线程的崩溃)

这里我这边主要是用来

1 判断线程是否重要,不重要我就忽略,重要的化我才退出app

2 收集崩溃信息,方便log查看。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值