Java高并发编程实战,原子性、可见性、有序性,傻傻分不清

本文深入探讨Java并发编程中的关键概念:原子性、可见性和有序性。通过实例分析,揭示了多线程环境下可能出现的问题,并提出了解决方案,包括使用synchronized、volatile关键字以及Java内存模型中的原则。
摘要由CSDN通过智能技术生成

目录

一、原子性

二、可见性

1、串行

2、单核CPU

3、多线程多CPU时的可见性问题

4、看下面一段代码,猜猜看删除结果

三、有序性

四、解决方案

一、原子性

原子性指操作在CPU执行的过程中,不可中断,也不可在中途切换,要么执行完成、要么不执行。

简单地分析一下原子性问题,写一段大众代码,如下:

package com.nezha.thread;

/**

*/

public class ThreadAtomicityTest {

private int step;

public int getStep(){

return step;

}

public void increaseStep(){

step++;

};

}

看不出什么问题,都这么写啊。

使用JDK自带的javap查看一下程序的指令码:

D:\MyProject\target\classes\com\nezha\thread>javap -c ThreadAtomicityTest.class

Compiled from "ThreadAtomicityTest.java"

public class com.nezha.thread.ThreadAtomicityTest {

public com.nezha.thread.ThreadAtomicityTest();

Code:

0: aload_0

1: invokespecial #1 // Method java/lang/Object."<init>":()V

4: return

public int getStep();

Code:

0: aload_0

1: getfield #2 // Field step:I

4: ireturn

public void increaseStep();

Code:

0: aload_0

1: dup

2: getfield #2 // Field step:I

5: iconst_1

6: iadd

7: putfield #2 // Field step:I

10: return

}

重点看一下increaseStep的指

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值