GoLang职责链模式代码实现介绍

 更新时间:2023年05月10日 11:23:26   作者:未来谁可知  
这篇文章主要介绍了GoLang职责链模式代码实现,职责链模式是一种常用的设计模式,可以提高代码的灵活性与可维护性,职责链模式将请求和处理分离,可以让请求在处理链中依次经过多个处理者,直到找到能够处理请求的处理者为止

1. 需求

实现一个工具能准确判断英雄能秒人的技能伤害!方便开挂时选择最优技能,直接秒人,有的英雄现如今只有三个技能,但也不排除之后重做会有四个技能,要求实现简单上手,易扩展!

技能 2 进来了
技能 2 满足条件释放 造成 9000 伤害
技能 3 进来了
技能 3 满足条件释放 造成 10000 伤害
2023/5/10 10:26:31 技能1,伤害7000有点低不太行啊!推荐你换其他技能
2023/5/10 10:26:31 技能1,伤害7000有点低不太行啊!推荐你换其他技能

职责: 判断能秒人的伤害技能

链:技能链

Golang实现职责链模式时候,因为没有继承的支持,使用链对象包涵职责的方式,即:

  • 链对象包含当前职责对象以及下一个职责链。
  • 职责对象提供接口表示是否能处理对应请求。
  • 职责对象提供处理函数处理相关职责。

2. 代码实现

1. manager.go

下面是先定义一个职责链管理器,来帮助每个对象判断它是否符合职责

package main
import "log"
// 职责链模式
type Manager interface {
	HaveKill(attack int) bool                         // 是否击杀
	HandleAttackRequest(skillId int, attack int) bool // 连招
}
// 连招
type SkillChain struct {
	Manager
	successor *SkillChain
}
func (r *SkillChain) SetSuccessor(m *SkillChain) {
	r.successor = m
}
func (r *SkillChain) HandleAttackRequest(skillId int, attack int) bool {
	// 伤害是否满足击杀
	if r.Manager.HaveKill(attack) {
		return r.Manager.HandleAttackRequest(skillId, attack) // 释放连招把并且播报
	}
	if r.successor != nil {
		log.Printf("技能%d,伤害%d有点低不太行啊!推荐你换其他技能\n", skillId, attack)
		return r.successor.HandleAttackRequest(skillId, attack)
	}
	return false
}
func (r *SkillChain) HaveKill(attack int) bool {
	return true
}

2. skill1_manager.go

给英雄技能一对象实现对应的职责

package main
import (
	"fmt"
)
const (
	Hp = 8000
	SkillOne =1
	SkillTwo =2
	SkillThree =3
)
type SkillOneManager struct {
}
func NewSkillOneManager() *SkillChain {
	return &SkillChain{
		Manager:&SkillOneManager{},
	}
}
func (s SkillOneManager) HaveKill(attack int) bool {
	return attack>Hp
}
func (s SkillOneManager) HandleAttackRequest(skillId int, attack int) bool {
	fmt.Printf("技能 %d 进来了\n",skillId)
	if skillId==SkillOne{
		fmt.Printf("技能 %d满足条件释放 造成 %d 伤害\n", skillId, attack)
		return true
	}
	fmt.Printf("技能 %d 满足条件释放 造成 %d 伤害\n", skillId, attack)
	return false
}

3. skill2_manager.go

package main
import (
	"fmt"
)
type SkillTwoManager struct {}
func NewSkillTwoManager() *SkillChain {
	return &SkillChain{
		Manager:&SkillTwoManager{},
	}
}
func (s SkillTwoManager) HaveKill(attack int) bool {
	return attack>Hp
}
func (s SkillTwoManager) HandleAttackRequest(skillId int, attack int) bool {
	if skillId==SkillTwo{
		fmt.Printf("技能 %d 满足条件释放 造成 %d 伤害\n", skillId, attack)
		return true
	}
	fmt.Printf("技能 %d不 满足条件释放 造成 %d 伤害\n", skillId, attack)
	return false
}

4. skill3_manager.go

package main
import (
	"fmt"
)
type SkillThreeManager struct {
}
func NewSkillThreeManager() *SkillChain {
	return &SkillChain{
		Manager:&SkillThreeManager{},
	}
}
func (s SkillThreeManager) HaveKill(attack int) bool {
	return attack>Hp
}
func (s SkillThreeManager) HandleAttackRequest(skillId int, attack int) bool {
	if skillId==SkillThree{
		fmt.Printf("技能 %d 满足条件释放 造成 %d 伤害\n", skillId, attack)
		return true
	}
	fmt.Printf("技能 %d不 满足条件释放 造成 %d 伤害\n", skillId, attack)
	return false
}

5. mian.go

package main
type (
	HeroId  = int
	SkillId = int
	Attack  = int
)
type DaJi struct {
	HeroId    HeroId
	Name      string
	SkillInfo map[SkillId]Attack
}
func NewDaJi(skillInfo map[SkillId]Attack) *DaJi {
	return &DaJi{HeroId: 1, Name: "妲己", SkillInfo: skillInfo}
}
func main() {
	c1 := NewSkillOneManager()
	c2 := NewSkillTwoManager()
	c3 := NewSkillThreeManager()
	c1.SetSuccessor(c2)
	c2.SetSuccessor(c3)
	var c Manager = c1
	skillInfo := make(map[SkillId]Attack, 3)
	skillInfo[SkillOne] = 7000  // 技能一  伤害
	skillInfo[SkillTwo] = 9000  // 技能一  伤害
	skillInfo[SkillThree] = 10000 // 大招  伤害
	daji:=NewDaJi(skillInfo)
	c.HandleAttackRequest(SkillOne, daji.SkillInfo[SkillOne])
	c.HandleAttackRequest(SkillTwo, daji.SkillInfo[SkillTwo])
	c.HandleAttackRequest(SkillThree, daji.SkillInfo[SkillThree])
}

总结

职责链模式算是迭代器模式的一个延伸,里面的思想与迭代器模式有些相似之处。迭代器是把队列每个元素作为输入,然后用户自己定义处理逻辑,而职责链是用户指定多个处理逻辑,处理同一个输入,只有满足条件的那个处理逻辑才能真正输出,而其他处理逻辑只是把输入传递给下一个处理逻辑。

到此这篇关于GoLang职责链模式分离组合职责的文章就介绍到这了,更多相关GoLang职责链模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Golang实现简易的rpc调用

    Golang实现简易的rpc调用

    RPC指(Remote Procedure Call Protocol)远程过程调用协议。本文将实现利用Golang进行rpc调用(只实现一个rpc框架基本的功能,不对性能做保证),需要的可以参考一下
    2023-03-03
  • 使用Golang创建单独的WebSocket会话

    使用Golang创建单独的WebSocket会话

    WebSocket是一种在Web开发中非常常见的通信协议,它提供了双向、持久的连接,适用于实时数据传输和实时通信场景,本文将介绍如何使用 Golang 创建单独的 WebSocket 会话,包括建立连接、消息传递和关闭连接等操作,需要的朋友可以参考下
    2023-12-12
  • 解决Go语言中高频次和高并发下随机数重复的问题

    解决Go语言中高频次和高并发下随机数重复的问题

    在Golang中,获取随机数的方法一般会介绍有两种,一种是基于math/rand的伪随机,一种是基于crypto/rand的真随机,math/rand由于其伪随机的原理,经常会出现重复的随机数,导致在需要进行随机的业务出现较多的重复问题,所以本文给大家介绍了较好的解放方案
    2023-12-12
  • Golang JSON的进阶用法实例讲解

    Golang JSON的进阶用法实例讲解

    这篇文章主要给大家介绍了关于Golang JSON进阶用法的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用golang具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-09-09
  • Go语言里切片slice的用法介绍

    Go语言里切片slice的用法介绍

    这篇文章介绍了Go语言里切片slice的用法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • golang判断net.Conn 是否已关闭的操作

    golang判断net.Conn 是否已关闭的操作

    这篇文章主要介绍了golang判断net.Conn 是否已关闭的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • Go错误处理的几种方式

    Go错误处理的几种方式

    在Go语言中,错误处理是一种重要的编程模式,它用于处理可能出现的错误或异常情况,本文就来介绍一下Go错误处理的几种方式,感兴趣的可以了解一下
    2023-11-11
  • go语言中的协程详解

    go语言中的协程详解

    本文详细讲解了go语言中的协程,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • golang coroutine 的等待与死锁用法

    golang coroutine 的等待与死锁用法

    这篇文章主要介绍了golang coroutine 的等待与死锁用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-05-05
  • golang实现java uuid的序列化方法

    golang实现java uuid的序列化方法

    这篇文章主要介绍了golang实现java uuid的序列化方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09

最新评论