Java-二进制学习

常见进制

二进制∶和1
八进制︰后面说
十进制︰0 1 3 4 5 6 7 8
十六进制︰后面说

二进制十进制相互转换

十进制转二进制:除以2取余从下往上数

例如:
6/2=3...0
3/2=1...1
1/2=0...1
6的二进制110
10/2=5...0
5/2= 2...1
2/2= 1...0
1/2= 0...1
10的二进制是1010

二进制转十进制:根据权重相乘相加

例如:10的二进制是1010
1*2³+0*2²+1*2+0*2=10
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 Netty 的 ChannelHandler 将二进制流写入到 Netty 的通道中。具体来说,可以实现自定义的 ChannelInboundHandler,并在其中重写 channelRead() 方法。该方法会在每次有新数据到达时被调用,可以在其中处理二进制流数据。 示例代码如下: ``` public class BinaryStreamHandler extends ChannelInboundHandlerAdapter { @Override public void channelRead(ChannelHandlerContext ctx, Object msg) { ByteBuf in = (ByteBuf) msg; try { while (in.isReadable()) { System.out.print((char) in.readByte()); System.out.flush(); } } finally { ReferenceCountUtil.release(msg); } } } ``` 然后,你可以在创建 Netty 服务器或客户端的时候,将该 ChannelHandler 添加到 ChannelPipeline 中。这样,每次有数据到达时,channelRead() 方法就会被调用,从而处理二进制流数据。 需要注意的是,在使用完二进制流数据后,一定要调用 ByteBuf 的 release() 方法释放缓存。如果不进行释放,可能会导致内存泄漏。 ### 回答2: 在Java代码中将二进制流发送到Netty需要以下步骤: 1. 创建一个Netty的客户端或者服务器,并设置相关的配置,例如端口号和IP地址等。 2. 创建一个`ChannelPipeline`,它是Netty应用程序中处理输入和输出数据的处理器链。通过往`ChannelPipeline`中添加处理器,可以实现编码和解码、数据转换、以及其他自定义的业务逻辑等。 3. 在`ChannelPipeline`中添加编码器,用于将二进制流转换成可发送的消息。Netty提供了多个编码器,例如`LengthFieldPrepender`和`ObjectEncoder`等,可以根据自己的需求选择适合的编码器。 4. 将待发送的二进制流封装成消息对象,并将其写入`ChannelPipeline`中,以便通过网络发送。可以使用Netty提供的`ByteBuf`类来表示二进制数据,并添加到消息对象中。 5. 调用`Channel`的`writeAndFlush()`方法将消息对象发送出去。`writeAndFlush()`方法是一个异步操作,它会将消息写入底层的TCP缓冲区并发送出去,不会阻塞当前线程。 以下是一个简单的示例代码: ```java // 创建一个ByteBuf来表示二进制流数据 ByteBuf buffer = Unpooled.buffer(); // 向ByteBuf中写入二进制数据 buffer.writeBytes(data); // 创建一个消息对象,并将ByteBuf添加到消息对象中 Message message = new Message(); message.setData(buffer); // 将消息对象写入ChannelPipeline并发送 channel.writeAndFlush(message); ``` 在上述示例中,`data`是待发送的二进制流数据,`Message`是自定义的消息对象。将二进制数据封装成消息对象后,通过`channel.writeAndFlush()`方法将消息发送出去。 需要注意的是,在实际使用中,还需要根据业务需求处理接收到的数据和设置相应的异常处理逻辑。此外,还需要在应用程序退出时关闭Netty的客户端或服务器。 ### 回答3: 要将Java代码的二进制流发送到Netty中,可以按照以下步骤进行: 1. 创建一个新的Netty客户端或服务器端。 2. 在Netty中,使用`ByteBuf`作为二进制数据的容器。使用`ByteBuf`的`writeBytes()`方法将Java代码的二进制流写入到`ByteBuf`中。 3. 将`ByteBuf`发送给远程服务器或客户端。如果你是客户端,可以通过`Channel`的`writeAndFlush()`方法将`ByteBuf`发送给服务器。如果你是服务器,可以在接收到客户端连接的事件中,通过`ChannelHandlerContext`的`writeAndFlush()`方法将`ByteBuf`发送给客户端。 4. 在接收方,可以通过设置Netty的ChannelPipeline来处理接收到的数据。添加一个自定义的`ChannelInboundHandlerAdapter`,重写`channelRead()`方法来处理接收到的数据。 5. 在重写的`channelRead()`方法中,可以使用`ByteBuf`的`readBytes()`方法读取二进制数据。根据数据的格式和协议将二进制数据转换为需要的数据类型进行处理。 通过以上步骤,你就可以将Java代码的二进制流发送到Netty并进行处理了。请注意,在实际应用中,你可能需要根据具体的需求和协议来进行适当地定制和处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值