石家庄外贸网站建设外贸建站主机空间哪家好
2026/1/26 7:52:05 网站建设 项目流程
石家庄外贸网站建设,外贸建站主机空间哪家好,win怎么使用wordpress,搜索引擎排名优化方案原子操作#xff1a;并发编程的基石 原子操作是并发编程中最核心的概念之一#xff0c;理解它对于编写正确、高效的多线程程序至关重要。 #x1f52c; 原子操作的定义 原子操作#xff08;Atomic Operation#xff09;指的是不可被中断的一个或一系列操作#xff0c;这些…原子操作并发编程的基石原子操作是并发编程中最核心的概念之一理解它对于编写正确、高效的多线程程序至关重要。 原子操作的定义原子操作Atomic Operation指的是不可被中断的一个或一系列操作这些操作要么全部执行成功要么全部不执行不存在中间状态。原子操作在多线程环境下是线程安全的因为其他线程无法看到原子操作的中间状态。关键特征不可分割Indivisible操作作为一个整体执行不可中断Non-interruptible执行过程中不会被线程调度打断一致性视图Consistent View其他线程看到的是操作前或操作后的状态不会看到中间状态 直观理解想象一个银行转账操作// ❌ 非原子操作分两步执行可能被中断account.balanceaccount.balance-100;// 步骤1扣款recipient.balancerecipient.balance100;// 步骤2存款// 如果在步骤1和步骤2之间发生线程切换// 线程A执行步骤1扣款成功// [线程切换发生]// 线程B读取account.balance看到扣款后的余额但收款方还没收到钱// 线程B执行其他操作...数据不一致// ✅ 原子操作要么全成功要么全失败atomicTransfer(account,recipient,100);️ 硬件层面的原子操作1.CPU指令级的原子操作现代CPU提供了一些原子指令; x86架构的原子指令示例 LOCK XADD ; 原子加 LOCK CMPXCHG ; 比较并交换CAS LOCK INC ; 原子自增 LOCK DEC ; 原子自减 ; 这些指令前缀LOCK会锁定内存总线确保操作原子性2.CASCompare and Swap原理CAS是大多数原子操作的基础// CAS操作的伪代码publicclassCAS{// 内存位置V期望值A新值BbooleancompareAndSwap(int*V,intA,intB){if(*VA){// 如果内存值等于期望值*VB;// 更新为新值returntrue;// 成功}returnfalse;// 失败}}// 实际使用volatileintvalue0;// 原子地更新value如果当前是0则改为1while(true){intcurrentvalue;intnextcurrent1;if(compareAndSwap(value,current,next)){break;// 更新成功}// 更新失败被其他线程修改重试}3.内存屏障Memory Barrier确保指令执行顺序和内存可见性// Java中的内存屏障publicclassMemoryBarrierExample{privatevolatileintflag0;privateintdata0;publicvoidwrite(){data42;// 普通写// StoreStore屏障volatile写之前flag1;// volatile写包含内存屏障// StoreLoad屏障volatile写之后}publicvoidread(){if(flag1){// volatile读包含内存屏障// LoadLoad屏障volatile读之后// LoadStore屏障volatile读之后System.out.println(data);// 保证看到data42}}} 原子操作的类型1.基本原子操作importjava.util.concurrent.atomic.*;// 1. 原子整型AtomicIntegeratomicIntnewAtomicInteger(0);atomicInt.incrementAndGet();// i 原子版本atomicInt.getAndAdd(5);// 先获取再加atomicInt.compareAndSet(0,1);// CAS操作// 2. 原子长整型AtomicLongatomicLongnewAtomicLong(0L);// 3. 原子布尔型AtomicBooleanatomicBoolnewAtomicBoolean(false);// 4. 原子引用AtomicReferenceStringatomicRefnewAtomicReference(initial);atomicRef.compareAndSet(initial,updated);// 5. 原子数组AtomicIntegerArrayatomicArraynewAtomicIntegerArray(10);atomicArray.getAndAdd(0,5);// 原子更新数组元素2.复合原子操作// 原子更新器publicclassBankAccount{privatevolatileintbalance;// 自定义原子操作安全转账publicbooleantransfer(BankAccountto,intamount){while(true){intfromBalancethis.balance;if(fromBalanceamount){returnfalse;// 余额不足}inttoBalanceto.balance;// CAS更新同时修改两个账户if(AtomicInteger.compareAndSet(this.balance,fromBalance,fromBalance-amount)AtomicInteger.compareAndSet(to.balance,toBalance,toBalanceamount)){returntrue;// 转账成功}// 失败重试}}}// 原子字段更新器无需volatile性能更好classCounter{privateintcount;privatestaticfinalAtomicIntegerFieldUpdaterCounterupdaterAtomicIntegerFieldUpdater.newUpdater(Counter.class,count);publicvoidincrement(){updater.incrementAndGet(this);}}⚡ Java中的原子操作实现1.Unsafe类 - 底层原子操作// Unsafe是Java中执行原子操作的底层类publicclassUnsafeExample{privatestaticfinalUnsafeUNSAFEgetUnsafe();privatestaticfinallongVALUE_OFFSET;privatevolatileintvalue;static{try{// 获取字段偏移量VALUE_OFFSETUNSAFE.objectFieldOffset(UnsafeExample.class.getDeclaredField(value));}catch(Exceptione){thrownewError(e);}}// 使用Unsafe实现原子操作publicbooleancompareAndSet(intexpect,intupdate){returnUNSAFE.compareAndSwapInt(this,VALUE_OFFSET,expect,update);}publicintgetAndIncrement(){while(true){intcurrentvalue;intnextcurrent1;if(compareAndSet(current,next)){returncurrent;}}}privatestaticUnsafegetUnsafe(){// 反射获取Unsafe实例实际使用中不推荐// ...}}2.Atomic类的实现原理// AtomicInteger源码分析publicclassAtomicIntegerextendsNumberimplementsjava.io.Serializable{privatestaticfinallongserialVersionUID6214790243416807050L;// 1. 使用Unsafe进行原子操作privatestaticfinalUnsafeUNSAFEUnsafe.getUnsafe();privatestaticfinallongvalueOffset;static{try{// 获取value字段的内存偏移量valueOffsetUNSAFE.objectFieldOffset(AtomicInteger.class.getDeclaredField(value));}catch(Exceptionex){thrownewError(ex);}}// 2. volatile保证可见性privatevolatileintvalue;// 3. CAS实现publicfinalbooleancompareAndSet(intexpect,intupdate){returnUNSAFE.compareAndSwapInt(this,valueOffset,expect,update);}// 4. 自增的原子实现publicfinalintincrementAndGet(){returnUNSAFE.getAndAddInt(this,valueOffset,1)1;}// 5. 乐观锁循环publicfinalintgetAndAdd(intdelta){returnUNSAFE.getAndAddInt(this,valueOffset,delta);}}3.LongAdder - 高并发优化// LongAdder分段累加减少竞争publicclassLongAdderExample{privatefinalLongAdderaddernewLongAdder();publicvoidhighConcurrencyIncrement(){// 在高度竞争环境下性能优于AtomicLongadder.increment();// 内部原理多个Cell分散竞争// base cell[0] cell[1] ... cell[n]}publiclongsum(){returnadder.sum();// 返回总和}}// LongAdder vs AtomicLong性能对比// 线程数少时AtomicLong更快// 线程数多时LongAdder更快减少CAS竞争 原子操作 vs 锁性能对比// 测试代码对比不同实现的性能publicclassPerformanceTest{privateintcounter0;privatefinalAtomicIntegeratomicCounternewAtomicInteger(0);privatefinalReentrantLocklocknewReentrantLock();// 1. 非线程安全最快的但可能出错publicvoidunsafeIncrement(){counter;}// 2. synchronized锁较慢publicsynchronizedvoidsynchronizedIncrement(){counter;}// 3. ReentrantLock比synchronized稍快publicvoidlockIncrement(){lock.lock();try{counter;}finally{lock.unlock();}}// 4. 原子操作最快且线程安全publicvoidatomicIncrement(){atomicCounter.incrementAndGet();}// 5. LongAdder高并发时最快privatefinalLongAdderlongAddernewLongAdder();publicvoidlongAdderIncrement(){longAdder.increment();}}性能测试结果假设线程数: 1 synchronized: 100 ns/op ReentrantLock: 90 ns/op AtomicInteger: 15 ns/op LongAdder: 20 ns/op 线程数: 10 synchronized: 500 ns/op ReentrantLock: 450 ns/

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询