public class io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase
  super_class: java.lang.Object
{
  protected final int messageSize;
    descriptor: I
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final java.net.SocketAddress myAddress;
    descriptor: Ljava/net/SocketAddress;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  protected final java.net.SocketAddress peerAddress;
    descriptor: Ljava/net/SocketAddress;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL

  public void <init>(int, java.net.SocketAddress, java.net.SocketAddress);
    descriptor: (ILjava/net/SocketAddress;Ljava/net/SocketAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase this
        start local 1 // int messageSize
        start local 2 // java.net.SocketAddress myAddress
        start local 3 // java.net.SocketAddress peerAddress
         0: .line 46
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 47
            aload 0 /* this */
            iload 1 /* messageSize */
            putfield io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase.messageSize:I
         2: .line 48
            aload 0 /* this */
            aload 2 /* myAddress */
            putfield io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase.myAddress:Ljava/net/SocketAddress;
         3: .line 49
            aload 0 /* this */
            aload 3 /* peerAddress */
            putfield io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase.peerAddress:Ljava/net/SocketAddress;
         4: .line 50
            return
        end local 3 // java.net.SocketAddress peerAddress
        end local 2 // java.net.SocketAddress myAddress
        end local 1 // int messageSize
        end local 0 // io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Lio/netty/example/udt/echo/rendezvousBytes/ByteEchoPeerBase;
            0    5     1  messageSize  I
            0    5     2    myAddress  Ljava/net/SocketAddress;
            0    5     3  peerAddress  Ljava/net/SocketAddress;
    MethodParameters:
             Name  Flags
      messageSize  
      myAddress    
      peerAddress  

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=1
        start local 0 // io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase this
         0: .line 53
            new io.netty.util.concurrent.DefaultThreadFactory
            dup
            ldc "rendezvous"
            invokespecial io.netty.util.concurrent.DefaultThreadFactory.<init>:(Ljava/lang/String;)V
            astore 1 /* connectFactory */
        start local 1 // java.util.concurrent.ThreadFactory connectFactory
         1: .line 54
            new io.netty.channel.nio.NioEventLoopGroup
            dup
            iconst_1
         2: .line 55
            aload 1 /* connectFactory */
            getstatic io.netty.channel.udt.nio.NioUdtProvider.BYTE_PROVIDER:Ljava/nio/channels/spi/SelectorProvider;
         3: .line 54
            invokespecial io.netty.channel.nio.NioEventLoopGroup.<init>:(ILjava/util/concurrent/ThreadFactory;Ljava/nio/channels/spi/SelectorProvider;)V
            astore 2 /* connectGroup */
        start local 2 // io.netty.channel.nio.NioEventLoopGroup connectGroup
         4: .line 57
            new io.netty.bootstrap.Bootstrap
            dup
            invokespecial io.netty.bootstrap.Bootstrap.<init>:()V
            astore 3 /* bootstrap */
        start local 3 // io.netty.bootstrap.Bootstrap bootstrap
         5: .line 58
            aload 3 /* bootstrap */
            aload 2 /* connectGroup */
            invokevirtual io.netty.bootstrap.Bootstrap.group:(Lio/netty/channel/EventLoopGroup;)Lio/netty/bootstrap/AbstractBootstrap;
            checkcast io.netty.bootstrap.Bootstrap
         6: .line 59
            getstatic io.netty.channel.udt.nio.NioUdtProvider.BYTE_RENDEZVOUS:Lio/netty/channel/ChannelFactory;
            invokevirtual io.netty.bootstrap.Bootstrap.channelFactory:(Lio/netty/channel/ChannelFactory;)Lio/netty/bootstrap/AbstractBootstrap;
            checkcast io.netty.bootstrap.Bootstrap
         7: .line 60
            new io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase$1
            dup
            aload 0 /* this */
            invokespecial io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase$1.<init>:(Lio/netty/example/udt/echo/rendezvousBytes/ByteEchoPeerBase;)V
            invokevirtual io.netty.bootstrap.Bootstrap.handler:(Lio/netty/channel/ChannelHandler;)Lio/netty/bootstrap/AbstractBootstrap;
            pop
         8: .line 68
            aload 3 /* bootstrap */
            aload 0 /* this */
            getfield io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase.peerAddress:Ljava/net/SocketAddress;
            aload 0 /* this */
            getfield io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase.myAddress:Ljava/net/SocketAddress;
            invokevirtual io.netty.bootstrap.Bootstrap.connect:(Ljava/net/SocketAddress;Ljava/net/SocketAddress;)Lio/netty/channel/ChannelFuture;
            invokeinterface io.netty.channel.ChannelFuture.sync:()Lio/netty/channel/ChannelFuture;
            astore 4 /* future */
        start local 4 // io.netty.channel.ChannelFuture future
         9: .line 69
            aload 4 /* future */
            invokeinterface io.netty.channel.ChannelFuture.channel:()Lio/netty/channel/Channel;
            invokeinterface io.netty.channel.Channel.closeFuture:()Lio/netty/channel/ChannelFuture;
            invokeinterface io.netty.channel.ChannelFuture.sync:()Lio/netty/channel/ChannelFuture;
            pop
        end local 4 // io.netty.channel.ChannelFuture future
        end local 3 // io.netty.bootstrap.Bootstrap bootstrap
        10: .line 70
            goto 14
      StackMap locals: io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase java.util.concurrent.ThreadFactory io.netty.channel.nio.NioEventLoopGroup
      StackMap stack: java.lang.Throwable
        11: astore 5
        12: .line 71
            aload 2 /* connectGroup */
            invokevirtual io.netty.channel.nio.NioEventLoopGroup.shutdownGracefully:()Lio/netty/util/concurrent/Future;
            pop
        13: .line 72
            aload 5
            athrow
        14: .line 71
      StackMap locals:
      StackMap stack:
            aload 2 /* connectGroup */
            invokevirtual io.netty.channel.nio.NioEventLoopGroup.shutdownGracefully:()Lio/netty/util/concurrent/Future;
            pop
        15: .line 73
            return
        end local 2 // io.netty.channel.nio.NioEventLoopGroup connectGroup
        end local 1 // java.util.concurrent.ThreadFactory connectFactory
        end local 0 // io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   16     0            this  Lio/netty/example/udt/echo/rendezvousBytes/ByteEchoPeerBase;
            1   16     1  connectFactory  Ljava/util/concurrent/ThreadFactory;
            4   16     2    connectGroup  Lio/netty/channel/nio/NioEventLoopGroup;
            5   10     3       bootstrap  Lio/netty/bootstrap/Bootstrap;
            9   10     4          future  Lio/netty/channel/ChannelFuture;
      Exception table:
        from    to  target  type
           4    11      11  any
    Exceptions:
      throws java.lang.Exception
}
SourceFile: "ByteEchoPeerBase.java"
NestMembers:
  io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase$1
InnerClasses:
  io.netty.example.udt.echo.rendezvousBytes.ByteEchoPeerBase$1