激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務器之家 - 編程語言 - Java教程 - Java concurrency之AtomicLongFieldUpdater原子類_動力節點Java學院整理

Java concurrency之AtomicLongFieldUpdater原子類_動力節點Java學院整理

2020-11-09 15:59動力節點 Java教程

AtomicLongFieldUpdater可以對指定"類的 'volatile long'類型的成員"進行原子更新。它是基于反射原理實現的。下面通過本文給大家分享Java concurrency之AtomicLongFieldUpdater原子類的相關知識,感興趣的朋友一起看看吧

AtomicLongFieldUpdater介紹和函數列表

AtomicLongFieldUpdater可以對指定"類的 'volatile long'類型的成員"進行原子更新。它是基于反射原理實現的。

AtomicLongFieldUpdater函數列表

?
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
// 受保護的無操作構造方法,供子類使用。
protected AtomicLongFieldUpdater()
// 以原子方式將給定值添加到此更新器管理的給定對象的字段的當前值。
long addAndGet(T obj, long delta)
// 如果當前值 == 預期值,則以原子方式將此更新器所管理的給定對象的字段設置為給定的更新值。
abstract boolean compareAndSet(T obj, long expect, long update)
// 以原子方式將此更新器管理的給定對象字段當前值減 1。
long decrementAndGet(T obj)
// 獲取此更新器管理的在給定對象的字段中保持的當前值。
abstract long get(T obj)
// 以原子方式將給定值添加到此更新器管理的給定對象的字段的當前值。
long getAndAdd(T obj, long delta)
// 以原子方式將此更新器管理的給定對象字段當前值減 1。
long getAndDecrement(T obj)
// 以原子方式將此更新器管理的給定對象字段的當前值加 1。
long getAndIncrement(T obj)
// 將此更新器管理的給定對象的字段以原子方式設置為給定值,并返回舊值。
long getAndSet(T obj, long newValue)
// 以原子方式將此更新器管理的給定對象字段當前值加 1。
long incrementAndGet(T obj)
// 最后將此更新器管理的給定對象的字段設置為給定更新值。
abstract void lazySet(T obj, long newValue)
// 為對象創建并返回一個具有給定字段的更新器。
static <U> AtomicLongFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName)
// 將此更新器管理的給定對象的字段設置為給定更新值。
abstract void set(T obj, long newValue)
// 如果當前值 == 預期值,則以原子方式將此更新器所管理的給定對象的字段設置為給定的更新值。
abstract boolean weakCompareAndSet(T obj, long expect, long update)

AtomicLongFieldUpdater示例

?
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
// LongTest.java的源碼
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
public class LongFieldTest {
  public static void main(String[] args) {
    // 獲取Person的class對象
    Class cls = Person.class;
    // 新建AtomicLongFieldUpdater對象,傳遞參數是“class對象”和“long類型在類中對應的名稱”
    AtomicLongFieldUpdater mAtoLong = AtomicLongFieldUpdater.newUpdater(cls, "id");
    Person person = new Person(12345678L);
    // 比較person的"id"屬性,如果id的值為12345678L,則設置為1000。
    mAtoLong.compareAndSet(person, 12345678L, 1000);
    System.out.println("id="+person.getId());
  }
}
class Person {
  volatile long id;
  public Person(long id) {
    this.id = id;
  }
  public void setId(long id) {
    this.id = id;
  }
  public long getId() {
    return id;
  }
}

運行結果:

id=1000

AtomicLongFieldUpdater源碼分析(基于JDK1.7.0_40)

AtomicLongFieldUpdater完整源碼

?
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
/*
 * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 *
 */
/*
 *
 *
 *
 *
 *
 * Written by Doug Lea with assistance from members of JCP JSR-
 * Expert Group and released to the public domain, as explained at
 * http://creativecommons.org/publicdomain/zero/./
 */
package java.util.concurrent.atomic;
import java.lang.reflect.*;
import sun.misc.Unsafe;
import sun.reflect.CallerSensitive;
import sun.reflect.Reflection;
/**
 * A reflection-based utility that enables atomic updates to
 * designated {@code volatile} reference fields of designated
 * classes. This class is designed for use in atomic data structures
 * in which several reference fields of the same node are
 * independently subject to atomic updates. For example, a tree node
 * might be declared as
 *
 * <pre> {@code
 * class Node {
 *  private volatile Node left, right;
 *
 *  private static final AtomicReferenceFieldUpdater<Node, Node> leftUpdater =
 *   AtomicReferenceFieldUpdater.newUpdater(Node.class, Node.class, "left");
 *  private static AtomicReferenceFieldUpdater<Node, Node> rightUpdater =
 *   AtomicReferenceFieldUpdater.newUpdater(Node.class, Node.class, "right");
 *
 *  Node getLeft() { return left; }
 *  boolean compareAndSetLeft(Node expect, Node update) {
 *   return leftUpdater.compareAndSet(this, expect, update);
 *  }
 *  // ... and so on
 * }}</pre>
 *
 * <p>Note that the guarantees of the {@code compareAndSet}
 * method in this class are weaker than in other atomic classes.
 * Because this class cannot ensure that all uses of the field
 * are appropriate for purposes of atomic access, it can
 * guarantee atomicity only with respect to other invocations of
 * {@code compareAndSet} and {@code set} on the same updater.
 *
 * @since .
 * @author Doug Lea
 * @param <T> The type of the object holding the updatable field
 * @param <V> The type of the field
 */
