线程安全:
指多个线程在执行同一段代码的时候采用加锁机制,使每次的执行结果和单线程执行的结果都是一样的,不存在执行程序时出现意外结果。
线程不安全:
指不提供加锁机制保护,有可能出现多个线程先后更改数据造成所得到的数据是脏数据。
引起线程安全问题的原因:
1、线程安全问题都是由全局变量及静态变量引起的 若每个线程中对全局变量、静态变量只有读操作,而无写操作,一般来说,这个全局变量是线程安全的;若有多个线程同时执行写操作,一般都需要考虑线程同步,否则的话就可能影响线程安全。
2、解决多线程并发访问资源安全问题的方法 (1)synchronized synchronized关键字,就是用来控制线程同步的,保证我们的线程在多线程环境下,不被多个线程同时执行,确保我们数据的完整性,使用方法一般是加在方法上。 (2)Lock Lock是在Java1.6被引入进来的,Lock的引入让锁有了可操作性,是指我们在需要的时候去手动的获取锁和释放锁,甚至我们还可以中断获取以及超时获取的同步特性,从使用上synchronized使用起来比Lock更方便。
线程并发容器:
线程并发容器是一种用于在多线程环境下安全地共享和操作数据的数据结构。它提供了线程安全的访问和操作接口,以确保多线程之间的数据一致性和线程安全性。
常见的线程并发容器包括:
-
ConcurrentHashMap:它是一个线程安全的哈希表,支持高并发读写操作。它通过将整个数据集分成多个段(Segment)来实现并发控制,不同的线程可以独立地访问不同的段,从而减少了锁的竞争。
-
CopyOnWriteArrayList:它是一个线程安全的动态数组,采用写时复制的策略。在进行写操作(如添加、修改或删除元素)时,会先将原始数据复制一份,然后在复制的数据上进行操作,确保读操作不会受到写操作的影响。
-
ConcurrentLinkedQueue:它是一个无界非阻塞并发队列,支持高并发的入队和出队操作。它的内部采用了无锁的CAS(Compare and Swap)操作来实现并发控制。
-
BlockingQueue:它是一个阻塞队列,提供线程安全的入队和出队操作,并支持在队列为空或满时进行阻塞等待。常见的实现类包括ArrayBlockingQueue、LinkedBlockingQueue等。
-
ConcurrentSkipListMap:它是一个线程安全的有序映射表,内部采用跳表的数据结构来实现。它支持高并发的插入、删除和查询操作,同时保持元素有序。
这些线程并发容器提供了不同的特性和适用场景,可以根据具体需求选择合适的容器来实现线程安全的并发操作。