【转】netty4.1.32 pipeline的添加顺序和执行顺序

原文:https://www.cnblogs.com/ruber/p/10186571.html

本文只想讨论一下pipeline的执行顺序问题,因为这个搞不明白就不知道先添加编码还是解码,是不是可以混淆添加等等一系列事情

1         pipeline.addLast(new outboundsHandler1()); //out1
2         pipeline.addLast(new outboundsHandler2()); //out2
3
4         pipeline.addLast(new InboundsHandler1()); //in1
5         pipeline.addLast(new InboundsHandler2()); //in2
6         pipeline.addLast("handler", new HelloServerHandler());//in3

先说最基本的, 读入数据,需要解码数据,执行顺序和注册顺序一致 in1 --> in2 -->in3 他们之间通过 ctx.fireChannelRead(msg);进行传递

解码完成,逻辑处理,进行数据发送 通过 ctx.writeAndFlush()就完成从in -->out的转换

out的执行顺是和注册顺序相反的,也就是out2 -->out1这么个顺序 out间的传递通过ctx.writeAndFlush();函数进行传递

ctx.channel().writeAndFlush()  和 ctx.writeAndFlush() 区别

网上说注册 outhandler的时候,必须放到最后一个inhandler前面(本例就是in3前面),其实是不准确的 比如

1         pipeline.addLast(new InboundsHandler1()); //in1
2         pipeline.addLast(new InboundsHandler2()); //in2
3         pipeline.addLast("handler", new HelloServerHandler());//in3
4
5         pipeline.addLast(new outboundsHandler1()); //out1
6         pipeline.addLast(new outboundsHandler2()); //out2

比如我注册时out放后面,接收执行到in3时,执行ctx.writeAndFlush(),会发生什么呢,outhandler不调用,因为ctx.writeAndFlush()是从当前节点往前查找out类handler,而out节点注册在当前节点后边

这种情况要想让他执行outhandler的处理,应该执行ctx.channel().writeAndFlush();这是从链表结尾开始往前查找out类handler,这就是两种writeAndFlush的区别

网上这种说法是使用ctx.writeAndFlush()的一种使用方式而已,还是要根据情况深入理解!

out就是继承自ChannelOutboundHandlerAdapter的 通常可以用来编码

in就是继承自ChannelInboundHandlerAdapter的,通常用来解码

原文地址:https://www.cnblogs.com/tc310/p/11130925.html

时间: 2024-11-15 06:34:05

【转】netty4.1.32 pipeline的添加顺序和执行顺序的相关文章

SQL 中的语法顺序与执行顺序(转)

很多程序员都很抵触SQL.其实SQL是一整为数不多的声明性语言,只是它的运行方式完全不同于我们所熟知的命令行语言.面向对象的程序语言.甚至是函数语言. 今天大家共同学习下SQL的语法顺序与执行顺序.(入门级的.大神们可以直接点退出了哈.) SQL 是一种声明式语言 首先要把这个概念记在脑中:“声明”. SQL 语言是为计算机声明了一个你想从原始数据中获得什么样的结果的一个范例,而不是告诉计算机如何能够得到结果. SQL 语言声明的是结果集的属性,计算机会根据 SQL 所声明的内容来从数据库中挑选

程序顺序与执行顺序

这是两个不同的概念. 程序顺序指的是代码的先后顺序. 执行顺序可能受到重排序的影响,不一定和程序顺序保持一致,具有不确定性. 见: <单线程程序语义> <haappen before 规则> 原文地址:https://www.cnblogs.com/xmsx/p/9716583.html

MySQL语法顺序及执行顺序

一.书写顺序 1 select[distinct] 2 from 3 join 4 on 5 where 6 group by 7 having 8 union 9 order by 10 limit 二.执行顺序 1 from 2 on 3 join 4 where 5 group by (可以使用select中的别名,后面的语句中都可以使用) 6 having 7 select 8 distinct 9 union 10 order by 11 limit 以上每个步骤都会产生一个虚拟表,该

SQL 中的语法顺序与执行顺序

FROM : HOME SQL 是一种声明式语言 SQL 语言是为计算机声明了一个你想从原始数据中获得什么样的结果的一个范例,而不是告诉计算机如何能够得到结果. SQL 语言声明的是结果集的属性,计算机会根据 SQL 所声明的内容来从数据库中挑选出符合声明的数据,而不是像传统编程思维去指示计算机如何操作. SQL 语句的语法顺序是: SELECT[DISTINCT] FROM WHERE GROUP BY HAVING UNION ORDER BY 执行顺序为: FROM WHERE GROUP

SQL语句的执行顺序--知道执行顺序,顺便可以做优化了,对吧

今天,被面试问到了一个问题,SQL的执行顺序,当时想的是,SQL有啥执行顺序,从上往下?当时瞎胡邹,说先执行from,为啥,不执行from怎么知道操作查询的是什么表,对吧,哎嘿,还蒙对了.下来之后总结了一下 (一)先讲讲查询吧 查询语句中select from where group by having order by的执行顺序 1.查询中用到的关键词主要包含六个,并且他们的顺序依次为 select--from--where--group by--having--order by 其中sele

SQL的编写顺序和执行顺序,以及一些其他问题

SQL即结构化查询语言.也就是用来从数据库中操作数据的,增删改查CRUD. 一,sql的分类,大致有四类: 1)DDL : 数据定义语言 create alter drop truncate 2)DML : 数据操纵语言 insert update delete 3)DCL : 数据控制语言 安全 授权 grant revoke 4)DQL : 数据查询语言 select from子句 where子句 二,查询语句的结构 select [列名] [*] from 表名 [where 条件] [g

Unity脚本生命周期与执行顺序

文章目录 脚本生命周期 MonoBehavior生命周期图 脚本执行顺序 自定义执行顺序 在Unity中,脚本可以理解为附加在游戏对象上的用于定义游戏对象行为的指令代码.必须绑定在游戏对象上才能开始它的生命周期.游戏对象可以理解为能容纳各种组件的容器,游戏对象的所有组件一起决定了这个对象的行为和游戏中的表现. 脚本生命周期 Unity脚本中的常见必然事件如下表所示 名称 触发时机 用途 Awake 脚本实例被创建时调用 用于游戏对象的初始化,注意Awake的执行早于所有脚本的Start函数 On

Unity脚本在层级面板中的执行顺序测试2

上一篇测试了生成顺序对执行顺序的影响,链接:LINK 这篇主要测试一下Awake,OnEnable,Start三个常用消息的循环顺序 先上一个最简单的打印测试代码 void Awake() { Debug.Log("Awake" + name); } void OnEnable() { Debug.Log("OnEnable" + name); } void Start() { Debug.Log("Start" + name); } Print

Mysql 语句执行顺序

转载自:http://blog.csdn.net/jintao_ma/article/details/51253356 1.这样一个问题,作为一个开发人员需要掌握数据库的哪些东西?  在开发中涉及到数据库,基本上只用到了sql语句,如何写sql以及对其进行优化就比较重要,那些mysql的厚本书籍针对的是DBA,我们只需要学习其中的sql就可以了. 2.既然会写sql是目标,那么怎么才能写好sql.学习下面几点: 1)Mysql的执行顺序,这个是写sql的核心,之前遇到的一些错误就是因为对其不了解