Netty客户端发送数据给服务器的两个通道(1)

EventLoopGroup group = new NioEventLoopGroup();// 设置的连接group。

Bootstrap bootstrap = new Bootstrap().group(group).option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 10000) // 超时时间。

.channel(NioSocketChannel.class).handler(new ChannelInitializer() {

@Override

public void initChannel(SocketChannel ch) throws Exception {

ch.pipeline().addLast(new JsonObjectDecoder());

ch.pipeline().addLast(new StringEncoder(CharsetUtil.UTF_8));// String解码。

ch.pipeline().addLast(new StringDecoder(CharsetUtil.UTF_8));// String解码。

ch.pipeline().addLast(new MyChannelHandlerAdapter());//

}

});

try {

System.out.println(“客户端连接服务器…”);

ChannelFuture channelFuture = bootstrap.connect(“127.0.0.1”, SERVER_PORT)

.addListener(new ChannelFutureListener() {

public void operationComplete(ChannelFuture future) throws Exception {

if (future.isSuccess()) {

// 第一种方法。

// Netty在这里发送数据。

// sendDataToServer(future.channel());

}

}

}).sync();

// 等待连接关闭。

channelFuture.channel().closeFuture().sync();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

  • 发送数据到服务器端。

  • @throws Exception

*/

private void sendDataToServer(Channel channel) throws Exception {

Date date = new Date(System.currentTimeMillis());

SimpleDateFormat sdf = new SimpleDateFormat(“MM-dd,HH:mm:ss:SSS”);

while (true) {

date.setTime(System.currentTimeMillis());

channel.writeAndFlush(“客户端@” + sdf.format(date));

System.out.println(“客户端发送数据:” + sdf.format(date));

Thread.sleep(1000);

}

}

private class MyChannelHandlerAdapter extends ChannelHandlerAdapter {

// 连接激活。

@Override

public void channelActive(ChannelHandlerContext ctx) throws Exception {

super.channelActive(ctx);

System.out.println(“channelActive:” + ctx.channel().remoteAddress());

// 第二种方法。

// 连接可用激活后,Netty开始往服务器端发送数据。

sendDataToServer(ctx.channel());

}

@Override

public void channelInactive(ChannelHandlerContext ctx) throws Exception {

super.channelInactive(ctx);

System.out.println(“channelInactive:” + ctx.channel().remoteAddress());

}

@Override

public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {

super.channelRead(ctx, msg);

}

@Override

public void channelReadComplete(ChannelHandlerContext ctx) throws Exception {

super.channelReadComplete(ctx);

System.out.println(ctx.channel().remoteAddress() + “读写完成”);

}

}

public static void main(String[] args) {

try {

new App();

} catch (Exception e) {

e.printStackTrace();

}

}

// 服务器端。演示作为服务器接受来自客户端的数据。

private class Server extends Thread {

private ServerSocket serverSocket;

public Server() throws Exception {

serverSocket = new ServerSocket(SERVER_PORT);

}

@Override

public void run() {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

[外链图片转存中…(img-tXM3SxdZ-1712291998153)]

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
Netty客户端中实现并发发送数据有多种方式,下面是其中两种常见的方式: 1. 使用线程池: - 创建一个线程池,例如`ExecutorService`。 - 在需要发送数据的地方,将发送逻辑封装成一个`Runnable`或`Callable`任务。 - 将任务提交给线程池执行,可以通过`execute()`方法提交`Runnable`任务,或者通过`submit()`方法提交`Callable`任务。 - 线程池会自动管理线程的创建和销毁,并发执行任务。 示例代码: ```java ExecutorService executorService = Executors.newFixedThreadPool(10); // 创建一个大小为10的线程池 // 循环发送数据 for (int i = 0; i < 10; i++) { final int index = i; executorService.execute(() -> { // 发送数据的逻辑 // ... System.out.println("Task " + index + " executed"); }); } executorService.shutdown(); // 关闭线程池 ``` 2. 使用Netty的EventLoopGroup: - 创建一个`NioEventLoopGroup`,它管理了一组NIO线程,用于处理I/O操作。 - 在需要发送数据的地方,通过调用`ChannelHandlerContext`的`writeAndFlush()`方法发送数据。 - 由于EventLoopGroup内部已经实现了并发处理,因此可以同时处理多个请求。 示例代码: ```java EventLoopGroup group = new NioEventLoopGroup(); try { Bootstrap bootstrap = new Bootstrap() .group(group) .channel(NioDatagramChannel.class) .handler(new ChannelInitializer<Channel>() { @Override protected void initChannel(Channel ch) throws Exception { // 添加处理器 } }); // 连接到服务器 Channel channel = bootstrap.connect(host, port).sync().channel(); // 循环发送数据 for (int i = 0; i < 10; i++) { channel.writeAndFlush(Unpooled.copiedBuffer("data", CharsetUtil.UTF_8)); } // 等待关闭连接 channel.closeFuture().sync(); } finally { group.shutdownGracefully(); } ``` 这两种方式都可以实现Netty客户端的并发发送数据,具体选择哪种方式取决于你的需求和场景。使用线程池可以更灵活地控制并发度,而使用EventLoopGroup则更符合Netty的设计思想。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值