go并发设计模式 --资源生成器模式
1.简单的生成器
- package main
- import (
- "fmt"
- "math/rand"
- )
- func GenerateIntA()chan int {
- ch := make(chan int ,10)
- go func(){
- for {
- ch<-rand.Int()
- }
- }()
- return ch
- }
- func main(){
- ch := GenerateIntA()
- fmt.Println(<-ch)
- fmt.Println(<-ch)
- }
2.叠加增强型资源生成器
可以使用多路复用技术进行堆积叠加,增加服务能力
可以使用缓冲chan增加服务能力
- package main
- import (
- "fmt"
- "math/rand"
- )
- func GenerateIntA() chan int {
- ch := make(chan int, 10)
- go func() {
- for {
- ch <- rand.Int()
- }
- }()
- return ch
- }
- func GenerateIntB() chan int {
- ch := make(chan int, 10)
- go func() {
- for {
- ch <- rand.Int()
- }
- }()
- return ch
- }
- func GenerateInt() chan int {
- ch := make(chan int, 20)
- go func() {
- for {
- select {
- case ch <- <-GenerateIntA():
- case ch <- <-GenerateIntB():
- }
- }
- }()
- return ch
- }
- func main() {
- ch := GenerateInt()
- for i := 0; i < 100; i++ {
- fmt.Println(<-ch)
- }
- }
3.有时我们希望生成器能够自动的退出,这时可以使用golang channel的
Close channel to broadcast 机制实现:
- package main
- import (
- "fmt"
- "math/rand"
- )
- func GenerateIntA(done chan struct{})chan int {
- ch := make(chan int )
- go func(){
- Lable:
- for {
- select {
- case ch<-rand.Int():
- case <-done:
- break Lable
- }
- }
- close(ch)
- }()
- return ch
- }
- func main(){
- done :=make(chan struct{})
- ch := GenerateIntA(done)
- fmt.Println(<-ch)
- fmt.Println(<-ch)
- close(done)
- fmt.Println(<-ch)
- fmt.Println(<-ch)
- fmt.Println(<-ch)
- fmt.Println(<-ch)
- }
4.可以更牛逼点,既要并发、缓冲,又有通知的生成器:
- package main
- import (
- "fmt"
- "math/rand"
- )
- func GenerateIntA(done chan struct{}) chan int {
- ch := make(chan int, 5)
- go func() {
- Lable:
- for {
- select {
- case ch <- rand.Int():
- case <-done:
- break Lable
- }
- }
- close(ch)
- }()
- return ch
- }
- func GenerateIntB(done chan struct{}) chan int {
- ch := make(chan int, 10)
- go func() {
- Lable:
- for {
- select {
- case ch <- rand.Int():
- case <-done:
- break Lable
- }
- }
- close(ch)
- }()
- return ch
- }
- func GenerateInt(done chan struct{}) chan int {
- ch := make(chan int)
- send := make(chan struct{})
- go func() {
- Lable:
- for {
- select {
- case ch <- <-GenerateIntA(send):
- case ch <- <-GenerateIntB(send):
- case <-done:
- send <- struct{}{}
- send <- struct{}{}
- break Lable
- }
- }
- close(ch)
- }()
- return ch
- }
- func main() {
- done := make(chan struct{})
- ch := GenerateInt(done)
- for i := 0; i < 10; i++ {
- fmt.Println(<-ch)
- }
- done <- struct{}{}
- for i := 0; i < 10; i++ {
- v := <-ch
- if v == 0 {
- return
- }
- fmt.Println(<-ch)
- }
- }
go并发设计模式 --资源生成器模式的更多相关文章
- 每天一个设计模式-7 生成器模式(Builder)
每天一个设计模式-7 生成器模式(Builder) 一.实际问题 在讨论工厂方法模式的时候,提到了一个导出数据的应用框架,但是并没有涉及到导出数据的具体实现,这次通过生成器模式来简单实现导出成文本,X ...
- Java设计模式:生成器模式
问题的提出: 有些类很容易创建对象,直接调用其构造方法,例如Student student = new Student("1001","zhang",21); ...
- 【设计模式】- 生成器模式(Builder)
生成器模式 建造者模式.Builder 生成器模式 也叫建造者模式,可以理解成可以分步骤创建一个复杂的对象.在该模式中允许你使用相同的创建代码生成不同类型和形式的对象. 生成器的结构模式 生成器(Bu ...
- Java设计模式-Builder生成器模式
概念: 生成器模式也称之为建造者模式.生成器模式的意图在于将一个复杂的构建与其表示相分离,构建与产品分离. UML: Ibuild接口清晰地反映了创建产品Product的流程. 生成器模式涉及4个关键 ...
- 面向对象设计模式_生成器模式详解(Builder Pattern)
首先提出一个很容易想到应用场景: 手机的生产过程:手机有非常多的子件(部件),成千上万,不同品牌的手机的生产过程都是复杂而有所区别的,相同品牌的手机在设计上也因客户需求多样化,大到型号,小到颜色,是否 ...
- 设计模式十: 生成器模式(Builder Pattern)
简介 生成器模式属于创建型模式的一种, 又叫建造者模式. 生成器模式涉及4个关键角色:产品(Product),抽象生成器(builder),具体生成器(ConcreteBuilder),指挥者(Dir ...
- 面向对象设计模式_生成器模式解读(Builder Pattern)
首先提出一个很容易想到应用场景: 手机的生产过程:手机有非常多的子件(部件),成千上万,不同品牌的手机的生产过程都是复杂而有所区别的,相同品牌的手机在设计上也因客户需求多样化,大到型号,小到颜色,是否 ...
- 设计模式--Builder生成器模式
如果文章中哪里有问题,希望各位大哥大姐指出,小弟十分感激. 正文 什么是生成器模式? 生成器模式就是把生产对象的过程进一步抽取.细化.独立.以往我们生产对象,可能就是在一个小作坊里面从头做到尾.现在用 ...
- Head First设计模式之生成器模式
一.定义 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.建造者模式是一种对象创建型模式. 二.结构 角色 Builder(抽象建造者):它为创建一个产品Product对象的 ...
随机推荐
- BZOJ4518: [Sdoi2016]征途(dp+斜率优化)
Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1875 Solved: 1045[Submit][Status][Discuss] Descript ...
- EditPlus代码自动完成的设置
EditPlus代码自动完成的设置保存在 *.acp 文件中,可以在“工具”->“首选项”->“文件”->“文件类型及语法”中(如下图) 其中“语法文件”保存着进行语法高亮的关键词, ...
- PhotoZoom放大图片,真的能无损吗?
当然想要无损放大一张很小的图片时,总会有人会和你推荐PhotoZoom这款软件,那么它真的和说的一样,可以无损放大吗?下面小编挑了2张图片做了一下对比. 案例1,我们选取一张尺寸为200x200像素的 ...
- 移动前端头部标签(HTML5 head meta)转载
移动web页面头部书写 字数2516 阅读1128 评论0 喜欢30 HTTP 标题信息(http-equiv) 和页面描述信息(name) http-equiv:该枚举的属性定义,可以改变服务器和用 ...
- centos7.XXX配置python3环境
众做周知,centos 是自带python2.7的.可是随着社会的进步,科技的发展,技术一步步更新换代,python2.7已经不足以满足项目的需求.这时候python3横空出世. 下面跟着我来一起实现 ...
- Nginx Location指令配置及常用全局变量
./configure的含义 在实践安装nginx的时候,不知道./configure是什么意思,这里特地记录一下. 在linux中./代表当前目录,属于相对路径../代表上一级目录,属于相对路径/代 ...
- Disconf入门指南(1)
Disconf简介 参考: https://github.com/knightliao/disconf/wiki/TutorialSummary 在一个分布式环境中,同类型的服务往往会部署很多实例.这 ...
- 洛谷 P1567 统计天数
题目背景 统计天数 题目描述 炎热的夏日,KC非常的不爽.他宁可忍受北极的寒冷,也不愿忍受厦门的夏天.最近,他开始研究天气的变化.他希望用研究的结果预测未来的天气. 经历千辛万苦,他收集了连续N(1& ...
- nyoj256-C小加之级数求和
C小加 之 级数求和 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 最近,C小加 又遇到难题了,正寻求你的帮助. 已知:Sn= 1+1/2+1/3+-+1/n. 显然对 ...
- LVM实践
[root@ftp:/root] > fdisk -l Disk /dev/sda: 53.7 GB, 53687091200 bytes, 104857600 sectors Units = ...