摘要:本文主要介紹下中的主要操作。所謂的內(nèi)存屏障,是之虛擬機在對于這樣的語句,在及后續(xù)寫入操作執(zhí)行前,保證的寫入操作對其它處理器可見。是會插入的內(nèi)存屏障,效率略低本篇為俺的課堂基礎(chǔ)手寫的前置知識,歡迎大家圍觀
Unsafe是Java無鎖操作的基石,在無鎖并發(fā)類中都少不了它們的身影,比如ConcurrentHashMap, ConcurrentLinkedQueue, 都是由Unsafe類來實現(xiàn)的。相對于與Java中的鎖,它基本無開銷,會原地等待。本文主要介紹下Unsafe中的主要操作。
1 compareAndSwap/** * 比較obj的offset處內(nèi)存位置中的值和期望的值,如果相同則更新。此更新是不可中斷的。 * * @param obj 需要更新的對象 * @param offset obj中整型field的偏移量 * @param expect 希望field中存在的值 * @param update 如果期望值expect與field的當前值相同,設(shè)置filed的值為這個新值 * @return 如果field的值被更改返回true */ public native boolean compareAndSwapInt(Object obj, long offset, int expect, int update);
這個就是著名的CAS操作了,分為三步來做
獲取obj對象中為offset的偏移值,這里假設(shè)為realVal
比較realVal和expect
如果相同,將該值更新為update,否則不更新
CAS家族還包括有,compareAndSwapObject(), compareAndSwapLong(), compareAndSwapInt()等等
用AtomicInteger中一個經(jīng)典的例子來說明:
public final int getAndAdd(int delta) { return unsafe.getAndAddInt(this, valueOffset, delta); } //unsafe.getAndAddInt public final int getAndAddInt(Object var1, long var2, int var4) { int var5; do { /**獲取原始值*/ var5 = this.getIntVolatile(var1, var2); /**確認原始值沒有被其它線程修改時,再執(zhí)行更新var5+var4操作,如果 被其它線程修改過了,則會原地等待,持續(xù)循環(huán)*/ } while(!this.compareAndSwapInt(var1, var2, var5, var5 + var4)); return var5; }
這里可以看出CAS操作存在的問題,在低競態(tài)情況下是ok的,但是在高競態(tài)情況下,while循環(huán)會一直消耗cpu資源
2 putOrder/*** * Sets the value of the integer field at the specified offset in the * supplied object to the given value. This is an ordered or lazy * version ofputIntVolatile(Object,long,int)
, which * doesn"t guarantee the immediate visibility of the change to other * threads. It is only really useful where the integer field is *volatile
, and is thus expected to change unexpectedly. * * @param obj the object containing the field to modify. * @param offset the offset of the integer field withinobj
. * @param value the new value of the field. * @see #putIntVolatile(Object,long,int) */ public native void putOrderedInt(Object obj, long offset, int value);
將obj對象的偏移量為offset的位置修改為value,因為Java中沒有內(nèi)存操作,而Unsafe的這個操作正好補充了內(nèi)存操作的不足。也可以用于數(shù)組操作,比如ConcurrentHashMap中就大量用到了該操作
Segments0 = new Segment (loadFactor, (int)(cap * loadFactor), (HashEntry [])new HashEntry[cap]); Segment [] ss = (Segment [])new Segment[ssize]; // 往數(shù)組下標為0的位置,寫入s0: ss[0]=s0 UNSAFE.putOrderedObject(ss, SBASE, s0); // ordered write of segments[0]
需要注意的是obj需要設(shè)置為Volatile,否則對于其它線程會不可見
該操作會插入一個#storestore的內(nèi)存屏障,而非putXxxVolatile的#storeload的內(nèi)存屏障,所以效率會高。所謂#storestore的內(nèi)存屏障,是之虛擬機在對于這樣的語句Store1; StoreStore; Store2,在Store2及后續(xù)寫入操作執(zhí)行前,保證Store1的寫入操作對其它處理器可見。
3 putXxxVolatile/***
* Sets the value of the integer field at the specified offset in the
* supplied object to the given value, with volatile store semantics.
*
* @param obj the object containing the field to modify.
* @param offset the offset of the integer field within obj
.
* @param value the new value of the field.
*/
public native void putIntVolatile(Object obj, long offset, int value);
Volatile是會插入#storeload的內(nèi)存屏障,效率略低
本篇為俺的課堂《Java基礎(chǔ):手寫jdk》的前置知識,歡迎大家圍觀
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/68871.html
摘要:菜鳥教程框架中文手冊入門目標使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學習指北 了解一下一下概念. RESTful API標準] 所有的API都遵循[RESTful API標準]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
摘要:菜鳥教程框架中文手冊入門目標使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學習指北 了解一下一下概念. RESTful API標準] 所有的API都遵循[RESTful API標準]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
摘要:菜鳥教程框架中文手冊入門目標使用搭建通過對數(shù)據(jù)增刪查改沒了純粹占行用的拜 后端API入門學習指北 了解一下一下概念. RESTful API標準] 所有的API都遵循[RESTful API標準]. 建議大家都簡單了解一下HTTP協(xié)議和RESTful API相關(guān)資料. 阮一峰:理解RESTful架構(gòu) 阮一峰:RESTful API 設(shè)計指南 RESTful API指南 依賴注入 D...
摘要:典型應(yīng)用鎖和同步器框架的核心類,就是通過調(diào)用和實現(xiàn)線程的阻塞和喚醒的,而的方法實際是調(diào)用的方式來實現(xiàn)。 前言 Unsafe是位于sun.misc包下的一個類,主要提供一些用于執(zhí)行低級別、不安全操作的方法,如直接訪問系統(tǒng)內(nèi)存資源、自主管理內(nèi)存資源等,這些方法在提升Java運行效率、增強Java語言底層資源操作能力方面起到了很大的作用。但由于Unsafe類使Java語言擁有了類似C語言指針...
摘要:本身不直接支持指針的操作,所以這也是該類命名為的原因之一。中的許多方法,內(nèi)部其實都是類在操作。 showImg(https://segmentfault.com/img/remote/1460000016012251); 本文首發(fā)于一世流云的專欄:https://segmentfault.com/blog... 一、Unsafe簡介 在正式的開講 juc-atomic框架系列之前,有...
閱讀 1646·2021-09-02 15:11
閱讀 1983·2019-08-30 14:04
閱讀 2569·2019-08-27 10:52
閱讀 1586·2019-08-26 11:52
閱讀 1211·2019-08-23 15:26
閱讀 2631·2019-08-23 15:09
閱讀 2610·2019-08-23 12:07
閱讀 2242·2019-08-22 18:41