zoukankan      html  css  js  c++  java
  • Go 典型并发任务

    学习-极客时间-Go语言从入门到实战 笔记

    单例模式

    代码片段举例:

    package once
    
    import (
    	"fmt"
    	"sync"
    	"testing"
    	"unsafe"
    )
    
    type Movie struct {
    }
    
    var once sync.Once
    var SingleInstance *Movie
    
    func GetInstance() *Movie {
    	once.Do(func() {
    		fmt.Println("create instance")
    		SingleInstance = new(Movie)
    	})
    	return SingleInstance
    }
    
    func TestSingleInstance(t *testing.T) {
    	var wg sync.WaitGroup
    	for i := 0; i < 5; i++ {
    		wg.Add(1)
    		go func() {
    			sing := GetInstance()
    			fmt.Println(unsafe.Pointer(sing))
    			wg.Done()
    		}()
    	}
    	wg.Wait()
    }
    

    仅需任意任务完成

    代码片段举例:

    package only
    
    import (
    	"fmt"
    	"runtime"
    	"testing"
    	"time"
    )
    
    func runTask(id int) string {
    	time.Sleep(10 * time.Millisecond)
    	return fmt.Sprintf("The result is from %d", id)
    }
    
    func FirstResponse() string {
    	numOfRunner := 10
    	ch := make(chan string, numOfRunner)
    	//没有指定channel容量,会导致阻塞,channel等待接收者,协程泄漏
    	//ch := make(chan string)
    	for i := 0; i < numOfRunner; i++ {
    		go func(i int) {
    			ch <- runTask(i)
    		}(i)
    	}
    	return <-ch
    }
    
    func TestOnly(t *testing.T) {
    	t.Log("Before: ", runtime.NumGoroutine())
    	fmt.Println(FirstResponse())
    	time.Sleep(time.Second * 1)
    	t.Log("After: ", runtime.NumGoroutine())
    }
    

    所有任务完成

    代码片段举例:

    package all
    
    import (
    	"fmt"
    	"runtime"
    	"testing"
    	"time"
    )
    
    func runTask(id int) string {
    	time.Sleep(10 * time.Millisecond)
    	return fmt.Sprintf("The result is from %d", id)
    }
    
    func FirstResponse() string {
    	numOfRunner := 10
    	ch := make(chan string, numOfRunner)
    	//没有指定channel容量,会导致阻塞,channel等待接收者,协程泄漏
    	//ch := make(chan string)
    	for i := 0; i < numOfRunner; i++ {
    		go func(i int) {
    			ch <- runTask(i)
    		}(i)
    	}
    	res := ""
    	for j := 0; j < numOfRunner; j++ {
    		res += <-ch + "
    "
    	}
    	return res
    }
    
    func TestOnly(t *testing.T) {
    	t.Log("Before: ", runtime.NumGoroutine())
    	fmt.Println(FirstResponse())
    	time.Sleep(time.Second * 1)
    	t.Log("After: ", runtime.NumGoroutine())
    }
    
  • 相关阅读:
    海盗分赃问题-----简化问题,分而治之
    计算机组成原理之输入输出系统
    计算机组成原理之外围设备
    计算机组成原理之总线系统
    计算机组成原理之控制器
    计算机组成原理之存储器
    计算机组成原理之运算器
    网络配置4:STP生成树协议配置
    微信内置浏览器私有接口WeixinJSBridge介绍(转)
    使用ajax和history.pushState无刷新改变页面URL(转)
  • 原文地址:https://www.cnblogs.com/yangqi7/p/12425594.html
Copyright © 2011-2022 走看看