public interface UnsafeProxy
| 限定符和类型 | 字段和说明 |
|---|---|
static int |
INVALID_FIELD_OFFSET
This constant differs from all results that will ever be returned from
staticFieldOffset(java.lang.reflect.Field), objectFieldOffset(java.lang.reflect.Field),
or arrayBaseOffset(java.lang.Class<?>). |
| 限定符和类型 | 方法和说明 |
|---|---|
int |
addressSize()
Report the size in bytes of a pointer, as stored via
putAddress(long, long). |
Object |
allocateInstance(Class<?> cls)
Allocate an instance but do not run any constructor.
|
long |
allocateMemory(long bytes)
Allocates a new block of memory, of the given size in bytes.
|
int |
arrayBaseOffset(Class<?> arrayClass)
Report the offset of the first element in the storage allocation of a
given array class.
|
int |
arrayIndexScale(Class<?> arrayClass)
Report the scale factor for addressing elements in the storage
allocation of a given array class.
|
boolean |
compareAndSwapInt(Object o,
long offset,
int expected,
int x)
Atomically update Java variable to x if it is currently
holding expected.
|
boolean |
compareAndSwapLong(Object o,
long offset,
long expected,
long x)
Atomically update Java variable to x if it is currently
holding expected.
|
boolean |
compareAndSwapObject(Object o,
long offset,
Object expected,
Object x)
Atomically update Java variable to x if it is currently
holding expected.
|
void |
copyMemory(long srcAddress,
long destAddress,
long bytes)
Sets all bytes in a given block of memory to a copy of another
block.
|
void |
copyMemory(Object srcBase,
long srcOffset,
Object destBase,
long destOffset,
long bytes)
Sets all bytes in a given block of memory to a copy of another
block.
|
Class<?> |
defineAnonymousClass(Class<?> hostClass,
byte[] data,
Object[] cpPatches)
Define a class but do not make it known to the class loader or system dictionary.
|
Class<?> |
defineClass(String name,
byte[] b,
int off,
int len,
ClassLoader loader,
ProtectionDomain protectionDomain)
Tell the VM to define a class, without security checks.
|
void |
ensureClassInitialized(Class<?> c)
Ensure the given class has been initialized.
|
int |
fieldOffset(Field f)
Returns the offset of a field, truncated to 32 bits.
|
void |
freeMemory(long address)
Disposes of a block of memory, as obtained from
allocateMemory(long) or reallocateMemory(long, long). |
void |
fullFence()
Ensures lack of reordering of loads or stores before the fence
with loads or stores after the fence.
|
long |
getAddress(long address)
Fetches a pointer from a given memory address.
|
int |
getAndAddInt(Object o,
long offset,
int delta)
Atomically adds the given value to the current value of a field
or array element within the given object
o
at the given offset. |
long |
getAndAddLong(Object o,
long offset,
long delta)
Atomically adds the given value to the current value of a field
or array element within the given object
o
at the given offset. |
int |
getAndSetInt(Object o,
long offset,
int newValue)
Atomically exchanges the given value with the current value of
a field or array element within the given object
o
at the given offset. |
long |
getAndSetLong(Object o,
long offset,
long newValue)
Atomically exchanges the given value with the current value of
a field or array element within the given object
o
at the given offset. |
Object |
getAndSetObject(Object o,
long offset,
Object newValue)
Atomically exchanges the given reference value with the current
reference value of a field or array element within the given
object
o at the given offset. |
boolean |
getBoolean(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
boolean |
getBoolean(Object o,
long offset) |
boolean |
getBooleanVolatile(Object o,
long offset)
Volatile version of
getBoolean(Object, long) |
byte |
getByte(long address)
Fetches a value from a given memory address.
|
byte |
getByte(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
byte |
getByte(Object o,
long offset) |
byte |
getByteVolatile(Object o,
long offset)
Volatile version of
getByte(Object, long) |
char |
getChar(long address) |
char |
getChar(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
char |
getChar(Object o,
long offset) |
char |
getCharVolatile(Object o,
long offset)
Volatile version of
getChar(Object, long) |
double |
getDouble(long address) |
double |
getDouble(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
double |
getDouble(Object o,
long offset) |
double |
getDoubleVolatile(Object o,
long offset)
Volatile version of
getDouble(Object, long) |
float |
getFloat(long address) |
float |
getFloat(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
float |
getFloat(Object o,
long offset) |
float |
getFloatVolatile(Object o,
long offset)
Volatile version of
getFloat(Object, long) |
int |
getInt(long address) |
int |
getInt(Object o,
int offset)
This method, like all others with 32-bit offsets, was
in a previous release but is now a wrapper which simply casts
the offset to a long value.
|
int |
getInt(Object o,
long offset)
Fetches a value from a given Java variable.
|
int |
getIntVolatile(Object o,
long offset)
Volatile version of
getInt(Object, long) |
int |
getLoadAverage(double[] loadavg,
int nelems)
Gets the load average in the system run queue assigned
to the available processors averaged over various periods of time.
|
long |
getLong(long address) |
long |
getLong(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
long |
getLong(Object o,
long offset) |
long |
getLongVolatile(Object o,
long offset)
Volatile version of
getLong(Object, long) |
Object |
getObject(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
Object |
getObject(Object o,
long offset)
Fetches a reference value from a given Java variable.
|
Object |
getObjectVolatile(Object o,
long offset)
Fetches a reference value from a given Java variable, with volatile
load semantics.
|
short |
getShort(long address) |
short |
getShort(Object o,
int offset)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
short |
getShort(Object o,
long offset) |
short |
getShortVolatile(Object o,
long offset)
Volatile version of
getShort(Object, long) |
void |
loadFence()
Ensures lack of reordering of loads before the fence
with loads or stores after the fence.
|
void |
monitorEnter(Object o)
Lock the object.
|
void |
monitorExit(Object o)
Unlock the object.
|
long |
objectFieldOffset(Field f)
Report the location of a given static field, in conjunction with
staticFieldBase(java.lang.Class<?>). |
int |
pageSize()
Report the size in bytes of a memory page (whatever that is).
|
void |
park(boolean isAbsolute,
long time)
Block current thread, returning when a balancing
unpark occurs, or a balancing unpark has
already occurred, or the thread is interrupted, or, if not
absolute and time is not zero, the given time nanoseconds have
elapsed, or if absolute, the given deadline in milliseconds
since Epoch has passed, or spuriously (i.e., returning for no
"reason").
|
void |
putAddress(long address,
long x)
Stores a pointer into a given memory address.
|
void |
putBoolean(Object o,
int offset,
boolean x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putBoolean(Object o,
long offset,
boolean x) |
void |
putBooleanVolatile(Object o,
long offset,
boolean x)
Volatile version of
putBoolean(Object, long, boolean) |
void |
putByte(long address,
byte x)
Stores a value into a given memory address.
|
void |
putByte(Object o,
int offset,
byte x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putByte(Object o,
long offset,
byte x) |
void |
putByteVolatile(Object o,
long offset,
byte x)
Volatile version of
putByte(Object, long, byte) |
void |
putChar(long address,
char x) |
void |
putChar(Object o,
int offset,
char x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putChar(Object o,
long offset,
char x) |
void |
putCharVolatile(Object o,
long offset,
char x)
Volatile version of
putChar(Object, long, char) |
void |
putDouble(long address,
double x) |
void |
putDouble(Object o,
int offset,
double x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putDouble(Object o,
long offset,
double x) |
void |
putDoubleVolatile(Object o,
long offset,
double x)
Volatile version of
putDouble(Object, long, double) |
void |
putFloat(long address,
float x) |
void |
putFloat(Object o,
int offset,
float x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putFloat(Object o,
long offset,
float x) |
void |
putFloatVolatile(Object o,
long offset,
float x)
Volatile version of
putFloat(Object, long, float) |
void |
putInt(long address,
int x) |
void |
putInt(Object o,
int offset,
int x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putInt(Object o,
long offset,
int x)
Stores a value into a given Java variable.
|
void |
putIntVolatile(Object o,
long offset,
int x)
Volatile version of
putInt(Object, long, int) |
void |
putLong(long address,
long x) |
void |
putLong(Object o,
int offset,
long x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putLong(Object o,
long offset,
long x) |
void |
putLongVolatile(Object o,
long offset,
long x)
Volatile version of
putLong(Object, long, long) |
void |
putObject(Object o,
int offset,
Object x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putObject(Object o,
long offset,
Object x)
Stores a reference value into a given Java variable.
|
void |
putObjectVolatile(Object o,
long offset,
Object x)
Stores a reference value into a given Java variable, with
volatile store semantics.
|
void |
putOrderedInt(Object o,
long offset,
int x)
Ordered/Lazy version of
putIntVolatile(Object, long, int) |
void |
putOrderedLong(Object o,
long offset,
long x)
Ordered/Lazy version of
putLongVolatile(Object, long, long) |
void |
putOrderedObject(Object o,
long offset,
Object x)
Version of
putObjectVolatile(Object, long, Object)
that does not guarantee immediate visibility of the store to
other threads. |
void |
putShort(long address,
short x) |
void |
putShort(Object o,
int offset,
short x)
As of jdk 1.4.1, cast the 32-bit offset argument to a long.
|
void |
putShort(Object o,
long offset,
short x) |
void |
putShortVolatile(Object o,
long offset,
short x)
Volatile version of
putShort(Object, long, short) |
long |
reallocateMemory(long address,
long bytes)
Resizes a new block of memory, to the given size in bytes.
|
void |
setMemory(long address,
long bytes,
byte value)
Sets all bytes in a given block of memory to a fixed value
(usually zero).
|
void |
setMemory(Object o,
long offset,
long bytes,
byte value)
Sets all bytes in a given block of memory to a fixed value
(usually zero).
|
boolean |
shouldBeInitialized(Class<?> c)
Detect if the given class may need to be initialized.
|
Object |
staticFieldBase(Class<?> c)
Returns the base address for accessing some static field
in the given class.
|
Object |
staticFieldBase(Field f)
Report the location of a given static field, in conjunction with
staticFieldOffset(java.lang.reflect.Field). |
long |
staticFieldOffset(Field f)
Report the location of a given field in the storage allocation of its
class.
|
void |
storeFence()
Ensures lack of reordering of stores before the fence
with loads or stores after the fence.
|
void |
throwException(Throwable ee)
Throw the exception without telling the verifier.
|
boolean |
tryMonitorEnter(Object o)
Tries to lock the object.
|
void |
unpark(Object thread)
Unblock the given thread blocked on park, or, if it is
not blocked, cause the subsequent call to park not to
block.
|
static final int INVALID_FIELD_OFFSET
staticFieldOffset(java.lang.reflect.Field), objectFieldOffset(java.lang.reflect.Field),
or arrayBaseOffset(java.lang.Class<?>).int getInt(Object o, long offset)
o at the given offset, or (if o is
null) from the memory address whose numerical value is the given
offset.
The results are undefined unless one of the following cases is true:
objectFieldOffset(java.lang.reflect.Field) on
the Field of some Java field and the object
referred to by o is of a class compatible with that
field's class.
o (either null or
non-null) were both obtained via staticFieldOffset(java.lang.reflect.Field)
and staticFieldBase(java.lang.Class<?>) (respectively) from the
reflective Field representation of some Java field.
o is an array, and the offset
is an integer of the form B+N*S, where N is
a valid index into the array, and B and S are
the values obtained by arrayBaseOffset(java.lang.Class<?>) and arrayIndexScale(java.lang.Class<?>) (respectively) from the array's class. The value
referred to is the Nth element of the array.
If one of the above cases is true, the call references a specific Java variable (field or array element). However, the results are undefined if that variable is not in fact of the type returned by this method.
This method refers to a variable by means of two parameters, and so
it provides (in effect) a double-register addressing mode
for Java variables. When the object reference is null, this method
uses its offset as an absolute address. This is similar in operation
to methods such as getInt(long), which provide (in effect) a
single-register addressing mode for non-Java variables.
However, because Java variables may have a different layout in memory
from non-Java variables, programmers should not assume that these
two addressing modes are ever equivalent. Also, programmers should
remember that offsets from the double-register addressing mode cannot
be portably confused with longs used in the single-register addressing
mode.
o - Java heap object in which the variable resides, if any, else
nulloffset - indication of where the variable resides in a Java heap
object, if any, else a memory address locating the variable
staticallyRuntimeException - No defined exceptions are thrown, not even
NullPointerExceptionvoid putInt(Object o, long offset, int x)
The first two parameters are interpreted exactly as with
getInt(Object, long) to refer to a specific
Java variable (field or array element). The given value
is stored into that variable.
The variable must be of the same type as the method
parameter x.
o - Java heap object in which the variable resides, if any, else
nulloffset - indication of where the variable resides in a Java heap
object, if any, else a memory address locating the variable
staticallyx - the value to store into the indicated Java variableRuntimeException - No defined exceptions are thrown, not even
NullPointerExceptionObject getObject(Object o, long offset)
getInt(Object, long)void putObject(Object o, long offset, Object x)
Unless the reference x being stored is either null
or matches the field type, the results are undefined.
If the reference o is non-null, car marks or
other store barriers for that object (if the VM requires them)
are updated.
putInt(Object, int, int)boolean getBoolean(Object o, long offset)
getInt(Object, long)void putBoolean(Object o, long offset, boolean x)
putInt(Object, int, int)byte getByte(Object o, long offset)
getInt(Object, long)void putByte(Object o, long offset, byte x)
putInt(Object, int, int)short getShort(Object o, long offset)
getInt(Object, long)void putShort(Object o, long offset, short x)
putInt(Object, int, int)char getChar(Object o, long offset)
getInt(Object, long)void putChar(Object o, long offset, char x)
putInt(Object, int, int)long getLong(Object o, long offset)
getInt(Object, long)void putLong(Object o, long offset, long x)
putInt(Object, int, int)float getFloat(Object o, long offset)
getInt(Object, long)void putFloat(Object o, long offset, float x)
putInt(Object, int, int)double getDouble(Object o, long offset)
getInt(Object, long)void putDouble(Object o, long offset, double x)
putInt(Object, int, int)int getInt(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putInt(Object o, int offset, int x)
staticFieldOffset(java.lang.reflect.Field).Object getObject(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putObject(Object o, int offset, Object x)
staticFieldOffset(java.lang.reflect.Field).boolean getBoolean(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putBoolean(Object o, int offset, boolean x)
staticFieldOffset(java.lang.reflect.Field).byte getByte(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putByte(Object o, int offset, byte x)
staticFieldOffset(java.lang.reflect.Field).short getShort(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putShort(Object o, int offset, short x)
staticFieldOffset(java.lang.reflect.Field).char getChar(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putChar(Object o, int offset, char x)
staticFieldOffset(java.lang.reflect.Field).long getLong(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putLong(Object o, int offset, long x)
staticFieldOffset(java.lang.reflect.Field).float getFloat(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putFloat(Object o, int offset, float x)
staticFieldOffset(java.lang.reflect.Field).double getDouble(Object o, int offset)
staticFieldOffset(java.lang.reflect.Field).void putDouble(Object o, int offset, double x)
staticFieldOffset(java.lang.reflect.Field).byte getByte(long address)
allocateMemory(long), the
results are undefined.allocateMemory(long)void putByte(long address,
byte x)
allocateMemory(long), the
results are undefined.getByte(long)short getShort(long address)
getByte(long)void putShort(long address,
short x)
putByte(long, byte)char getChar(long address)
getByte(long)void putChar(long address,
char x)
putByte(long, byte)int getInt(long address)
getByte(long)void putInt(long address,
int x)
putByte(long, byte)long getLong(long address)
getByte(long)void putLong(long address,
long x)
putByte(long, byte)float getFloat(long address)
getByte(long)void putFloat(long address,
float x)
putByte(long, byte)double getDouble(long address)
getByte(long)void putDouble(long address,
double x)
putByte(long, byte)long getAddress(long address)
allocateMemory(long), the results are undefined.
If the pointer is less than 64 bits wide, it is extended as
an unsigned number to a Java long. The pointer may be indexed by any
given byte offset, simply by adding that offset (as a simple integer) to
the long representing the pointer. The number of bytes actually read
from the target address maybe determined by consulting addressSize().
allocateMemory(long)void putAddress(long address,
long x)
allocateMemory(long), the results are undefined.
The number of bytes actually written at the target address maybe
determined by consulting addressSize().
getAddress(long)long allocateMemory(long bytes)
freeMemory(long), or resize it with reallocateMemory(long, long).IllegalArgumentException - if the size is negative or too large
for the size_t typeOutOfMemoryError - if the allocation is refused by the systemgetByte(long),
putByte(long, byte)long reallocateMemory(long address,
long bytes)
freeMemory(long), or resize it with reallocateMemory(long, long). The address passed to this method may be null, in
which case an allocation will be performed.IllegalArgumentException - if the size is negative or too large
for the size_t typeOutOfMemoryError - if the allocation is refused by the systemallocateMemory(long)void setMemory(Object o, long offset, long bytes, byte value)
This method determines a block's base address by means of two parameters,
and so it provides (in effect) a double-register addressing mode,
as discussed in getInt(Object, long). When the object reference is null,
the offset supplies an absolute base address.
The stores are in coherent (atomic) units of a size determined by the address and length parameters. If the effective address and length are all even modulo 8, the stores take place in 'long' units. If the effective address and length are (resp.) even modulo 4 or 2, the stores take place in units of 'int' or 'short'.
void setMemory(long address,
long bytes,
byte value)
getInt(Object, long).
Equivalent to setMemory(null, address, bytes, value).
void copyMemory(Object srcBase, long srcOffset, Object destBase, long destOffset, long bytes)
This method determines each block's base address by means of two parameters,
and so it provides (in effect) a double-register addressing mode,
as discussed in getInt(Object, long). When the object reference is null,
the offset supplies an absolute base address.
The transfers are in coherent (atomic) units of a size determined by the address and length parameters. If the effective addresses and length are all even modulo 8, the transfer takes place in 'long' units. If the effective addresses and length are (resp.) even modulo 4 or 2, the transfer takes place in units of 'int' or 'short'.
void copyMemory(long srcAddress,
long destAddress,
long bytes)
getInt(Object, long).
Equivalent to copyMemory(null, srcAddress, null, destAddress, bytes).
void freeMemory(long address)
allocateMemory(long) or reallocateMemory(long, long). The address passed to
this method may be null, in which case no action is taken.allocateMemory(long)int fieldOffset(Field f)
public int fieldOffset(Field f) {
if (Modifier.isStatic(f.getModifiers()))
return (int) staticFieldOffset(f);
else
return (int) objectFieldOffset(f);
}
As of jdk 1.4.1, use staticFieldOffset(java.lang.reflect.Field) for static
fields and objectFieldOffset(java.lang.reflect.Field) for non-static fields.Object staticFieldBase(Class<?> c)
public Object staticFieldBase(Class c) {
Field[] fields = c.getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
if (Modifier.isStatic(fields[i].getModifiers())) {
return staticFieldBase(fields[i]);
}
}
return null;
}
As of jdk 1.4.1, use staticFieldBase(Field)
to obtain the base pertaining to a specific Field.
This method works only for JVMs which store all statics
for a given class in one place.long staticFieldOffset(Field f)
Any given field will always have the same offset and base, and no two distinct fields of the same class will ever have the same offset and base.
As of jdk 1.4.1, offsets for fields are represented as long values,
although the Sun JVM does not use the most significant 32 bits.
However, JVM implementations which store static fields at absolute
addresses can use long offsets and null base pointers to express
the field locations in a form usable by getInt(Object, long).
Therefore, code which will be ported to such JVMs on 64-bit platforms
must preserve all bits of static field offsets.
getInt(Object, long)long objectFieldOffset(Field f)
staticFieldBase(java.lang.Class<?>).
Do not expect to perform any sort of arithmetic on this offset; it is just a cookie which is passed to the unsafe heap memory accessors.
Any given field will always have the same offset, and no two distinct fields of the same class will ever have the same offset.
As of jdk 1.4.1, offsets for fields are represented as long values, although the Sun JVM does not use the most significant 32 bits. It is hard to imagine a JVM technology which needs more than a few bits to encode an offset within a non-array object, However, for consistency with other methods in this class, this method reports its result as a long value.
getInt(Object, long)Object staticFieldBase(Field f)
staticFieldOffset(java.lang.reflect.Field).
Fetch the base "Object", if any, with which static fields of the
given class can be accessed via methods like getInt(Object,
long). This value may be null. This value may refer to an object
which is a "cookie", not guaranteed to be a real Object, and it should
not be used in any way except as argument to the get and put routines in
this class.
boolean shouldBeInitialized(Class<?> c)
ensureClassInitialized would have no effectvoid ensureClassInitialized(Class<?> c)
int arrayBaseOffset(Class<?> arrayClass)
arrayIndexScale(java.lang.Class<?>) returns a non-zero value
for the same class, you may use that scale factor, together with this
base offset, to form new offsets to access elements of arrays of the
given class.int arrayIndexScale(Class<?> arrayClass)
getByte(Object, int), so the scale factor for such classes is reported
as zero.int addressSize()
putAddress(long, long). This value will be either 4 or 8. Note that the sizes of
other primitive types (as stored in memory blocks) is determined
fully by their information content.int pageSize()
Class<?> defineClass(String name, byte[] b, int off, int len, ClassLoader loader, ProtectionDomain protectionDomain)
Class<?> defineAnonymousClass(Class<?> hostClass, byte[] data, Object[] cpPatches)
For each CP entry, the corresponding CP patch must either be null or have the a format that matches its tag:
hostClass - context for linkage, access control, protection domain, and class loaderdata - bytes of a class filecpPatches - where non-null entries exist, they replace corresponding CP entries in dataObject allocateInstance(Class<?> cls) throws InstantiationException
void monitorEnter(Object o)
monitorExit(java.lang.Object).void monitorExit(Object o)
monitorEnter(java.lang.Object).boolean tryMonitorEnter(Object o)
monitorExit(java.lang.Object).void throwException(Throwable ee)
boolean compareAndSwapObject(Object o, long offset, Object expected, Object x)
boolean compareAndSwapInt(Object o, long offset, int expected, int x)
boolean compareAndSwapLong(Object o, long offset, long expected, long x)
Object getObjectVolatile(Object o, long offset)
getObject(Object, long)void putObjectVolatile(Object o, long offset, Object x)
putObject(Object, long, Object)int getIntVolatile(Object o, long offset)
getInt(Object, long)void putIntVolatile(Object o, long offset, int x)
putInt(Object, long, int)boolean getBooleanVolatile(Object o, long offset)
getBoolean(Object, long)void putBooleanVolatile(Object o, long offset, boolean x)
putBoolean(Object, long, boolean)byte getByteVolatile(Object o, long offset)
getByte(Object, long)void putByteVolatile(Object o, long offset, byte x)
putByte(Object, long, byte)short getShortVolatile(Object o, long offset)
getShort(Object, long)void putShortVolatile(Object o, long offset, short x)
putShort(Object, long, short)char getCharVolatile(Object o, long offset)
getChar(Object, long)void putCharVolatile(Object o, long offset, char x)
putChar(Object, long, char)long getLongVolatile(Object o, long offset)
getLong(Object, long)void putLongVolatile(Object o, long offset, long x)
putLong(Object, long, long)float getFloatVolatile(Object o, long offset)
getFloat(Object, long)void putFloatVolatile(Object o, long offset, float x)
putFloat(Object, long, float)double getDoubleVolatile(Object o, long offset)
getDouble(Object, long)void putDoubleVolatile(Object o, long offset, double x)
putDouble(Object, long, double)void putOrderedObject(Object o, long offset, Object x)
putObjectVolatile(Object, long, Object)
that does not guarantee immediate visibility of the store to
other threads. This method is generally only useful if the
underlying field is a Java volatile (or if an array cell, one
that is otherwise only accessed using volatile accesses).void putOrderedInt(Object o, long offset, int x)
putIntVolatile(Object, long, int)void putOrderedLong(Object o, long offset, long x)
putLongVolatile(Object, long, long)void unpark(Object thread)
thread - the thread to unpark.void park(boolean isAbsolute,
long time)
int getLoadAverage(double[] loadavg,
int nelems)
int getAndAddInt(Object o, long offset, int delta)
o
at the given offset.o - object/array to update the field/element inoffset - field/element offsetdelta - the value to addlong getAndAddLong(Object o, long offset, long delta)
o
at the given offset.o - object/array to update the field/element inoffset - field/element offsetdelta - the value to addint getAndSetInt(Object o, long offset, int newValue)
o
at the given offset.o - object/array to update the field/element inoffset - field/element offsetnewValue - new valuelong getAndSetLong(Object o, long offset, long newValue)
o
at the given offset.o - object/array to update the field/element inoffset - field/element offsetnewValue - new valueObject getAndSetObject(Object o, long offset, Object newValue)
o at the given offset.o - object/array to update the field/element inoffset - field/element offsetnewValue - new valuevoid loadFence()
void storeFence()
void fullFence()
Copyright © 2022. All rights reserved.