public final class javax.security.auth.Subject implements java.io.Serializable
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: javax.security.auth.Subject
  super_class: java.lang.Object
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -8308522755600156056

  java.util.Set<java.security.Principal> principals;
    descriptor: Ljava/util/Set;
    flags: (0x0000) 
    Signature: Ljava/util/Set<Ljava/security/Principal;>;

  transient java.util.Set<java.lang.Object> pubCredentials;
    descriptor: Ljava/util/Set;
    flags: (0x0080) ACC_TRANSIENT
    Signature: Ljava/util/Set<Ljava/lang/Object;>;

  transient java.util.Set<java.lang.Object> privCredentials;
    descriptor: Ljava/util/Set;
    flags: (0x0080) ACC_TRANSIENT
    Signature: Ljava/util/Set<Ljava/lang/Object;>;

  private volatile boolean readOnly;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private static final int PRINCIPAL_SET;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  private static final int PUB_CREDENTIAL_SET;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  private static final int PRIV_CREDENTIAL_SET;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  private static final java.security.ProtectionDomain[] NULL_PD_ARRAY;
    descriptor: [Ljava/security/ProtectionDomain;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 136
            iconst_0
            anewarray java.security.ProtectionDomain
         1: .line 135
            putstatic javax.security.auth.Subject.NULL_PD_ARRAY:[Ljava/security/ProtectionDomain;
         2: .line 136
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 157
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 159
            aload 0 /* this */
         2: .line 160
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_1
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
         3: .line 159
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.principals:Ljava/util/Set;
         4: .line 161
            aload 0 /* this */
         5: .line 162
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_2
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
         6: .line 161
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
         7: .line 163
            aload 0 /* this */
         8: .line 164
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_3
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
         9: .line 163
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
        10: .line 165
            return
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Ljavax/security/auth/Subject;

  public void <init>(boolean, java.util.Set<? extends java.security.Principal>, java.util.Set<?>, java.util.Set<?>);
    descriptor: (ZLjava/util/Set;Ljava/util/Set;Ljava/util/Set;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=5
        start local 0 // javax.security.auth.Subject this
        start local 1 // boolean readOnly
        start local 2 // java.util.Set principals
        start local 3 // java.util.Set pubCredentials
        start local 4 // java.util.Set privCredentials
         0: .line 205
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 208
            aload 2 /* principals */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)Ljava/util/LinkedList;
         2: .line 207
            astore 5 /* principalList */
        start local 5 // java.util.LinkedList principalList
         3: .line 210
            aload 3 /* pubCredentials */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)Ljava/util/LinkedList;
         4: .line 209
            astore 6 /* pubCredsList */
        start local 6 // java.util.LinkedList pubCredsList
         5: .line 212
            aload 4 /* privCredentials */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)Ljava/util/LinkedList;
         6: .line 211
            astore 7 /* privCredsList */
        start local 7 // java.util.LinkedList privCredsList
         7: .line 214
            aload 0 /* this */
         8: .line 215
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_1
            aload 5 /* principalList */
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;ILjava/util/LinkedList;)V
         9: .line 214
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.principals:Ljava/util/Set;
        10: .line 216
            aload 0 /* this */
        11: .line 217
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_2
            aload 6 /* pubCredsList */
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;ILjava/util/LinkedList;)V
        12: .line 216
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
        13: .line 218
            aload 0 /* this */
        14: .line 219
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_3
            aload 7 /* privCredsList */
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;ILjava/util/LinkedList;)V
        15: .line 218
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
        16: .line 220
            aload 0 /* this */
            iload 1 /* readOnly */
            putfield javax.security.auth.Subject.readOnly:Z
        17: .line 221
            return
        end local 7 // java.util.LinkedList privCredsList
        end local 6 // java.util.LinkedList pubCredsList
        end local 5 // java.util.LinkedList principalList
        end local 4 // java.util.Set privCredentials
        end local 3 // java.util.Set pubCredentials
        end local 2 // java.util.Set principals
        end local 1 // boolean readOnly
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   18     0             this  Ljavax/security/auth/Subject;
            0   18     1         readOnly  Z
            0   18     2       principals  Ljava/util/Set<+Ljava/security/Principal;>;
            0   18     3   pubCredentials  Ljava/util/Set<*>;
            0   18     4  privCredentials  Ljava/util/Set<*>;
            3   18     5    principalList  Ljava/util/LinkedList<Ljava/security/Principal;>;
            5   18     6     pubCredsList  Ljava/util/LinkedList<Ljava/lang/Object;>;
            7   18     7    privCredsList  Ljava/util/LinkedList<Ljava/lang/Object;>;
    Signature: (ZLjava/util/Set<+Ljava/security/Principal;>;Ljava/util/Set<*>;Ljava/util/Set<*>;)V
    MethodParameters:
                 Name  Flags
      readOnly         
      principals       
      pubCredentials   
      privCredentials  

  public void setReadOnly();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 245
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* sm */
        start local 1 // java.lang.SecurityManager sm
         1: .line 246
            aload 1 /* sm */
            ifnull 3
         2: .line 247
            aload 1 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.SET_READ_ONLY_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 250
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield javax.security.auth.Subject.readOnly:Z
         4: .line 251
            return
        end local 1 // java.lang.SecurityManager sm
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljavax/security/auth/Subject;
            1    5     1    sm  Ljava/lang/SecurityManager;

  public boolean isReadOnly();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 259
            aload 0 /* this */
            getfield javax.security.auth.Subject.readOnly:Z
            ireturn
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject;

  public static javax.security.auth.Subject getSubject(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.security.AccessControlContext acc
         0: .line 290
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 1 /* sm */
        start local 1 // java.lang.SecurityManager sm
         1: .line 291
            aload 1 /* sm */
            ifnull 3
         2: .line 292
            aload 1 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.GET_SUBJECT_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 295
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 0 /* acc */
         4: .line 296
            ldc "invalid.null.AccessControlContext.provided"
         5: .line 295
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 300
            new javax.security.auth.Subject$1
            dup
            aload 0 /* acc */
            invokespecial javax.security.auth.Subject$1.<init>:(Ljava/security/AccessControlContext;)V
         7: .line 299
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast javax.security.auth.Subject
            areturn
        end local 1 // java.lang.SecurityManager sm
        end local 0 // java.security.AccessControlContext acc
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0   acc  Ljava/security/AccessControlContext;
            1    8     1    sm  Ljava/lang/SecurityManager;
    MethodParameters:
      Name  Flags
      acc   final

  public static <T> T doAs(javax.security.auth.Subject, java.security.PrivilegedAction<T>);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/PrivilegedAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.security.PrivilegedAction action
         0: .line 351
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 2 /* sm */
        start local 2 // java.lang.SecurityManager sm
         1: .line 352
            aload 2 /* sm */
            ifnull 3
         2: .line 353
            aload 2 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.DO_AS_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 356
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 1 /* action */
         4: .line 357
            ldc "invalid.null.action.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 356
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 361
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* currentAcc */
        start local 3 // java.security.AccessControlContext currentAcc
         7: .line 365
            aload 1 /* action */
         8: .line 366
            aload 0 /* subject */
            aload 3 /* currentAcc */
            invokestatic javax.security.auth.Subject.createContext:(Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
         9: .line 364
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 3 // java.security.AccessControlContext currentAcc
        end local 2 // java.lang.SecurityManager sm
        end local 1 // java.security.PrivilegedAction action
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0     subject  Ljavax/security/auth/Subject;
            0   10     1      action  Ljava/security/PrivilegedAction<TT;>;
            1   10     2          sm  Ljava/lang/SecurityManager;
            7   10     3  currentAcc  Ljava/security/AccessControlContext;
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/security/PrivilegedAction<TT;>;)TT;
    MethodParameters:
         Name  Flags
      subject  final
      action   final

  public static <T> T doAs(javax.security.auth.Subject, java.security.PrivilegedExceptionAction<T>);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.security.PrivilegedExceptionAction action
         0: .line 414
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 2 /* sm */
        start local 2 // java.lang.SecurityManager sm
         1: .line 415
            aload 2 /* sm */
            ifnull 3
         2: .line 416
            aload 2 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.DO_AS_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 419
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 1 /* action */
         4: .line 420
            ldc "invalid.null.action.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 419
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 423
            invokestatic java.security.AccessController.getContext:()Ljava/security/AccessControlContext;
            astore 3 /* currentAcc */
        start local 3 // java.security.AccessControlContext currentAcc
         7: .line 427
            aload 1 /* action */
         8: .line 428
            aload 0 /* subject */
            aload 3 /* currentAcc */
            invokestatic javax.security.auth.Subject.createContext:(Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
         9: .line 426
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 3 // java.security.AccessControlContext currentAcc
        end local 2 // java.lang.SecurityManager sm
        end local 1 // java.security.PrivilegedExceptionAction action
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0     subject  Ljavax/security/auth/Subject;
            0   10     1      action  Ljava/security/PrivilegedExceptionAction<TT;>;
            1   10     2          sm  Ljava/lang/SecurityManager;
            7   10     3  currentAcc  Ljava/security/AccessControlContext;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/security/PrivilegedExceptionAction<TT;>;)TT;
    MethodParameters:
         Name  Flags
      subject  final
      action   final

  public static <T> T doAsPrivileged(javax.security.auth.Subject, java.security.PrivilegedAction<T>, java.security.AccessControlContext);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.security.PrivilegedAction action
        start local 2 // java.security.AccessControlContext acc
         0: .line 471
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 3 /* sm */
        start local 3 // java.lang.SecurityManager sm
         1: .line 472
            aload 3 /* sm */
            ifnull 3
         2: .line 473
            aload 3 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.DO_AS_PRIVILEGED_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 476
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 1 /* action */
         4: .line 477
            ldc "invalid.null.action.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 476
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 482
            aload 2 /* acc */
            ifnonnull 8
         7: .line 483
            new java.security.AccessControlContext
            dup
            getstatic javax.security.auth.Subject.NULL_PD_ARRAY:[Ljava/security/ProtectionDomain;
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;)V
            goto 9
         8: .line 484
      StackMap locals:
      StackMap stack:
            aload 2 /* acc */
         9: .line 481
      StackMap locals:
      StackMap stack: java.security.AccessControlContext
            astore 4 /* callerAcc */
        start local 4 // java.security.AccessControlContext callerAcc
        10: .line 488
            aload 1 /* action */
        11: .line 489
            aload 0 /* subject */
            aload 4 /* callerAcc */
            invokestatic javax.security.auth.Subject.createContext:(Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
        12: .line 487
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 4 // java.security.AccessControlContext callerAcc
        end local 3 // java.lang.SecurityManager sm
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.security.PrivilegedAction action
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0    subject  Ljavax/security/auth/Subject;
            0   13     1     action  Ljava/security/PrivilegedAction<TT;>;
            0   13     2        acc  Ljava/security/AccessControlContext;
            1   13     3         sm  Ljava/lang/SecurityManager;
           10   13     4  callerAcc  Ljava/security/AccessControlContext;
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/security/PrivilegedAction<TT;>;Ljava/security/AccessControlContext;)TT;
    MethodParameters:
         Name  Flags
      subject  final
      action   final
      acc      final

  public static <T> T doAsPrivileged(javax.security.auth.Subject, java.security.PrivilegedExceptionAction<T>, java.security.AccessControlContext);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=5, args_size=3
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.security.PrivilegedExceptionAction action
        start local 2 // java.security.AccessControlContext acc
         0: .line 538
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 3 /* sm */
        start local 3 // java.lang.SecurityManager sm
         1: .line 539
            aload 3 /* sm */
            ifnull 3
         2: .line 540
            aload 3 /* sm */
            getstatic javax.security.auth.Subject$AuthPermissionHolder.DO_AS_PRIVILEGED_PERMISSION:Ljavax/security/auth/AuthPermission;
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;)V
         3: .line 543
      StackMap locals: java.lang.SecurityManager
      StackMap stack:
            aload 1 /* action */
         4: .line 544
            ldc "invalid.null.action.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 543
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 548
            aload 2 /* acc */
            ifnonnull 8
         7: .line 549
            new java.security.AccessControlContext
            dup
            getstatic javax.security.auth.Subject.NULL_PD_ARRAY:[Ljava/security/ProtectionDomain;
            invokespecial java.security.AccessControlContext.<init>:([Ljava/security/ProtectionDomain;)V
            goto 9
         8: .line 550
      StackMap locals:
      StackMap stack:
            aload 2 /* acc */
         9: .line 547
      StackMap locals:
      StackMap stack: java.security.AccessControlContext
            astore 4 /* callerAcc */
        start local 4 // java.security.AccessControlContext callerAcc
        10: .line 554
            aload 1 /* action */
        11: .line 555
            aload 0 /* subject */
            aload 4 /* callerAcc */
            invokestatic javax.security.auth.Subject.createContext:(Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
        12: .line 553
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;Ljava/security/AccessControlContext;)Ljava/lang/Object;
            areturn
        end local 4 // java.security.AccessControlContext callerAcc
        end local 3 // java.lang.SecurityManager sm
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.security.PrivilegedExceptionAction action
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0    subject  Ljavax/security/auth/Subject;
            0   13     1     action  Ljava/security/PrivilegedExceptionAction<TT;>;
            0   13     2        acc  Ljava/security/AccessControlContext;
            1   13     3         sm  Ljava/lang/SecurityManager;
           10   13     4  callerAcc  Ljava/security/AccessControlContext;
    Exceptions:
      throws java.security.PrivilegedActionException
    Signature: <T:Ljava/lang/Object;>(Ljavax/security/auth/Subject;Ljava/security/PrivilegedExceptionAction<TT;>;Ljava/security/AccessControlContext;)TT;
    MethodParameters:
         Name  Flags
      subject  final
      action   final
      acc      final

  private static java.security.AccessControlContext createContext(javax.security.auth.Subject, java.security.AccessControlContext);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)Ljava/security/AccessControlContext;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // javax.security.auth.Subject subject
        start local 1 // java.security.AccessControlContext acc
         0: .line 563
            new javax.security.auth.Subject$2
            dup
            aload 0 /* subject */
            aload 1 /* acc */
            invokespecial javax.security.auth.Subject$2.<init>:(Ljavax/security/auth/Subject;Ljava/security/AccessControlContext;)V
         1: .line 562
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.security.AccessControlContext
            areturn
        end local 1 // java.security.AccessControlContext acc
        end local 0 // javax.security.auth.Subject subject
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0  subject  Ljavax/security/auth/Subject;
            0    2     1      acc  Ljava/security/AccessControlContext;
    MethodParameters:
         Name  Flags
      subject  final
      acc      final

  public java.util.Set<java.security.Principal> getPrincipals();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 598
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            areturn
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject;
    Signature: ()Ljava/util/Set<Ljava/security/Principal;>;

  public <T extends java.security.Principal> java.util.Set<T> getPrincipals(java.lang.Class<T>);
    descriptor: (Ljava/lang/Class;)Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.lang.Class c
         0: .line 625
            aload 1 /* c */
         1: .line 626
            ldc "invalid.null.Class.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 625
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 630
            new javax.security.auth.Subject$ClassSet
            dup
            aload 0 /* this */
            iconst_1
            aload 1 /* c */
            invokespecial javax.security.auth.Subject$ClassSet.<init>:(Ljavax/security/auth/Subject;ILjava/lang/Class;)V
            areturn
        end local 1 // java.lang.Class c
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljavax/security/auth/Subject;
            0    4     1     c  Ljava/lang/Class<TT;>;
    Signature: <T::Ljava/security/Principal;>(Ljava/lang/Class<TT;>;)Ljava/util/Set<TT;>;
    MethodParameters:
      Name  Flags
      c     

  public java.util.Set<java.lang.Object> getPublicCredentials();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 654
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            areturn
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject;
    Signature: ()Ljava/util/Set<Ljava/lang/Object;>;

  public java.util.Set<java.lang.Object> getPrivateCredentials();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 692
            aload 0 /* this */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            areturn
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject;
    Signature: ()Ljava/util/Set<Ljava/lang/Object;>;

  public <T> java.util.Set<T> getPublicCredentials(java.lang.Class<T>);
    descriptor: (Ljava/lang/Class;)Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.lang.Class c
         0: .line 719
            aload 1 /* c */
         1: .line 720
            ldc "invalid.null.Class.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 719
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 724
            new javax.security.auth.Subject$ClassSet
            dup
            aload 0 /* this */
            iconst_2
            aload 1 /* c */
            invokespecial javax.security.auth.Subject$ClassSet.<init>:(Ljavax/security/auth/Subject;ILjava/lang/Class;)V
            areturn
        end local 1 // java.lang.Class c
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljavax/security/auth/Subject;
            0    4     1     c  Ljava/lang/Class<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljava/lang/Class<TT;>;)Ljava/util/Set<TT;>;
    MethodParameters:
      Name  Flags
      c     

  public <T> java.util.Set<T> getPrivateCredentials(java.lang.Class<T>);
    descriptor: (Ljava/lang/Class;)Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.lang.Class c
         0: .line 763
            aload 1 /* c */
         1: .line 764
            ldc "invalid.null.Class.provided"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 763
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 768
            new javax.security.auth.Subject$ClassSet
            dup
            aload 0 /* this */
            iconst_3
            aload 1 /* c */
            invokespecial javax.security.auth.Subject$ClassSet.<init>:(Ljavax/security/auth/Subject;ILjava/lang/Class;)V
            areturn
        end local 1 // java.lang.Class c
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljavax/security/auth/Subject;
            0    4     1     c  Ljava/lang/Class<TT;>;
    Signature: <T:Ljava/lang/Object;>(Ljava/lang/Class<TT;>;)Ljava/util/Set<TT;>;
    MethodParameters:
      Name  Flags
      c     

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.lang.Object o
         0: .line 793
            aload 1 /* o */
            ifnonnull 2
         1: .line 794
            iconst_0
            ireturn
         2: .line 797
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* o */
            if_acmpne 4
         3: .line 798
            iconst_1
            ireturn
         4: .line 801
      StackMap locals:
      StackMap stack:
            aload 1 /* o */
            instanceof javax.security.auth.Subject
            ifeq 31
         5: .line 803
            aload 1 /* o */
            checkcast javax.security.auth.Subject
            astore 2 /* that */
        start local 2 // javax.security.auth.Subject that
         6: .line 807
            aload 2 /* that */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            dup
            astore 4
            monitorenter
         7: .line 809
            new java.util.HashSet
            dup
            aload 2 /* that */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 3 /* thatPrincipals */
        start local 3 // java.util.Set thatPrincipals
         8: .line 807
            aload 4
            monitorexit
         9: goto 12
        end local 3 // java.util.Set thatPrincipals
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject top java.util.Set
      StackMap stack: java.lang.Throwable
        10: aload 4
            monitorexit
        11: athrow
        start local 3 // java.util.Set thatPrincipals
        12: .line 811
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            aload 3 /* thatPrincipals */
            invokeinterface java.util.Set.equals:(Ljava/lang/Object;)Z
            ifne 14
        13: .line 812
            iconst_0
            ireturn
        14: .line 816
      StackMap locals:
      StackMap stack:
            aload 2 /* that */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            dup
            astore 5
            monitorenter
        15: .line 818
            new java.util.HashSet
            dup
            aload 2 /* that */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 4 /* thatPubCredentials */
        start local 4 // java.util.Set thatPubCredentials
        16: .line 816
            aload 5
            monitorexit
        17: goto 20
        end local 4 // java.util.Set thatPubCredentials
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject java.util.Set top java.util.Set
      StackMap stack: java.lang.Throwable
        18: aload 5
            monitorexit
        19: athrow
        start local 4 // java.util.Set thatPubCredentials
        20: .line 820
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject java.util.Set java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            aload 4 /* thatPubCredentials */
            invokeinterface java.util.Set.equals:(Ljava/lang/Object;)Z
            ifne 22
        21: .line 821
            iconst_0
            ireturn
        22: .line 825
      StackMap locals:
      StackMap stack:
            aload 2 /* that */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            dup
            astore 6
            monitorenter
        23: .line 827
            new java.util.HashSet
            dup
            aload 2 /* that */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 5 /* thatPrivCredentials */
        start local 5 // java.util.Set thatPrivCredentials
        24: .line 825
            aload 6
            monitorexit
        25: goto 28
        end local 5 // java.util.Set thatPrivCredentials
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject java.util.Set java.util.Set top java.util.Set
      StackMap stack: java.lang.Throwable
        26: aload 6
            monitorexit
        27: athrow
        start local 5 // java.util.Set thatPrivCredentials
        28: .line 829
      StackMap locals: javax.security.auth.Subject java.lang.Object javax.security.auth.Subject java.util.Set java.util.Set java.util.Set
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            aload 5 /* thatPrivCredentials */
            invokeinterface java.util.Set.equals:(Ljava/lang/Object;)Z
            ifne 30
        29: .line 830
            iconst_0
            ireturn
        30: .line 832
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
        end local 5 // java.util.Set thatPrivCredentials
        end local 4 // java.util.Set thatPubCredentials
        end local 3 // java.util.Set thatPrincipals
        end local 2 // javax.security.auth.Subject that
        31: .line 834
      StackMap locals: javax.security.auth.Subject java.lang.Object
      StackMap stack:
            iconst_0
            ireturn
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   32     0                 this  Ljavax/security/auth/Subject;
            0   32     1                    o  Ljava/lang/Object;
            6   31     2                 that  Ljavax/security/auth/Subject;
            8   10     3       thatPrincipals  Ljava/util/Set<Ljava/security/Principal;>;
           12   31     3       thatPrincipals  Ljava/util/Set<Ljava/security/Principal;>;
           16   18     4   thatPubCredentials  Ljava/util/Set<Ljava/lang/Object;>;
           20   31     4   thatPubCredentials  Ljava/util/Set<Ljava/lang/Object;>;
           24   26     5  thatPrivCredentials  Ljava/util/Set<Ljava/lang/Object;>;
           28   31     5  thatPrivCredentials  Ljava/util/Set<Ljava/lang/Object;>;
      Exception table:
        from    to  target  type
           7     9      10  any
          10    11      10  any
          15    17      18  any
          18    19      18  any
          23    25      26  any
          26    27      26  any
    MethodParameters:
      Name  Flags
      o     

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 844
            aload 0 /* this */
            iconst_1
            invokevirtual javax.security.auth.Subject.toString:(Z)Ljava/lang/String;
            areturn
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/security/auth/Subject;

  java.lang.String toString(boolean);
    descriptor: (Z)Ljava/lang/String;
    flags: (0x0000) 
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // boolean includePrivateCredentials
         0: .line 854
            ldc "Subject."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* s */
        start local 2 // java.lang.String s
         1: .line 855
            ldc ""
            astore 3 /* suffix */
        start local 3 // java.lang.String suffix
         2: .line 857
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            dup
            astore 4
            monitorenter
         3: .line 858
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5 /* pI */
        start local 5 // java.util.Iterator pI
         4: .line 859
            goto 9
         5: .line 860
      StackMap locals: javax.security.auth.Subject int java.lang.String java.lang.String java.util.Set java.util.Iterator
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Principal
            astore 6 /* p */
        start local 6 // java.security.Principal p
         6: .line 861
            new java.lang.StringBuilder
            dup
            aload 3 /* suffix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc ".Principal."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 862
            aload 6 /* p */
            invokeinterface java.security.Principal.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "NEWLINE"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         8: .line 861
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* suffix */
        end local 6 // java.security.Principal p
         9: .line 859
      StackMap locals:
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        end local 5 // java.util.Iterator pI
        10: .line 857
            aload 4
            monitorexit
        11: goto 14
      StackMap locals: javax.security.auth.Subject int java.lang.String java.lang.String java.util.Set
      StackMap stack: java.lang.Throwable
        12: aload 4
            monitorexit
        13: athrow
        14: .line 866
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            dup
            astore 4
            monitorenter
        15: .line 867
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5 /* pI */
        start local 5 // java.util.Iterator pI
        16: .line 868
            goto 22
        17: .line 869
      StackMap locals: java.util.Set java.util.Iterator
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* o */
        start local 6 // java.lang.Object o
        18: .line 870
            new java.lang.StringBuilder
            dup
            aload 3 /* suffix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        19: .line 871
            ldc ".Public.Credential."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        20: .line 872
            aload 6 /* o */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "NEWLINE"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        21: .line 870
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* suffix */
        end local 6 // java.lang.Object o
        22: .line 868
      StackMap locals:
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 17
        end local 5 // java.util.Iterator pI
        23: .line 866
            aload 4
            monitorexit
        24: goto 27
      StackMap locals: javax.security.auth.Subject int java.lang.String java.lang.String java.util.Set
      StackMap stack: java.lang.Throwable
        25: aload 4
            monitorexit
        26: athrow
        27: .line 876
      StackMap locals:
      StackMap stack:
            iload 1 /* includePrivateCredentials */
            ifeq 49
        28: .line 877
            aload 0 /* this */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            dup
            astore 4
            monitorenter
        29: .line 878
            aload 0 /* this */
            getfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 5 /* pI */
        start local 5 // java.util.Iterator pI
        30: .line 879
            goto 44
        31: .line 881
      StackMap locals: java.util.Set java.util.Iterator
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* o */
        start local 6 // java.lang.Object o
        32: .line 882
            new java.lang.StringBuilder
            dup
            aload 3 /* suffix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        33: .line 883
            ldc ".Private.Credential."
        34: .line 882
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        35: .line 884
            aload 6 /* o */
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        36: .line 885
            ldc "NEWLINE"
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        37: .line 882
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* suffix */
        end local 6 // java.lang.Object o
        38: .line 886
            goto 44
      StackMap locals:
      StackMap stack: java.lang.SecurityException
        39: pop
        40: .line 887
            new java.lang.StringBuilder
            dup
            aload 3 /* suffix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        41: .line 888
            ldc ".Private.Credential.inaccessible."
        42: .line 887
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 3 /* suffix */
        43: .line 889
            goto 45
        44: .line 879
      StackMap locals:
      StackMap stack:
            aload 5 /* pI */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 31
        end local 5 // java.util.Iterator pI
        45: .line 877
      StackMap locals:
      StackMap stack:
            aload 4
            monitorexit
        46: goto 49
      StackMap locals:
      StackMap stack: java.lang.Throwable
        47: aload 4
            monitorexit
        48: athrow
        49: .line 894
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            aload 2 /* s */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* suffix */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 3 // java.lang.String suffix
        end local 2 // java.lang.String s
        end local 1 // boolean includePrivateCredentials
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot                       Name  Signature
            0   50     0                       this  Ljavax/security/auth/Subject;
            0   50     1  includePrivateCredentials  Z
            1   50     2                          s  Ljava/lang/String;
            2   50     3                     suffix  Ljava/lang/String;
            4   10     5                         pI  Ljava/util/Iterator<Ljava/security/Principal;>;
            6    9     6                          p  Ljava/security/Principal;
           16   23     5                         pI  Ljava/util/Iterator<Ljava/lang/Object;>;
           18   22     6                          o  Ljava/lang/Object;
           30   45     5                         pI  Ljava/util/Iterator<Ljava/lang/Object;>;
           32   38     6                          o  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           3    11      12  any
          12    13      12  any
          15    24      25  any
          25    26      25  any
          31    38      39  Class java.lang.SecurityException
          29    46      47  any
          47    48      47  any
    MethodParameters:
                           Name  Flags
      includePrivateCredentials  

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=1
        start local 0 // javax.security.auth.Subject this
         0: .line 920
            iconst_0
            istore 1 /* hashCode */
        start local 1 // int hashCode
         1: .line 922
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            dup
            astore 2
            monitorenter
         2: .line 923
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3 /* pIterator */
        start local 3 // java.util.Iterator pIterator
         3: .line 924
            goto 6
         4: .line 925
      StackMap locals: int java.util.Set java.util.Iterator
      StackMap stack:
            aload 3 /* pIterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Principal
            astore 4 /* p */
        start local 4 // java.security.Principal p
         5: .line 926
            iload 1 /* hashCode */
            aload 4 /* p */
            invokeinterface java.security.Principal.hashCode:()I
            ixor
            istore 1 /* hashCode */
        end local 4 // java.security.Principal p
         6: .line 924
      StackMap locals:
      StackMap stack:
            aload 3 /* pIterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        end local 3 // java.util.Iterator pIterator
         7: .line 922
            aload 2
            monitorexit
         8: goto 11
      StackMap locals: javax.security.auth.Subject int java.util.Set
      StackMap stack: java.lang.Throwable
         9: aload 2
            monitorexit
        10: athrow
        11: .line 930
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            dup
            astore 2
            monitorenter
        12: .line 931
            aload 0 /* this */
            getfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3 /* pubCIterator */
        start local 3 // java.util.Iterator pubCIterator
        13: .line 932
            goto 15
        14: .line 933
      StackMap locals: java.util.Set java.util.Iterator
      StackMap stack:
            iload 1 /* hashCode */
            aload 0 /* this */
            aload 3 /* pubCIterator */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            invokevirtual javax.security.auth.Subject.getCredHashCode:(Ljava/lang/Object;)I
            ixor
            istore 1 /* hashCode */
        15: .line 932
      StackMap locals:
      StackMap stack:
            aload 3 /* pubCIterator */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        end local 3 // java.util.Iterator pubCIterator
        16: .line 930
            aload 2
            monitorexit
        17: goto 20
      StackMap locals: javax.security.auth.Subject int java.util.Set
      StackMap stack: java.lang.Throwable
        18: aload 2
            monitorexit
        19: athrow
        20: .line 936
      StackMap locals:
      StackMap stack:
            iload 1 /* hashCode */
            ireturn
        end local 1 // int hashCode
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   21     0          this  Ljavax/security/auth/Subject;
            1   21     1      hashCode  I
            3    7     3     pIterator  Ljava/util/Iterator<Ljava/security/Principal;>;
            5    6     4             p  Ljava/security/Principal;
           13   16     3  pubCIterator  Ljava/util/Iterator<Ljava/lang/Object;>;
      Exception table:
        from    to  target  type
           2     8       9  any
           9    10       9  any
          12    17      18  any
          18    19      18  any

  private int getCredHashCode(java.lang.Object);
    descriptor: (Ljava/lang/Object;)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.lang.Object o
         0: .line 944
            aload 1 /* o */
            invokevirtual java.lang.Object.hashCode:()I
         1: ireturn
         2: .line 945
      StackMap locals:
      StackMap stack: java.lang.IllegalStateException
            pop
         3: .line 946
            aload 1 /* o */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.hashCode:()I
            ireturn
        end local 1 // java.lang.Object o
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljavax/security/auth/Subject;
            0    4     1     o  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           0     1       2  Class java.lang.IllegalStateException
    MethodParameters:
      Name  Flags
      o     

  private void writeObject(java.io.ObjectOutputStream);
    descriptor: (Ljava/io/ObjectOutputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.io.ObjectOutputStream oos
         0: .line 956
            aload 0 /* this */
            getfield javax.security.auth.Subject.principals:Ljava/util/Set;
            dup
            astore 2
            monitorenter
         1: .line 957
            aload 1 /* oos */
            invokevirtual java.io.ObjectOutputStream.defaultWriteObject:()V
         2: .line 956
            aload 2
            monitorexit
         3: goto 6
      StackMap locals: javax.security.auth.Subject java.io.ObjectOutputStream java.util.Set
      StackMap stack: java.lang.Throwable
         4: aload 2
            monitorexit
         5: athrow
         6: .line 959
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.ObjectOutputStream oos
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Ljavax/security/auth/Subject;
            0    7     1   oos  Ljava/io/ObjectOutputStream;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      oos   

  private void readObject(java.io.ObjectInputStream);
    descriptor: (Ljava/io/ObjectInputStream;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // javax.security.auth.Subject this
        start local 1 // java.io.ObjectInputStream s
         0: .line 969
            aload 1 /* s */
            invokevirtual java.io.ObjectInputStream.readFields:()Ljava/io/ObjectInputStream$GetField;
            astore 2 /* gf */
        start local 2 // java.io.ObjectInputStream$GetField gf
         1: .line 971
            aload 0 /* this */
            aload 2 /* gf */
            ldc "readOnly"
            iconst_0
            invokevirtual java.io.ObjectInputStream$GetField.get:(Ljava/lang/String;Z)Z
            putfield javax.security.auth.Subject.readOnly:Z
         2: .line 973
            aload 2 /* gf */
            ldc "principals"
            aconst_null
            invokevirtual java.io.ObjectInputStream$GetField.get:(Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Set
            astore 3 /* inputPrincs */
        start local 3 // java.util.Set inputPrincs
         3: .line 975
            aload 3 /* inputPrincs */
         4: .line 976
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         5: .line 975
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         6: .line 980
            aload 3 /* inputPrincs */
            invokestatic javax.security.auth.Subject.collectionNullClean:(Ljava/util/Collection;)Ljava/util/LinkedList;
            astore 4 /* principalList */
        start local 4 // java.util.LinkedList principalList
         7: .line 981
            aload 0 /* this */
            new javax.security.auth.Subject$SecureSet
            dup
         8: .line 982
            aload 0 /* this */
            iconst_1
            aload 4 /* principalList */
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;ILjava/util/LinkedList;)V
         9: .line 981
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.principals:Ljava/util/Set;
        end local 4 // java.util.LinkedList principalList
        10: .line 983
            goto 15
      StackMap locals: javax.security.auth.Subject java.io.ObjectInputStream java.io.ObjectInputStream$GetField java.util.Set
      StackMap stack: java.lang.NullPointerException
        11: pop
        12: .line 986
            aload 0 /* this */
        13: .line 987
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_1
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
        14: .line 986
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.principals:Ljava/util/Set;
        15: .line 992
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
        16: .line 993
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_2
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
        17: .line 992
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.pubCredentials:Ljava/util/Set;
        18: .line 994
            aload 0 /* this */
        19: .line 995
            new javax.security.auth.Subject$SecureSet
            dup
            aload 0 /* this */
            iconst_3
            invokespecial javax.security.auth.Subject$SecureSet.<init>:(Ljavax/security/auth/Subject;I)V
        20: .line 994
            invokestatic java.util.Collections.synchronizedSet:(Ljava/util/Set;)Ljava/util/Set;
            putfield javax.security.auth.Subject.privCredentials:Ljava/util/Set;
        21: .line 996
            return
        end local 3 // java.util.Set inputPrincs
        end local 2 // java.io.ObjectInputStream$GetField gf
        end local 1 // java.io.ObjectInputStream s
        end local 0 // javax.security.auth.Subject this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   22     0           this  Ljavax/security/auth/Subject;
            0   22     1              s  Ljava/io/ObjectInputStream;
            1   22     2             gf  Ljava/io/ObjectInputStream$GetField;
            3   22     3    inputPrincs  Ljava/util/Set<Ljava/security/Principal;>;
            7   10     4  principalList  Ljava/util/LinkedList<Ljava/security/Principal;>;
      Exception table:
        from    to  target  type
           6    10      11  Class java.lang.NullPointerException
    Exceptions:
      throws java.io.IOException, java.lang.ClassNotFoundException
    MethodParameters:
      Name  Flags
      s     

  private static <E> java.util.LinkedList<E> collectionNullClean(java.util.Collection<? extends E>);
    descriptor: (Ljava/util/Collection;)Ljava/util/LinkedList;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=4, args_size=1
        start local 0 // java.util.Collection coll
         0: .line 1010
            aload 0 /* coll */
         1: .line 1011
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         2: .line 1010
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         3: .line 1013
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 1 /* output */
        start local 1 // java.util.LinkedList output
         4: .line 1014
            aload 0 /* coll */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 9
      StackMap locals: java.util.Collection java.util.LinkedList top java.util.Iterator
      StackMap stack:
         5: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 2 /* e */
        start local 2 // java.lang.Object e
         6: .line 1015
            aload 1 /* output */
            aload 2 /* e */
         7: .line 1016
            ldc "invalid.null.input.s."
            invokestatic sun.security.util.ResourcesMgr.getString:(Ljava/lang/String;)Ljava/lang/String;
         8: .line 1015
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            invokevirtual java.util.LinkedList.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // java.lang.Object e
         9: .line 1014
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        10: .line 1018
            aload 1 /* output */
            areturn
        end local 1 // java.util.LinkedList output
        end local 0 // java.util.Collection coll
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   11     0    coll  Ljava/util/Collection<+TE;>;
            4   11     1  output  Ljava/util/LinkedList<TE;>;
            6    9     2       e  TE;
    Signature: <E:Ljava/lang/Object;>(Ljava/util/Collection<+TE;>;)Ljava/util/LinkedList<TE;>;
    MethodParameters:
      Name  Flags
      coll  
}
SourceFile: "Subject.java"
NestMembers:
  javax.security.auth.Subject$1  javax.security.auth.Subject$2  javax.security.auth.Subject$AuthPermissionHolder  javax.security.auth.Subject$ClassSet  javax.security.auth.Subject$ClassSet$1  javax.security.auth.Subject$SecureSet  javax.security.auth.Subject$SecureSet$1  javax.security.auth.Subject$SecureSet$2  javax.security.auth.Subject$SecureSet$3  javax.security.auth.Subject$SecureSet$4  javax.security.auth.Subject$SecureSet$5  javax.security.auth.Subject$SecureSet$6
InnerClasses:
  public abstract GetField = java.io.ObjectInputStream$GetField of java.io.ObjectInputStream
  javax.security.auth.Subject$1
  javax.security.auth.Subject$2
  final AuthPermissionHolder = javax.security.auth.Subject$AuthPermissionHolder of javax.security.auth.Subject
  private ClassSet = javax.security.auth.Subject$ClassSet of javax.security.auth.Subject
  private SecureSet = javax.security.auth.Subject$SecureSet of javax.security.auth.Subject