⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 atomicboolean.java

📁 java1.6众多例子参考
💻 JAVA
字号:
/* * @(#)AtomicBoolean.java	1.13 06/06/15 * * Copyright 2006 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */package java.util.concurrent.atomic;import sun.misc.Unsafe;/** * A {@code boolean} value that may be updated atomically. See the * {@link java.util.concurrent.atomic} package specification for * description of the properties of atomic variables. An * {@code AtomicBoolean} is used in applications such as atomically * updated flags, and cannot be used as a replacement for a * {@link java.lang.Boolean}. * * @since 1.5 * @author Doug Lea */public class AtomicBoolean implements java.io.Serializable {    private static final long serialVersionUID = 4654671469794556979L;    // setup to use Unsafe.compareAndSwapInt for updates    private static final Unsafe unsafe = Unsafe.getUnsafe();    private static final long valueOffset;    static {      try {        valueOffset = unsafe.objectFieldOffset            (AtomicBoolean.class.getDeclaredField("value"));      } catch (Exception ex) { throw new Error(ex); }    }    private volatile int value;    /**     * Creates a new {@code AtomicBoolean} with the given initial value.     *     * @param initialValue the initial value     */    public AtomicBoolean(boolean initialValue) {        value = initialValue ? 1 : 0;    }    /**     * Creates a new {@code AtomicBoolean} with initial value {@code false}.     */    public AtomicBoolean() {    }    /**     * Returns the current value.     *     * @return the current value     */    public final boolean get() {        return value != 0;    }    /**     * Atomically sets the value to the given updated value     * if the current value {@code ==} the expected value.     *     * @param expect the expected value     * @param update the new value     * @return true if successful. False return indicates that     * the actual value was not equal to the expected value.     */    public final boolean compareAndSet(boolean expect, boolean update) {        int e = expect ? 1 : 0;        int u = update ? 1 : 0;        return unsafe.compareAndSwapInt(this, valueOffset, e, u);    }    /**     * Atomically sets the value to the given updated value     * if the current value {@code ==} the expected value.     *     * <p>May <a href="package-summary.html#Spurious">fail spuriously</a>     * and does not provide ordering guarantees, so is only rarely an     * appropriate alternative to {@code compareAndSet}.     *     * @param expect the expected value     * @param update the new value     * @return true if successful.     */    public boolean weakCompareAndSet(boolean expect, boolean update) {        int e = expect ? 1 : 0;        int u = update ? 1 : 0;        return unsafe.compareAndSwapInt(this, valueOffset, e, u);    }    /**     * Unconditionally sets to the given value.     *     * @param newValue the new value     */    public final void set(boolean newValue) {        value = newValue ? 1 : 0;    }    /**     * Eventually sets to the given value.     *     * @param newValue the new value     * @since 1.6     */    public final void lazySet(boolean newValue) {        int v = newValue ? 1 : 0;        unsafe.putOrderedInt(this, valueOffset, v);    }    /**     * Atomically sets to the given value and returns the previous value.     *     * @param newValue the new value     * @return the previous value     */    public final boolean getAndSet(boolean newValue) {        for (;;) {            boolean current = get();            if (compareAndSet(current, newValue))                return current;        }    }    /**     * Returns the String representation of the current value.     * @return the String representation of the current value.     */    public String toString() {        return Boolean.toString(get());    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -