class io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl implements io.vertx.core.shareddata.Lock
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl
super_class: java.lang.Object
{
private final org.apache.ignite.IgniteSemaphore semaphore;
descriptor: Lorg/apache/ignite/IgniteSemaphore;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.Executor lockReleaseExec;
descriptor: Ljava/util/concurrent/Executor;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.atomic.AtomicBoolean released;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private void <init>(org.apache.ignite.IgniteSemaphore, java.util.concurrent.Executor);
descriptor: (Lorg/apache/ignite/IgniteSemaphore;Ljava/util/concurrent/Executor;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=3
start local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
start local 1 // org.apache.ignite.IgniteSemaphore semaphore
start local 2 // java.util.concurrent.Executor lockReleaseExec
0: .line 448
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 446
aload 0 /* this */
new java.util.concurrent.atomic.AtomicBoolean
dup
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.released:Ljava/util/concurrent/atomic/AtomicBoolean;
2: .line 449
aload 0 /* this */
aload 1 /* semaphore */
putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.semaphore:Lorg/apache/ignite/IgniteSemaphore;
3: .line 450
aload 0 /* this */
aload 2 /* lockReleaseExec */
putfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.lockReleaseExec:Ljava/util/concurrent/Executor;
4: .line 451
return
end local 2 // java.util.concurrent.Executor lockReleaseExec
end local 1 // org.apache.ignite.IgniteSemaphore semaphore
end local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lio/vertx/spi/cluster/ignite/IgniteClusterManager$LockImpl;
0 5 1 semaphore Lorg/apache/ignite/IgniteSemaphore;
0 5 2 lockReleaseExec Ljava/util/concurrent/Executor;
MethodParameters:
Name Flags
semaphore
lockReleaseExec
public void release();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
0: .line 455
aload 0 /* this */
getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.released:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifeq 2
1: .line 456
aload 0 /* this */
getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.lockReleaseExec:Ljava/util/concurrent/Executor;
aload 0 /* this */
getfield io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl.semaphore:Lorg/apache/ignite/IgniteSemaphore;
dup
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
pop
invokedynamic run(Lorg/apache/ignite/IgniteSemaphore;)Ljava/lang/Runnable;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
()V
org/apache/ignite/IgniteSemaphore.release()V (9 itf)
()V
invokeinterface java.util.concurrent.Executor.execute:(Ljava/lang/Runnable;)V
2: .line 458
StackMap locals:
StackMap stack:
return
end local 0 // io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl this
LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/vertx/spi/cluster/ignite/IgniteClusterManager$LockImpl;
}
SourceFile: "IgniteClusterManager.java"
NestHost: io.vertx.spi.cluster.ignite.IgniteClusterManager
InnerClasses:
private LockImpl = io.vertx.spi.cluster.ignite.IgniteClusterManager$LockImpl of io.vertx.spi.cluster.ignite.IgniteClusterManager
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles