Ai
7 Star 27 Fork 2

Gitee 极速下载/goworld

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/xiaonanln/goworld
克隆/下载
profile.go 1.29 KB
一键复制 编辑 原始数据 按行查看 历史
seis 提交于 2017-06-29 11:39 +08:00 . GetMails
package main
import (
"fmt"
"os"
"sync"
"time"
)
var (
profLock sync.Mutex
profSectionStartTime time.Time
thingMaxTime map[string]time.Duration
thingMinTime map[string]time.Duration
thingTimes map[string]time.Duration
thingCounts map[string]int
)
func recordThingTime(thing string, d time.Duration) {
profLock.Lock()
now := time.Now()
if now.Sub(profSectionStartTime) >= time.Second {
// start new profile section
dumpThingProfile()
profSectionStartTime = now
thingTimes = map[string]time.Duration{}
thingCounts = map[string]int{}
thingMinTime = map[string]time.Duration{}
thingMaxTime = map[string]time.Duration{}
}
thingCounts[thing] += 1
thingTimes[thing] += d
if oldMaxTime, ok := thingMaxTime[thing]; !ok || oldMaxTime < d {
thingMaxTime[thing] = d
}
if oldMinTime, ok := thingMaxTime[thing]; !ok || oldMinTime > d {
thingMinTime[thing] = d
}
profLock.Unlock()
}
func dumpThingProfile() {
for thing, count := range thingCounts {
totalTime := thingTimes[thing]
fmt.Fprintf(os.Stdout, "> %-32s *%d AVG %s RANGE %s ~ %s\n", thing, count, totalTime/time.Duration(count), thingMinTime[thing], thingMaxTime[thing])
}
fmt.Fprintln(os.Stdout, "===============================================================================")
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/mirrors/goworld.git
git@gitee.com:mirrors/goworld.git
mirrors
goworld
goworld
v0.1.6

搜索帮助