多线程--JUC-安全

简介: 多线程--JUC-安全

@[toc]

从底层原理来进行分类

互斥同步

 **使用各种互斥锁
                 Synchronized
                 ReentrantLock
                 Readwritelock**

**使用同步工具
Collections.synchronized(new ArrayList)等
Vector deng**

非互斥同步

原子类

atomic包 原子类

基本类型
AtomicInteger 整形,
AtomicLong 长整型
AtiomicBoolean 布尔

Array数组
AtomicIntergerArray 整形数组
AtomicLongArray 长整形数组
AtomicRefernceArray 引入数组

引用类型原子类
AtomicReference :引用类型
AtomicStampedReference 引用类型 带时间戳,可以解决ABA问题
升级原子类
后面文章会讲到

Adder加法器
LongAdder
DoubleAdder
Accumulator累加器
LongAccumulator
DoubleAccumulator

结合互斥和非互斥同步

并发容器
ConcurrentHashMap
并发队列

无同步方案不可变

final 关键字
ThreadLocal

1.线程安全问题

什么是线程安全问题:当多个线程同时访问一个全局变量,注意(做写的操作的时候可能会受到别的线程的干扰),做读的操作的时候不会发生线程安全问题

如 ++ , -- 修改等操作 抢火车票的操作,就会引发线程安全问题

在这里插入图片描述

模拟场景:

package com.yxl.demo.ThreadTest;

public class test5 {

    public static void main(String[] args) {

        TestDemo thread = new TestDemo();
        Thread t1 = new Thread(thread,"窗口一");
        Thread t2 = new Thread(thread,"窗口二");
        t1.start();
        t2.start();
    }
}

class TestDemo implements Runnable{
    //共享的火车票变量
    private  int count = 100;

    //重寫run方法
    @Override
    public void run() {
        while (count > 0){
            try {
                //休眠一下 方便出现并发问题
                Thread.sleep(50);
            }catch (Exception e){
                e.getMessage();
            }
            sale();
        }
    }
    //卖票
    public void sale(){
        if(count > 0){
            System.out.println(Thread.currentThread().getName() +"出售 :" +(100 -  count + 1));
            count--;
        }
    }
}

运行结果如下:会发现出现卖重复票的问题

在这里插入图片描述

解决这个线程安全问题

内置锁(Synchronized)

  • 保证线程原子性,当先车管进入方法自动的获取锁,当某一个线程获取到锁后,其他线程就会等待,
  • 锁的特性:只有一个线程进行使用。
  • 放程序执行完毕之久,就会把锁释放,但是锁会降低程序的运行效率,

Synchronized 也是 重入锁,内置锁也是互斥锁

使用 Synchronized 有两种方式, 同步方法(使用的是this锁),同步代码块

synchronized 修饰方法使用锁是当前this锁。

synchronized 修饰静态方法使用锁是当前类的字节码文件

显示锁 (lock锁)

解决方案 :

1.同步方法

在这里插入图片描述

2. 同步代码块

在这里插入图片描述

使用同步代码块的时候 注意(锁一定要使用同一个锁 )

问:如何解决多线程之间线程安全问题

*答:使用多线程之间同步synchronized或使用锁(lock)。*

问:为什么使用线程同步或使用锁能解决线程安全问题呢?

*答:将可能会发生数据冲突问题(线程不安全问题),只能让当前一个线程进行执行。代码执行完成后释放锁,让后才能让其他线程进行执行。这样的话就可以解决线程不安全问题。*

问:什么是多线程之间同步

*答:当多个线程共享同一个资源,不会受到其他线程的干扰。*

相关文章
|
25天前
|
缓存 安全 Java
【JavaEE】——单例模式引起的多线程安全问题:“饿汉/懒汉”模式,及解决思路和方法(面试高频)
单例模式下,“饿汉模式”,“懒汉模式”,单例模式下引起的线程安全问题,解锁思路和解决方法
|
25天前
|
Java 调度
【JavaEE】——线程的安全问题和解决方式
【JavaEE】——线程的安全问题和解决方式。为什么多线程运行会有安全问题,解决线程安全问题的思路,synchronized关键字的运用,加锁机制,“锁竞争”,几个变式
|
7月前
|
安全 Java
java线程之List集合并发安全问题及解决方案
java线程之List集合并发安全问题及解决方案
1099 1
|
4月前
|
存储 缓存 安全
【Java面试题汇总】多线程、JUC、锁篇(2023版)
线程和进程的区别、CAS的ABA问题、AQS、哪些地方使用了CAS、怎么保证线程安全、线程同步方式、synchronized的用法及原理、Lock、volatile、线程的六个状态、ThreadLocal、线程通信方式、创建方式、两种创建线程池的方法、线程池设置合适的线程数、线程安全的集合?ConcurrentHashMap、JUC
|
3月前
|
Java C++
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
45 0
|
4月前
|
监控 Java 调度
【Java学习】多线程&JUC万字超详解
本文详细介绍了多线程的概念和三种实现方式,还有一些常见的成员方法,CPU的调动方式,多线程的生命周期,还有线程安全问题,锁和死锁的概念,以及等待唤醒机制,阻塞队列,多线程的六种状态,线程池等
286 6
|
5月前
|
算法 Java
JUC(1)线程和进程、并发和并行、线程的状态、lock锁、生产者和消费者问题
该博客文章综合介绍了Java并发编程的基础知识,包括线程与进程的区别、并发与并行的概念、线程的生命周期状态、`sleep`与`wait`方法的差异、`Lock`接口及其实现类与`synchronized`关键字的对比,以及生产者和消费者问题的解决方案和使用`Condition`对象替代`synchronized`关键字的方法。
JUC(1)线程和进程、并发和并行、线程的状态、lock锁、生产者和消费者问题
|
5月前
|
设计模式 Java 调度
JUC线程池: ScheduledThreadPoolExecutor详解
`ScheduledThreadPoolExecutor`是Java标准库提供的一个强大的定时任务调度工具,它让并发编程中的任务调度变得简单而可靠。这个类的设计兼顾了灵活性与功能性,使其成为实现复杂定时任务逻辑的理想选择。不过,使用时仍需留意任务的执行时间以及系统的实际响应能力,以避免潜在的调度问题影响应用程序的行为。
105 1
|
5月前
|
Java
【Java集合类面试十二】、HashMap为什么线程不安全?
HashMap在并发环境下执行put操作可能导致循环链表的形成,进而引起死循环,因而它是线程不安全的。
|
5月前
|
安全 算法 Java
【Java集合类面试二】、 Java中的容器,线程安全和线程不安全的分别有哪些?
这篇文章讨论了Java集合类的线程安全性,列举了线程不安全的集合类(如HashSet、ArrayList、HashMap)和线程安全的集合类(如Vector、Hashtable),同时介绍了Java 5之后提供的java.util.concurrent包中的高效并发集合类,如ConcurrentHashMap和CopyOnWriteArrayList。
【Java集合类面试二】、 Java中的容器,线程安全和线程不安全的分别有哪些?