public abstract class AtomicReferenceFieldUpdater<T, V> {
  /**
   * Creates and returns an updater for objects with the given field.
   * The Class arguments are needed to check that reflective types and
   * generic types match.
   *
   * @param tclass the class of the objects holding the field.
   * @param vclass the class of the field
   * @param fieldName the name of the field to be updated.
   * @return the updater
   * @throws IllegalArgumentException if the field is not a volatile reference type.
   * @throws RuntimeException with a nested reflection-based
   * exception if the class does not hold field or is the wrong type.
   */
  @CallerSensitive
  public static <U, W> AtomicReferenceFieldUpdater<U,W> newUpdater(Class<U> tclass, Class<W> vclass, String fieldName) {
    return new AtomicReferenceFieldUpdaterImpl<U,W>(tclass,
                            vclass,
                            fieldName,
                            Reflection.getCallerClass());
  }
  /**
  * Protected do-nothing constructor for use by subclasses.
  */
  protected AtomicReferenceFieldUpdater() {
  }
  /**
  * Atomically sets the field of the given object managed by this updater
  * to the given updated value if the current value {@code ==} the
  * expected value. This method is guaranteed to be atomic with respect to
  * other calls to {@code compareAndSet} and {@code set}, but not
  * necessarily with respect to other changes in the field.
  *
  * @param obj An object whose field to conditionally set
  * @param expect the expected value
  * @param update the new value
  * @return true if successful.
  */
  public abstract boolean compareAndSet(T obj, V expect, V update);
  /**
  * Atomically sets the field of the given object managed by this updater
  * to the given updated value if the current value {@code ==} the
  * expected value. This method is guaranteed to be atomic with respect to
  * other calls to {@code compareAndSet} and {@code set}, but not
  * necessarily with respect to other changes in the field.
  *
  * <p>May <a href="package-summary.html#Spurious" rel="external nofollow" >fail spuriously</a>
  * and does not provide ordering guarantees, so is only rarely an
  * appropriate alternative to {@code compareAndSet}.
  *
  * @param obj An object whose field to conditionally set
  * @param expect the expected value
  * @param update the new value
  * @return true if successful.
  */
  public abstract boolean weakCompareAndSet(T obj, V expect, V update);
  /**
  * Sets the field of the given object managed by this updater to the
  * given updated value. This operation is guaranteed to act as a volatile
  * store with respect to subsequent invocations of {@code compareAndSet}.
  *
  * @param obj An object whose field to set
  * @param newValue the new value
  */
  public abstract void set(T obj, V newValue);
  /**
  * Eventually sets the field of the given object managed by this
  * updater to the given updated value.
  *
  * @param obj An object whose field to set
  * @param newValue the new value
  * @since 1.6
  */
  public abstract void lazySet(T obj, V newValue);
  /**
  * Gets the current value held in the field of the given object managed
  * by this updater.
  *
  * @param obj An object whose field to get
  * @return the current value
  */
  public abstract V get(T obj);
  /**
  * Atomically sets the field of the given object managed by this updater
  * to the given value and returns the old value.
  *
  * @param obj An object whose field to get and set
  * @param newValue the new value
  * @return the previous value
  */
  public V getAndSet(T obj, V newValue) {
    for (;;) {
      V current = get(obj);
      if (compareAndSet(obj, current, newValue))
        return current;
    }
  }
  private static final class AtomicReferenceFieldUpdaterImpl<T,V>
    extends AtomicReferenceFieldUpdater<T,V> {
    private static final Unsafe unsafe = Unsafe.getUnsafe();
    private final long offset;
    private final Class<T> tclass;
    private final Class<V> vclass;
    private final Class cclass;
    /*
    * Internal type checks within all update methods contain
    * internal inlined optimizations checking for the common
    * cases where the class is final (in which case a simple
    * getClass comparison suffices) or is of type Object (in
    * which case no check is needed because all objects are
    * instances of Object). The Object case is handled simply by
    * setting vclass to null in constructor. The targetCheck and
    * updateCheck methods are invoked when these faster
    * screenings fail.
    */
    AtomicReferenceFieldUpdaterImpl(Class<T> tclass,
                    Class<V> vclass,
                    String fieldName,
                    Class<?> caller) {
      Field field = null;
      Class fieldClass = null;
      int modifiers = 0;
      try {
        field = tclass.getDeclaredField(fieldName);
        modifiers = field.getModifiers();
        sun.reflect.misc.ReflectUtil.ensureMemberAccess(
          caller, tclass, null, modifiers);
        sun.reflect.misc.ReflectUtil.checkPackageAccess(tclass);
        fieldClass = field.getType();
      } catch (Exception ex) {
        throw new RuntimeException(ex);
      }
      if (vclass != fieldClass)
        throw new ClassCastException();
      if (!Modifier.isVolatile(modifiers))
        throw new IllegalArgumentException("Must be volatile type");
      this.cclass = (Modifier.isProtected(modifiers) &&
             caller != tclass) ? caller : null;
      this.tclass = tclass;
      if (vclass == Object.class)
        this.vclass = null;
      else
        this.vclass = vclass;
      offset = unsafe.objectFieldOffset(field);
    }
    void targetCheck(T obj) {
      if (!tclass.isInstance(obj))
        throw new ClassCastException();
      if (cclass != null)
        ensureProtectedAccess(obj);
    }
    void updateCheck(T obj, V update) {
      if (!tclass.isInstance(obj) ||
        (update != null && vclass != null && !vclass.isInstance(update)))
        throw new ClassCastException();
      if (cclass != null)
        ensureProtectedAccess(obj);
    }
    public boolean compareAndSet(T obj, V expect, V update) {
      if (obj == null || obj.getClass() != tclass || cclass != null ||
        (update != null && vclass != null &&
        vclass != update.getClass()))
        updateCheck(obj, update);
      return unsafe.compareAndSwapObject(obj, offset, expect, update);
    }
    public boolean weakCompareAndSet(T obj, V expect, V update) {
      // same implementation as strong form for now
      if (obj == null || obj.getClass() != tclass || cclass != null ||
        (update != null && vclass != null &&
        vclass != update.getClass()))
        updateCheck(obj, update);
      return unsafe.compareAndSwapObject(obj, offset, expect, update);
    }
    public void set(T obj, V newValue) {
      if (obj == null || obj.getClass() != tclass || cclass != null ||
        (newValue != null && vclass != null &&
        vclass != newValue.getClass()))
        updateCheck(obj, newValue);
      unsafe.putObjectVolatile(obj, offset, newValue);
    }
    public void lazySet(T obj, V newValue) {
      if (obj == null || obj.getClass() != tclass || cclass != null ||
        (newValue != null && vclass != null &&
        vclass != newValue.getClass()))
        updateCheck(obj, newValue);
      unsafe.putOrderedObject(obj, offset, newValue);
    }
    public V get(T obj) {
      if (obj == null || obj.getClass() != tclass || cclass != null)
        targetCheck(obj);
      return (V)unsafe.getObjectVolatile(obj, offset);
    }
    private void ensureProtectedAccess(T obj) {
      if (cclass.isInstance(obj)) {
        return;
      }
      throw new RuntimeException(
        new IllegalAccessException("Class " +
          cclass.getName() +
          " can not access a protected member of class " +
          tclass.getName() +
          " using an instance of " +
          obj.getClass().getName()
        )
      );
    }
  }
}

   下面分析LongFieldTest.java的流程。

