php怎么利用多核,golang如何利用多核

c07c97c2de3d8211778e27f844569f14.png

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教程栏目。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值