1.简单的生成器

  1. package main
  2. import (
  3. "fmt"
  4. "math/rand"
  5. )
  6. func GenerateIntA()chan int {
  7. ch := make(chan int ,10)
  8. go func(){
  9. for {
  10. ch<-rand.Int()
  11. }
  12. }()
  13. return ch
  14. }
  15. func main(){
  16. ch := GenerateIntA()
  17. fmt.Println(<-ch)
  18. fmt.Println(<-ch)
  19. }

2.叠加增强型资源生成器

可以使用多路复用技术进行堆积叠加,增加服务能力
可以使用缓冲chan增加服务能力

  1. package main
  2. import (
  3. "fmt"
  4. "math/rand"
  5. )
  6. func GenerateIntA() chan int {
  7. ch := make(chan int, 10)
  8. go func() {
  9. for {
  10. ch <- rand.Int()
  11. }
  12. }()
  13. return ch
  14. }
  15. func GenerateIntB() chan int {
  16. ch := make(chan int, 10)
  17. go func() {
  18. for {
  19. ch <- rand.Int()
  20. }
  21. }()
  22. return ch
  23. }
  24. func GenerateInt() chan int {
  25. ch := make(chan int, 20)
  26. go func() {
  27. for {
  28. select {
  29. case ch <- <-GenerateIntA():
  30. case ch <- <-GenerateIntB():
  31. }
  32. }
  33. }()
  34. return ch
  35. }
  36. func main() {
  37. ch := GenerateInt()
  38. for i := 0; i < 100; i++ {
  39. fmt.Println(<-ch)
  40. }
  41. }

3.有时我们希望生成器能够自动的退出,这时可以使用golang  channel的

Close channel to broadcast 机制实现:

  1. package main
  2. import (
  3. "fmt"
  4. "math/rand"
  5. )
  6. func GenerateIntA(done chan struct{})chan int {
  7. ch := make(chan int )
  8. go func(){
  9. Lable:
  10. for {
  11. select {
  12. case ch<-rand.Int():
  13. case <-done:
  14. break Lable
  15. }
  16. }
  17. close(ch)
  18. }()
  19. return ch
  20. }
  21. func main(){
  22. done :=make(chan struct{})
  23. ch := GenerateIntA(done)
  24. fmt.Println(<-ch)
  25. fmt.Println(<-ch)
  26. close(done)
  27. fmt.Println(<-ch)
  28. fmt.Println(<-ch)
  29. fmt.Println(<-ch)
  30. fmt.Println(<-ch)
  31. }

4.可以更牛逼点,既要并发、缓冲,又有通知的生成器:

    1. package main
    2. import (
    3. "fmt"
    4. "math/rand"
    5. )
    6. func GenerateIntA(done chan struct{}) chan int {
    7. ch := make(chan int, 5)
    8. go func() {
    9. Lable:
    10. for {
    11. select {
    12. case ch <- rand.Int():
    13. case <-done:
    14. break Lable
    15. }
    16. }
    17. close(ch)
    18. }()
    19. return ch
    20. }
    21. func GenerateIntB(done chan struct{}) chan int {
    22. ch := make(chan int, 10)
    23. go func() {
    24. Lable:
    25. for {
    26. select {
    27. case ch <- rand.Int():
    28. case <-done:
    29. break Lable
    30. }
    31. }
    32. close(ch)
    33. }()
    34. return ch
    35. }
    36. func GenerateInt(done chan struct{}) chan int {
    37. ch := make(chan int)
    38. send := make(chan struct{})
    39. go func() {
    40. Lable:
    41. for {
    42. select {
    43. case ch <- <-GenerateIntA(send):
    44. case ch <- <-GenerateIntB(send):
    45. case <-done:
    46. send <- struct{}{}
    47. send <- struct{}{}
    48. break Lable
    49. }
    50. }
    51. close(ch)
    52. }()
    53. return ch
    54. }
    55. func main() {
    56. done := make(chan struct{})
    57. ch := GenerateInt(done)
    58. for i := 0; i < 10; i++ {
    59. fmt.Println(<-ch)
    60. }
    61. done <- struct{}{}
    62. for i := 0; i < 10; i++ {
    63. v := <-ch
    64. if v == 0 {
    65. return
    66. }
    67. fmt.Println(<-ch)
    68. }
    69. }

