python与go线程性能简单对比

昨天看到一篇关于python多线程公众号文章,做了简单的对比试验。用python和go做单线程1亿递减到1和两个线程各自从5千万减到1,看程序执行时间:

python一个线程:

def decrement(n):
    while n > 0:
         n -= 1

from time import perf_counter as pc
start = pc()
decrement(100000000)
print(pc() - start)

执行时间:

14.351082861999998
14.311808035000013
13.47257553399993

python两个线程:

import threading

t1 = threading.Thread(target=decrement, args=(50000000,))
t2 = threading.Thread(target=decrement, args=(50000000,))

start = pc()
t1.start()
t2.start()

t1.join()
t2.join()
print(pc() - start)

执行时间:

40.047668924999925
17.143103717999793
36.23898320300009
49.22135359899994
34.21361186399986

go一个线程:

package main

import "fmt"
import "time"

var c chan int

func decrement(n int) {
    for n > 0 {
        n -= 1
    }
}

func main() {
    start := time.Now()
    decrement(100000000)
    fmt.Println(time.Since(start))
}

执行时间:

434.60565ms
425.799923ms
421.821211ms
459.630486ms

go两个线程:

package main

import "fmt"
import "time"

var c chan int

func decrement(n int) {
    for n > 0 {
        n -= 1
    }
    c <- 0
}

func main() {
    start := time.Now()
    c = make(chan int)
    go decrement(50000000)
    go decrement(50000000)
    <-c
    <-c
    fmt.Println(time.Since(start))
}

执行时间:

51.382195ms
61.355949ms
42.02437ms
53.019678ms
38.299514ms

结论

实验环境是同一台虚拟机,python3.6.5,go1.10。

python执行结果不稳定,双线程比单线程还慢,时间大约是一倍。

go执行结果稳定,双线程比单线程快大约10倍。

go比python单线程快n倍。

猜你喜欢

转载自blog.csdn.net/qq_35753140/article/details/80198772
今日推荐