java两个线程对变量进行加1操作实例分析
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇内容主要讲解"java两个线程对变量进行加1操作实例分析",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"java两个线程对变量进行加1操作实例分析"吧!
千家信息网最后更新 2025年12月03日java两个线程对变量进行加1操作实例分析
本篇内容主要讲解"java两个线程对变量进行加1操作实例分析",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"java两个线程对变量进行加1操作实例分析"吧!
1--错误的常规写法
public static int i=0;public static void add(){i=i+1;action();}public static void action(){System.out.println("==>"+Thread.currentThread().getName()+":"+i);}public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread(SysUserServiceImpl::add,"t1");Thread t2= new Thread(SysUserServiceImpl::add,"t2");t1.start();t2.start();}运行结果==>==>t1:1==>t2:2==>t1:2==>t2:1==>t1:2==>t2:2
每次运行结果不一致,多线程环境下,t1对共享内存中的i进行+1操作,但未将值刷新到主内存,此时恰好t2也对i取到还是0进行+1操作,使得最后结果i都为1,同理t1处理完为1,t2处理完为2。多次运行结果都不一致。
改进方法1 --同步锁
public class ThreadException {public static volatile int i=0;public static void add(){synchronized (ThreadException.class){i=i+1;action();}}public static void action(){System.out.println("==>"+Thread.currentThread().getName()+":"+i);}public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread(ThreadException::add,"t1");Thread t2= new Thread(ThreadException::add,"t2");t1.start();t2.start();}}
优点:实现简单
缺点:加锁粒度大,性能低下,分布式环境,多JVM条件,synchronized失效,synchronized 只是本地锁,锁的也只是当前jvm下的对象,在分布式场景下,要用分布式锁
改进方法2 AtomicInteger
public class ThreadException { private static AtomicInteger num = new AtomicInteger(0); public static void add(){ int i = num.getAndIncrement(); action(i); } public static void action(int i){ System.out.println("由"+i+"==>"+Thread.currentThread().getName()+":"+num); } public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread(ThreadException::add,"t1"); Thread t2= new Thread(ThreadException::add,"t2"); t1.start(); t2.start(); }}改进方法3 lock
public class ThreadException {public static volatile int i=0;public static void action(){System.out.println("==>"+Thread.currentThread().getName()+":"+i);}static Lock lock=new ReentrantLock();public static void inc() {lock.lock();try {Thread.sleep(1);i=i+1;action();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}}public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread(ThreadException::inc,"t1");Thread t2= new Thread(ThreadException::inc,"t2");t1.start();t2.start();}}
分布式锁:保证多个节点同步执行
实现方案:1。基于数据库,2.基于redis缓存,3.基于zookeeper
到此,相信大家对"java两个线程对变量进行加1操作实例分析"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
线程
分布式
方法
结果
两个
变量
实例
实例分析
分析
运行
一致
内存
内容
只是
环境
同步
处理
学习
低下
实用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
上海控制器软件开发供应商
互联网科技行业赞助
广西ukey开票软件服务器地址
网络安全得奖感受
数据库 qq好友库
远程服务器登录时间
内存 服务器 台式机
传世数据库管理工具免费版
浙江信息化软件开发活动方案
网络安全 黑白名单
数据库基础的概述的相关论文
浙江软件开发费用是多少
深圳软件开发定制需要多少钱
mesh 数据库
几个人软件开发小组成员
网络安全意义重大
上海同能网络技术
杭州星船互联网科技
创新软件开发市场报价
开展了网络安全岗位培训
开源重量数据库
数钥网络技术合同上征信吗
服务器管理系统建议
期间网络安全保障方案
杭州制造软件开发亿连信
狐表软件开发财务软件
济南有实力的存储服务器店面
丽水市正阳网络技术有限公司
南昌服务器ups电源
rpg服务器