1. newUpdater()

newUpdater()的源碼如下:

?
1
2
3
4
5
6
7
public static <U> AtomicLongFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName) {
  Class<?> caller = Reflection.getCallerClass();
  if (AtomicLong.VM_SUPPORTS_LONG_CAS)
    return new CASUpdater<U>(tclass, fieldName, caller);
  else
    return new LockedUpdater<U>(tclass, fieldName, caller);
}

說明:newUpdater()的作用是獲取一個AtomicIntegerFieldUpdater類型的對象。

它實際上返回的是CASUpdater對象,或者LockedUpdater對象;具體返回哪一個類取決于JVM是否支持long類型的CAS函數。CASUpdater和LockedUpdater都是AtomicIntegerFieldUpdater的子類,它們的實現類似。下面以CASUpdater來進行說明。 

CASUpdater類的源碼如下:

?
1
2
3
4
public boolean compareAndSet(T obj, long expect, long update) {
  if (obj == null || obj.getClass() != tclass || cclass != null) fullCheck(obj);
  return unsafe.compareAndSwapLong(obj, offset, expect, update);
}

說明:它實際上是通過CAS函數操作。如果類的long對象的值是expect,則設置它的值為update。 

延伸 · 閱讀

精彩推薦
508
主站蜘蛛池模板: 成人污在线 | 欧日韩 | 国产精品99久久久久久久女警 | 性欧美日本 | 中文字幕在线观看免费视频 | 精品二区在线观看 | 国产中文一区 | 欧美日韩综合视频 | 91资源在线观看 | 精品亚洲在线 | 9191色| 91成人在线免费观看 | 国产一区二区视频网站 | 性片免费看 | 国产流白浆高潮在线观看 | 大胆在线日本aⅴ免费视频 美国黄色毛片女人性生活片 | 国产一区二区国产 | 羞羞视频免费视频欧美 | 视频一区二区三区在线观看 | 欧美性生活久久 | 在线观看91精品 | 欧美成人精品一区二区三区 | 久久久一区二区三区精品 | 日韩精品a在线观看 | 午夜视频在线在免费 | 又黄又爽免费无遮挡在线观看 | 亚洲日本韩国精品 | 久草在线播放视频 | 精品国产精品久久 | 日韩av成人 | 最新久久免费视频 | 欧美精品一级 | 国产高清一区 | 特黄一区二区三区 | 成人免费在线播放 | 一级毛片手机在线观看 | 深夜免费视频 | 久久国产免费 | 成年人在线视频免费 | 悠悠成人资源亚洲一区二区 | 欧美一区二区三区不卡免费观看 |