20240428-并发编程特性-原子性(一)

20240428-并发编程特性-原子性

1.原子性

1.1 JMM概述

不同的硬件和不同的操作系统在内存操作上有一定差异,java为了解决相同代码在不同操作系统上出现的各种问题,用JMM(java memory model)java内存模型,
屏蔽了各种硬件和操作系统带来的差异,让java可以跨平台

1.2 JMM特性

JMM规定,所有变量都会存储在主内存中,在操作的时候,需要从主内存复制一份到线程内存,在线程内部做计算,然后写回主内存中(不一定会及时操作)

1.3 原子性的定义

  • 原子性是指一个操作是不可分割且不可中断的,一个线程在执行时,不受另外一个线程的影响
// 这个操作是不可分割的,是原子操作
int i = 0;

// 这个操作不是原子操作,要现查询i的值,再把i赋值给j
int j = i;

// 这个操作也不是原子操作,要先查询i的值,然后给i的值加1,然后再赋值给i
i++;
  • 测试代码
package com.ysf;

public class Tst01Atomic {

    private static int count = 0;

    public static void increment(){
        count ++;
        try {
            Thread.sleep(10L);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) throws InterruptedException {
        Thread t1 = new Thread(()->{
            for (int i = 0;i<100;i++){
                increment();
            }
        },"plus-1");
        Thread t2 = new Thread(()->{
            for (int i = 0;i<100;i++){
                increment();
            }
        },"plus-2");
        t1.start();
        t2.start();
        t1.join();
        t2.join();
        System.out.println(count);
    }
}
  • 从运行结果可以看出,与预期的200不符,因为++操作不是原子操作
  • 如何保证原子性呢?
    • 使用单线程
    • 不操作临界资源
    • 使用synchronized锁
    • 使用CAS锁
    • 使用lock锁
    • 使用ThreadLocal

1.4 对于++操作,看下CPU到底干了啥

cd \study-juc\day-0428\src\main\java\com\ysf
javac Tst01Atomic
javap -v Tst01Atomic.class
 public static void increment();
    descriptor: ()V
    flags: ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=0
         0: getstatic     #2                  //从主内存取值
         3: iconst_1
         4: iadd                              //++
         5: putstatic     #2                  //往主内存放值
         8: ldc2_w        #3
        11: invokestatic  #5
        14: goto          22
  • 多线程情况下,该代码可能存在的过程
    • 线程1、线程2同时取值为1
    • 线程1、线程2同时计算为2
    • 线程1、线程2同时放值
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《Java并发编程实战》是一本经典的Java并发编程指南,它深入解析了Java中线程、锁、并发集合、并发工具等关键概念和技术,并提供了各种实用的实战技巧和例子。 该书包含以下主要章节:引言、线程安全、对象的共享、对象的构造与发布、基础构建模块、任务执行、取消与关闭、线程池、同步器、构建自定义的同步工具、能与可伸缩、显式锁、构建锁的高级特性原子变量与非阻塞同步、隐式的线程局部变量、构建自定义的同步器、构建一个框架。 这本书的特点是理论结合实践,通过大量的实例和案例演示了各种并发编程问题的解决方案,以及如何正确地使用Java提供的并发工具和类库。在阅读过程中,读者可以逐步了解并掌握线程安全、锁、线程池等核心概念,从而能够更好地应对多线程编程中的各种挑战。 该书的目标读者主要面向有一定Java编程基础的开发人员和架构师,但也适合初学者通过系统学习并发编程知识。无论是学习Java并发编程的基础知识,还是深入研究Java并发编程的高级特性和技术,这本书都是不可或缺的参考书籍之一。 总之,通过阅读《Java并发编程实战》,读者可以系统地学习和掌握Java并发编程的基础和高级知识,提升自己在多线程编程方面的能力,从而编写出更高效、更可靠、更安全的并发程序。 ### 回答2: 《Java并发编程实战》是一本非常经典的Java并发编程书籍,由Brian Goetz等人合著。这本书以清晰易懂的方式介绍了Java并发编程的概念、原理和实践技巧,对于Java开发者来说,是学习和掌握多线程编程不可或缺的参考资料。 这本书的目录包括: 第1章:介绍并发编程 第2章:线程安全 第3章:对象的共享 第4章:对象的组合 第5章:构建并发程序 第6章:任务执行 第7章:取消和关闭 第8章:线程池 第9章:构建自定义的同步工具类 第10章:避免活跃危险 第11章:能与可伸缩 第12章:并发程序的测试 第13章:隐式使用锁 第14章:构建高并发程序 这本书通过实例、案例和代码来解释并发编程的概念和技巧。它涵盖了从基本概念到高级主题的内容,包括线程安全、锁、对象共享、线程池、自定义同步工具类等。通过学习这本书,读者可以了解多线程编程的核心概念,学会如何避免并发问题,提高程序的能和可伸缩。 《Java并发编程实战》不仅适用于Java初学者,也适合有一定经验的开发人员。它提供了一系列实用的技巧和建议,帮助开发人员编写高质量、高效率的并发程序。无论是想学习并发编程的基本原理,还是深入研究Java并发库中的高级特性,这本书都是一个不可多得的学习资源。 ### 回答3: 《Java并发编程实战》是由美国计算机科学家Brian Goetz等人合著的一本经典的Java并发编程指南。本书全面介绍了Java并发编程的基本概念、原则、机制和设计模式,是学习和理解Java并发编程不可或缺的重要参考书。 本书的目录包括以下主要部分: 第1部分:基础知识 1. 引论:介绍了并发编程的基本概念、挑战和解决方案。 第2部分:结构化并发应用程序 2. 线程安全:详细介绍了线程安全的概念、实现原理和验证方法。 3. 对象的共享:讲述了在多线程环境下如何安全地共享对象。 4. 对象的组合:介绍了如何使用复合对象来提高并发应用程序的能和可扩展。 第3部分:构建并发应用程序 5. 基础构建模块:详细介绍了Java并发编程的基本构建模块,包括线程池、任务和执行者框架。 6. 任务执行:讲述了如何利用任务和执行者框架来实现并发任务的执行。 7. 取消与关闭:介绍了如何取消和关闭并发任务以及处理取消操作的相关问题。 8. 线程池的扩展:讲述了如何扩展Java线程池以满足特定需求。 第4部分:活跃能和测试 9. 阻塞与响应:详细介绍了如何解决并发编程中的阻塞和响应问题。 10. 能与可伸缩:讲述了如何提高并发应用程序的能和可伸缩。 11. 显式锁:详细介绍了显式锁的使用和相关设计模式。 12. 构建自定义的同步工具:介绍了如何构建自定义的同步工具。 第5部分:构建更安全的并发应用程序 13. 基础模块:详细介绍了Java并发编程中的基础模块,包括原子变量、非阻塞同步机制等。 14. 高级主题:讲述了一些高级的并发编程主题,包括显式条件、原子类等。 15. 显式的通知:详细介绍了如何使用显式的通知机制来实现线程间的协作和通信。 《Java并发编程实战》通过系统、全面的内容和丰富的示例展示了如何正确地并发编程。无论是初学者还是有一定经验的开发人员,都可从中获得宝贵的知识和实战经验。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值