golang默认使用单核单线程,可以通过调整或设置运行参数设置多核多线程支持

runtime.GOMAXPROCS(int)runtime.GOMAXPROCS(runtime.NumCPU())直接设置环境变量$GOMAXPROCS

Go从1.5版本开始,默认采用多核执行,默认是你的CPU核心数,以前版本默认为1

那么我们在什么情况下应该用多核心来加速程序,而在什么情况下用单核即可呢?

现在我们用一简单的程序来说明下:

package mainimport (        "runtime"        "fmt"        "sync"        "database/sql"        _ "github.com/go-sql-driver/mysql""time")//定义任务队列var waitgroup sync.WaitGroupfunc xtgxiso(num int) {        //fmt.Println(num)        db, err := sql.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/test?charset=utf8")        if err != nil {                fmt.Println(err)        }        defer db.Close()        rows, err := db.Query("select sleep(1) as a")        if err != nil {                fmt.Println(err)        }        defer rows.Close()        var a string        for rows.Next() {                err = rows.Scan(&a)                if err != nil {                        fmt.Println(err)                } else {                        //fmt.Println(a)                }        }        waitgroup.Done() //任务完成,将任务队列中的任务数量-1,其实.Done就是.Add(-1)}func main() {//记录开始时间start := time.Now()        //设置最大的可同时使用的CPU核数和实际cpu核数一致        runtime.GOMAXPROCS(1)        for i := 1; i <= 10; i++ {                waitgroup.Add(1) //每创建一个goroutine,就把任务队列中任务的数量+1                go xtgxiso(i)        }        waitgroup.Wait() //Wait()这里会发生阻塞,直到队列中所有的任务结束就会解除阻塞//记录结束时间end :=  time.Now()//输出执行时间,单位为秒。fmt.Println(end.Sub(start).Seconds())}

这个程序是执行十次”select sleep(1) as a“.如果是顺序阻塞执行的话,执行时间肯定是10s以上,而我们用的协程不会有这种情况。我们可以修改“runtime.GOMAXPROCS(1)”来设置是单核还是多核心执行。

更多golang知识请关注golang教程栏目。

更多相关文章

  1. Golang能使用多核cpu吗
  2. 网卡多队列技术与RSS功能的详细介绍
  3. 芋道 Spring Boot 消息队列 RocketMQ 入门
  4. 分布式消息队列 RocketMQ源码解析:事务消息
  5. 分布式消息队列 RocketMQ源码解析:Filtersrv
  6. 分布式消息队列 RocketMQ 源码分析 —— 定时消息与消息重试
  7. 分布式消息队列 RocketMQ 源码分析 —— 高可用
  8. 分布式消息队列 RocketMQ 源码分析 —— Message 拉取与消费(上)
  9. 分布式消息队列 RocketMQ 源码分析 —— Message 拉取与消费(下)

随机推荐

  1. Android 之 发送短信
  2. 初识RatingBar
  3. Android(安卓)EditText 属性汇总
  4. Android实用编程技巧代码总结
  5. 自定义view-制作一个加载中的圆形
  6. android 对话框详解
  7. Android(安卓)签名信息读取
  8. android之RecycleView之ItemTouchHelper
  9. Android WiFi 架构总览(模块及接口)
  10. ionic build android log