关于在vim环境下开发go快捷import的问题

有问必答songtianyi 回复了问题 • 3 人关注 • 2 个回复 • 701 次浏览 • 2016-12-07 13:05 • 来自相关话题

json 解析器哪家强?

开源程序taowen 发表了文章 • 8 个评论 • 956 次浏览 • 2016-12-07 12:42 • 来自相关话题

全文链接: https://github.com/json-iterator/go-benchmark查看全部

全文链接: https://github.com/json-iterator/go-benchmark


目的不是推销 json-iterator 。而是证明 json-iterator 不比其他的库更慢,从而使得大家可以把吐槽点放到其他方面:比如特性是不是齐全, api 是不是友好。重新发明 json 解析器是因为经常需要处理奇怪格式的 json ,而又不想把数据转两遍。市面上没有 api 满足我的需求的,后面我会专门写一篇 api 介绍的文章来演示 json-iterator 的独特性。( https://github.com/json-iterator/go/blob/master/README.md



  • jsonparser: https://github.com/buger/jsonparser

  • jsoniter pull-api: https://github.com/json-iterator/go

  • jsoniter reflect-api: https://github.com/json-iterator/go/blob/master/jsoniter_reflect.go

  • encoding/json: golang standard lib

  • easy json: https://github.com/mailru/easyjson


测试设备



  • CPU: i7-6700K @ 4.0G

  • Level 1 cache size: 4 x 32 KB 8-way set associative instruction caches

  • Level 2 cache size: 4 x 256 KB 4-way set associative caches

  • Level 3 cache size: 8 MB 16-way set associative shared cache

  • Go: 1.8beta1


small payload


https://github.com/json-iterator/go-benchmark/blob/master/src/github.com/json-iterator/go-benchmark/benchmark_small_payload_test.go



































jsonparser jsoniter pull-api jsoniter reflect-api encoding/json easyjson
599 ns/op 515 ns/op 684 ns/op 2453 ns/op 687 ns/op
64 B/op 64 B/op 256 B/op 864 B/op 64 B/op
2 allocs/op 2 allocs/op 4 allocs/op 31 allocs/op 2 allocs/op

encoding/json 在 i7-6700K 上性能还不错,但是在缓存小一些的 cpu 上性能要比这慢更多。


small


medium payload



































jsonparser jsoniter pull-api jsoniter reflect-api encoding/json easyjson
5238 ns/op 4111 ns/op 4708 ns/op 24939 ns/op 7361 ns/op
104 B/op 104 B/op 368 B/op 808 B/op 248 B/op
4 allocs/op 4 allocs/op 14 allocs/op 18 allocs/op 8 allocs/op

https://github.com/json-iterator/go-benchmark/blob/master/src/github.com/json-iterator/go-benchmark/benchmark_medium_payload_test.go


json-iterator 的反射 api 也是相当快的。


medium


large payload


https://github.com/json-iterator/go-benchmark/blob/master/src/github.com/json-iterator/go-benchmark/benchmark_large_payload_test.go



























jsonparser jsoniter pull-api encoding/json
38334 ns/op 38463 ns/op 290778 ns/op
0 B/op 0 B/op 2128 B/op
0 allocs/op 0 allocs/op 46 allocs/op

jsonparser 在大部分字段不使用的时候,要快那么一丁点。


large


large file


test file used: https://github.com/json-iterator/test-data/blob/master/large-file.json



























jsonparser jsoniter pull-api encoding/json
42698634 ns/op 37760014 ns/op 235354502 ns/op
67107104 B/op 4248 B/op 71467896 B/op
19 allocs/op 5 allocs/op 272477 allocs/op

jsonparser 等其他一大票 json 解析器都是以 []byte 作为输入的,简直是为跑分而生。关于这一点 jackson 的作者也有吐槽( https://www.infoq.com/news/2014/05/jackson-founder-responds )。而 jsoniter 可以支持 io.Reader 作为输入,对于大文件处理非常友好。


large-file

beego的redis模块是构造的连接池吗

有问必答astaxie 回复了问题 • 2 人关注 • 1 个回复 • 697 次浏览 • 2016-12-07 12:30 • 来自相关话题

请问下有golang实现的贝叶斯过滤器吗?

有问必答astaxie 回复了问题 • 2 人关注 • 1 个回复 • 619 次浏览 • 2016-12-07 12:27 • 来自相关话题

go 定时执行

有问必答astaxie 回复了问题 • 2 人关注 • 1 个回复 • 672 次浏览 • 2016-12-07 12:26 • 来自相关话题

ubuntu tail 日志文件显示颜色的问题

有问必答astaxie 回复了问题 • 2 人关注 • 1 个回复 • 656 次浏览 • 2016-12-07 12:21 • 来自相关话题

TiDB Weekly [2016.12.05]

文章分享qiuyesuifeng 发表了文章 • 0 个评论 • 381 次浏览 • 2016-12-07 11:42 • 来自相关话题

Weekly update in TiDB

Last week, we landed 查看全部

Weekly update in TiDB


Last week, we landed 48 PRs in the TiDB repositories, 6 PRs in the TiDB docs repositories.


Added



Fixed



Improved



Document change


The following guides are updated:



Weekly update in TiKV


Last week, we landed 22 PRs in the TiKV repositories.


Added



Fixed



Improved




  • Replace the score type with resource kind to calculate the scores more easily.




  • Replace origin concept balance with schedule and simplify configurations.



  • Use coordinator to control the speed of different schedulers.


原文链接

Codebase Refactoring (with help from Go)

文章分享stevewang 发表了文章 • 1 个评论 • 261 次浏览 • 2016-12-07 11:42 • 来自相关话题

Russ Cox的一篇文章,讲大代码库维护的思路以及go对此的支持,推荐阅读。 https://talks.golang.org/2016/...

用匿名变量显式声明类型与接口的实现关系,有什么好处?

技术讨论astaxie 回复了问题 • 6 人关注 • 1 个回复 • 754 次浏览 • 2016-12-07 11:09 • 来自相关话题

github.com/go-sql-driver/mysql

有问必答RedMothball 回复了问题 • 4 人关注 • 3 个回复 • 738 次浏览 • 2016-12-07 10:32 • 来自相关话题

那种动态调用技术效率最高?

有问必答RedMothball 回复了问题 • 3 人关注 • 4 个回复 • 1034 次浏览 • 2016-12-07 09:57 • 来自相关话题

ajax和beego间的数据如何进行json格式的通信(发送传输)

有问必答RedMothball 回复了问题 • 3 人关注 • 1 个回复 • 893 次浏览 • 2016-12-07 09:49 • 来自相关话题

go 在机器学习方面的生态环境如何?

有问必答DQ 回复了问题 • 2 人关注 • 2 个回复 • 977 次浏览 • 2016-12-07 09:25 • 来自相关话题

Go 1.8 的 Plugins 使用

文章分享veni 发表了文章 • 11 个评论 • 2186 次浏览 • 2016-12-06 18:05 • 来自相关话题

Go 1.8为我们提供了一个创建共享库的新工具,称为Plugins!让我们来创建和使用一个插件。 目前的插件只能在 Linux 和 Darwin (1.8正式版 因为 bug 已移除支持)上工作。

安装1.8 beta1, 不做说明.查看全部

Go 1.8为我们提供了一个创建共享库的新工具,称为Plugins!让我们来创建和使用一个插件。
目前的插件只能在 Linux 和 Darwin (1.8正式版 因为 bug 已移除支持)上工作。


安装1.8 beta1, 不做说明.


创建一个插件方法到 aplugin.go:


package main

func Add(x, y int) int {
return x+y
}

func Subtract(x, y int) int {
return x-y
}

然后构建插件:


运行下面命令构建插件:


go build -buildmode=plugin

构建指定文件插件aplugin.go到aplugin.so:


go build -buildmode=plugin -o aplugin.so aplugin.go

加载插件:


p, _ := plugin.Open("./aplugin.so")
//p, err := plugin.Open("./aplugin.so")

call插件:


add, _ := p.Lookup("Add")
sub, _ := p.Lookup("Subtract")

使用插件:


sum := add.(func(int, int) int)(11, 2)
fmt.Println(sum)
subt := sub.(func(int, int) int)(11, 2)
fmt.Println(subt)

另外源码测试中有:


go build -buildmode=c-shared

应该可以支持c语言构建插件

初学到range map部分,为何用range输出的map是无序的?

有问必答tupunco 回复了问题 • 3 人关注 • 2 个回复 • 525 次浏览 • 2016-12-06 18:00 • 来自相关话题