链式处理器是一种常见的编程设计,Netty 是使用 Java 语言编写的一款异步事件驱动的网络应用程序框架,支持快速开发可维护的高性能的面向协议的服务器和客户端,Netty 中就有相似的链式处理器的设计。编程
Netty 能够使用相似的处理链对封包进行收发编码及处理,Netty 的开发者能够分为 3 种:第一种是 Netty 底层开发者;第二种是每一个处理环节的开发者;第三种是业务实现者。在实际开发环节中,后两种开发者每每是同一批开发者,链式处理的开发思想将数据和操做拆分、解耦,让开发者能够根据本身的技术优点和需求,进行系统开发,同时将本身的开发成果共享给其余的开发者。服务器
package main import ( "fmt" "strings" ) // 字符串处理函数,传入字符串切片和处理链 func StringProccess(list []string, chain []func(string) string) { // 遍历每个字符串 for index, str := range list { // 第一个须要处理的字符串 result := str // 遍历每个处理链 for _, proc := range chain { // 输入一个字符串进行处理,返回数据做为下一个处理链的输入。 result = proc(result) } // 将结果放回切片 list[index] = result } } // 自定义的移除前缀的处理函数 func removePrefix(str string) string { return strings.TrimPrefix(str, "go") } func main() { // 待处理的字符串列表 list := []string{ "go scanner", "go parser", "go compiler", "go printer", "go formater", } // 处理函数链 chain := []func(string) string{ removePrefix, strings.TrimSpace, strings.ToUpper, } // 处理字符串 StringProccess(list, chain) // 输出处理好的字符串 for _, str := range list { fmt.Println(str) } }