1.看图自己体会
2.体会不了就给你个小程序
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | package cs.util; public class VolatileDemo { private volatile int count = 0 ; public int getCount() { return this .count; } public void setCount() { try { Thread.sleep( 100 ); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } this .count++; } public static void main(String[] args) { // TODO Auto-generated method stub VolatileDemo demo= new VolatileDemo(); for ( int i = 0 ; i < 1000 ; i++) { new Thread( new Runnable() { @Override public void run() { // TODO Auto-generated method stub demo.setCount(); } }).start(); } while (Thread.activeCount()> 1 ) { Thread.yield(); } System.out.println(demo.getCount()); } } |
输出的结果是
不等于1000其实也不怪,这是由于count++其实是有三个操作组成 1.从主存拿共享变量count 2.进行count++ 3.把count写进 内存
本该为7的,最后却为6,少了1,道理知道了吧
3.怎么解决没有出现1000的情况呢 很简单 有几种做法
一.可以加入 synchronized
1 2 3 4 5 6 7 8 9 10 11 12 13 | public void setCount() { try { Thread.sleep( 100 ); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); }<br> //对count进行原子性操作 synchronized ( this ) { this .count++; } } |
二、使用jdk1.5推出的方法 具体修改如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | //定义一个Lock private Lock lock=new ReentrantLock(); private volatile int count = 0 ; public int getCount() { return this .count; } public void setCount() { try { Thread.sleep( 100 ); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } //加锁 lock.lock(); try { this .count++; } finally { //解锁 lock.unlock(); } } |
输出结果就都为
赶紧试一试吧
最后总结一下
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现