链式处理器是一种常见的编程设计,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)
   }

}