go并发设计模式 --资源生成器模式的更多相关文章

  1. 每天一个设计模式-7 生成器模式(Builder)

    每天一个设计模式-7 生成器模式(Builder) 一.实际问题 在讨论工厂方法模式的时候,提到了一个导出数据的应用框架,但是并没有涉及到导出数据的具体实现,这次通过生成器模式来简单实现导出成文本,X ...

  2. Java设计模式:生成器模式

    问题的提出: 有些类很容易创建对象,直接调用其构造方法,例如Student student = new Student("1001","zhang",21); ...

  3. 【设计模式】- 生成器模式(Builder)

    生成器模式 建造者模式.Builder 生成器模式 也叫建造者模式,可以理解成可以分步骤创建一个复杂的对象.在该模式中允许你使用相同的创建代码生成不同类型和形式的对象. 生成器的结构模式 生成器(Bu ...

  4. Java设计模式-Builder生成器模式

    概念: 生成器模式也称之为建造者模式.生成器模式的意图在于将一个复杂的构建与其表示相分离,构建与产品分离. UML: Ibuild接口清晰地反映了创建产品Product的流程. 生成器模式涉及4个关键 ...

  5. 面向对象设计模式_生成器模式详解(Builder Pattern)

    首先提出一个很容易想到应用场景: 手机的生产过程:手机有非常多的子件(部件),成千上万,不同品牌的手机的生产过程都是复杂而有所区别的,相同品牌的手机在设计上也因客户需求多样化,大到型号,小到颜色,是否 ...

  6. 设计模式十: 生成器模式(Builder Pattern)

    简介 生成器模式属于创建型模式的一种, 又叫建造者模式. 生成器模式涉及4个关键角色:产品(Product),抽象生成器(builder),具体生成器(ConcreteBuilder),指挥者(Dir ...

  7. 面向对象设计模式_生成器模式解读(Builder Pattern)

    首先提出一个很容易想到应用场景: 手机的生产过程:手机有非常多的子件(部件),成千上万,不同品牌的手机的生产过程都是复杂而有所区别的,相同品牌的手机在设计上也因客户需求多样化,大到型号,小到颜色,是否 ...

  8. 设计模式--Builder生成器模式

    如果文章中哪里有问题,希望各位大哥大姐指出,小弟十分感激. 正文 什么是生成器模式? 生成器模式就是把生产对象的过程进一步抽取.细化.独立.以往我们生产对象,可能就是在一个小作坊里面从头做到尾.现在用 ...

  9. Head First设计模式之生成器模式

    一.定义 将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.建造者模式是一种对象创建型模式. 二.结构 角色 Builder(抽象建造者):它为创建一个产品Product对象的 ...

随机推荐

  1. RoIPooling与RoIAlign的区别

    一.RoIPooling与RoIAlign 1.1.RoIPooling 通过对Faster RCNN的学习我妈了解的RolPooling可以使生成的候选框region proposal映射产生固定大 ...

  2. Struts2框架学习(二)——访问流程及架构

    1.Struts2的执行流程 从客户端发送请求过来,先经过前端控制器(核心过滤器StrutsPrepareAndExecuteFilter)过滤器中执行一组拦截器(一组拦截器就会完成部分功能代码),拦 ...

  3. XML文件操作之dom4j

    能够操作xml的api还是挺多的,DOM也是可以的,不过在此记录下dom4j的使用,感觉确实挺方便的 所需jar包官网地址:http://www.dom4j.org/dom4j-1.6.1/ dom4 ...

  4. LoadRunner时间戳函数web_save_timestamp_param

    举例:1520822348346(13位,毫秒级)   做时间戳的目的是为了JS缓存和防止CSRF,在LR中可以简单的使用下面这个函数 web_save_timestamp_param 来生成时间戳 ...

  5. springboot-helloworld实现

    springboot快速入门 首先,建立一个空的项目 第二步: 建立一个springboot项目 第三步:添加依赖: <?xml version="1.0" encoding ...

  6. Project Euler 33 Digit cancelling fractions

    题意:49/98是一个有趣的分数,因为可能在化简时错误地认为,等式49/98 = 4/8之所以成立,是因为在分数线上下同时抹除了9的缘故.分子分母是两位数且分子小于分母的这种有趣的分数有4个,将这四个 ...

  7. [USACO17JAN]Promotion Counting

    线段树合并. 正解好像不是线段树合并,但是出于练手的目的写了线段树合并. 大概就是对于左右子树,如果有一个为空,返回非空的,如果都不为空,就把这两个整合到一起就行了. #include <ios ...

  8. Mybaitis-generator生成数据对象和时间的优化

    1.本章涉及到知识点,Mybaitis-generator生成数据对象和时间,xml的引用*.properties 外部文件(在这之前必须导入了mybaitis的核心架包) A.在pom.xml的案例 ...

  9. 汇编-理解call,ret

    ; 有意思的东西,主函数调用子函数用汇编来理解 assume cs:codeseg codeseg segment start: main: call sub1 ; 调用子函数1, push IP1 ...

  10. php文件上传相关知识点回顾

    近来正在回顾PHP的文件上传.在此做个记录. <?php date_default_timezone_set('PRC'); if(isset($_POST['submit'])) { echo ...