文档章节

Go1.2新功能简介

chai2010
 chai2010
发布于 2013/09/09 16:43
字数 1101
阅读 6632
收藏 29

<!-- Go1.2有哪些改进? -->

距离2013.08.12正式发布Go1.1.2大约1个月了. 目前Go语言已经进入Go1.2的发布流程, 预计将在2013年底发布.

本文主要列举Go1.2的一些大的改进, 并会持续保持更新.

语言的改变

禁止nil对象取值

对于Go1.0, 有以下代码:

type T struct {
	X [1<<24]byte
	Field int32
}

func main() {
	var x *T
}

操作 x.Field 将会对应到 1<<24 位置的内存. 在Go1.2中, 将导致 panic 或 错误.

切片语法增加cap域

之前在切片时, cap默认为最大. 比如:

var array [10]int
slice := array[2:4]

slice的容量是8. 在Go1.2中, 如希望容量为6, 可以这样:

slice = array[2:4:6]

如果第一部分的开始地址省略, 则默认为0.

有了可定制的cap语法,就可以自己new一个大内存,然后自己构造malloc/free内存管理函数了。

每次malloc返回的slice的cap被严格限定为申请的size。

该语法的设计文档: https://docs.google.com/document/d/1GKKdiGYAghXRxC2BFrSEbHBZZgAGKQ-yXK-hRKBo0Kk/pub

cgo支持C++源码

CGO支持函数指针, 用法请参考 https://code.google.com/p/go/source/browse/misc/cgo/test/fpvar.go.

CGO支持C++语法, 但是只支持C语言的导入符号.

针对C++增加了 CPPFLAGSCXXFLAGS 参数设置选项.

比较适合用C语言导出, 但是用C++实现的库.

注: windows版本的MinGW还不支持外部链接, 详情请参考 Issue6533.

runtime实现的变化

goroutines 的函数入口采用抢占式调度.

在之前的版本中, 如果goroutines内部有死循环, 那么其他的 goroutines 可能无法获取此线程的CPU资源, 特别是在 GOMAXPROCS 设置为 1 个线程的时候.

在Go1.2中部分解决了此问题: 调度器会在函数的 入口处被偶尔触发. 也就是说, 如果任何循环 内部调用了一个非内联的函数的话, 其他goroutines 也将有机会在同一个线程执行.

在Go1.2, goroutine 的默认堆栈大小临时由4KB改为8KB. 新改的8KB大小对于很多实际的程序可以带来一定的性能提升. 当然, 更大的默认堆栈也导致了程序可能使用更多的内存, 在后续的Go开发中采用更好的堆栈技术解决这个问题.

同时goroutine的栈有最大限制(不是无限的), 64位系统默认限制为1GB, 32位系统模型限制为250MB. 如果需要调整默认值, 可以调用 runtime/debug 包的 SetMaxStack 函数修改. 具体请参考: CL12541052

程序开启的系统线程有增加了最大数量限制(默认为10000). 如果需要调整默认值, 可以调用 runtime/debug 包的 SetMaxThreads 函数修改. 具体请参考: CL13037043

关于动态库支持

Linux/Arm 版本已经支持外部链接. 这是Go的编译工具链支持动态库特性的一个关键环节.

gccgo的状态

期望GCC4.9能包含完整的Go1.2. 目前的GCC4.8.2包含Go1.1.2.

性能优化

  • compress/bzip2: 30%的性能提升
  • crypto/des: 5倍的性能提升
  • encoding/json: encoding 30% 的性能提升
  • net: windows/BSD下 网络和 runtime 的深度集成(Linux/OS X在Go1.1已经支持), 30% 的性能提升

标准库的变化

较大的变化有:

  • encoding: 新包, 提供通用的 encoding 接口
  • fmt: 引入参数索引支持, 主要是处理不同语言翻译之后参数顺序的变化
  • sync/atomic: 增加了 Swap 函数
  • text/template: 增加 eq/lt 等比较函数, 增加 {{else if ... }}简化语法
  • runtime: 简化 SetFinalizer 参数 f 的参数类型的限制, 只要可赋值即可
  • testing: 增加的 TB 接口
  • image/gif 增加了 encode 函数
  • MD5/HASH等增加便利的函数

fmt新支持的参数索引:

fmt.Printf("%[3]c %[1]c %[1]c %c\n", 'a', 'b', 'c')
// output: c a a b

简化的HASH用法:

hash := sha1.Sum([]byte("123"))
fmt.Printf("H(data) = %x\n", hash)

杂项消息(个人补充)

  • go 命令行工具迁移到 go.tools, 并将大幅改进版面
  • go.text/encoding 增加了 GBK 的支持, 彻底解决中文Windows命令行中文乱码问题.
  • go.image 增加了 bmp 的保存 和 分块 tiff 的读取支持, 目前还不支持超大tiff图像.
  • notepad++ 更好的高亮显示, builtin函数的自动补全, 函数/方法列表等功能.

© 著作权归作者所有

共有 人打赏支持
chai2010

chai2010

粉丝 416
博文 99
码字总数 81560
作品 10
武汉
程序员
加载中

评论(19)

雨里有条鱼
雨里有条鱼

引用来自“林夕如梦”的评论

1.5.2 amd64 的go 在windows上mingw还是能外部链接吗?

引用来自“chai2010”的评论

1.5 就可以了, 可以支持 C++ 代码编译.
嗯,我的问题,测试可以了
chai2010
chai2010

引用来自“林夕如梦”的评论

1.5.2 amd64 的go 在windows上mingw还是能外部链接吗?
1.5 就可以了, 可以支持 C++ 代码编译.
雨里有条鱼
雨里有条鱼
1.5.2 amd64 的go 在windows上mingw还是能外部链接吗?
雨里有条鱼
雨里有条鱼

引用来自“chai2010”的评论

引用来自“林夕如梦”的评论

go1.2调用c++的静态库,出现问题,无法识别new,需要用cppflags之类的设置吗?

new等C++特有的特征只能在C++文件中访问. 头文件只能导出C的函数和结构体.
如果是Windows, Go1.2还可能遇到一些链接问题, 具体请参考 Issue4069 .
cppflags只是用于指定C++版本的链接库.

嗯,昨晚搞定了,原来windows下cgo不能用libxxx.a, 使用#cgo LDFLAGS -lxxx,会出现undefined,只能通过dll,Go1.3不知道会不会支持
chai2010
chai2010

引用来自“林夕如梦”的评论

go1.2调用c++的静态库,出现问题,无法识别new,需要用cppflags之类的设置吗?

new等C++特有的特征只能在C++文件中访问. 头文件只能导出C的函数和结构体.
如果是Windows, Go1.2还可能遇到一些链接问题, 具体请参考 Issue4069 .
cppflags只是用于指定C++版本的链接库.
雨里有条鱼
雨里有条鱼
go1.2调用c++的静态库,出现问题,无法识别new,需要用cppflags之类的设置吗?
chai2010
chai2010

引用来自“encro”的评论

“如果如果任何循环”

已经更正, 多谢提醒 :)
encro
encro
“如果如果任何循环”
张露兵
张露兵
template功能确实该改进下了。
狗头666
狗头666
感觉又编辑了?又加了点内容
Go 1.2 RC5 发布(继续RC)

Go1.2新功能预览: http://golang.org/doc/go1.2 Go 1.2 RC5下载: https://code.google.com/p/go/downloads/list...

李察德-泰森
2013/11/18
2.5K
16
Go 1.2 RC4 发布

Go1.2新功能预览: http://golang.org/doc/go1.2 Go 1.2 RC4下载: https://code.google.com/p/go/downloads/list...

李察德-泰森
2013/11/13
1K
11
Go 1.2 RC3 发布

Go1.2新功能预览: http://golang.org/doc/go1.2 Go 1.2 RC2下载: https://code.google.com/p/go/downloads/list...

李察德-泰森
2013/11/01
4.1K
46
Go 1.2 RC2 发布

Go1.2新功能预览: http://my.oschina.net/chai2010/blog/160143 Go 1.2 RC2下载: https://code.google.com/p/go/downloads/list...

chai2010
2013/10/18
3.3K
30
GCC 4.8.2 发布

GCC 4.8.2 的主要更新是包含了完整的对 Go1.1.2 的支持。 对还未发布的 Go1.2 的支持预计要等到 GCC4.9。 GCC 4.8.2 还包含了一些BUG修改,具体请参考更新日志。 http://gcc.gnu.org/gcc-4.8...

chai2010
2013/10/17
11.3K
20

没有更多内容

加载失败,请刷新页面

加载更多

下一页

(一)软件测试专题——之Linux常用命令篇01

本文永久更新地址:https://my.oschina.net/bysu/blog/1931063 【若要到岸,请摇船:开源中国 不最醉不龟归】 Linux的历史之类的很多书籍都习惯把它的今生来世,祖宗十八代都扒出来,美其名曰...

不最醉不龟归
19分钟前
3
0
蚂蚁金服Java开发三面

8月20号晚上8点进行了蚂蚁金服Java开发岗的第三面,下面开始: 自我介绍(要求从实践过程以及技术背景角度着重介绍) 实习经历,说说你在公司实习所做的事情,学到了什么 关于你们的交易平台...

edwardGe
26分钟前
7
0
TypeScript基础入门 - 函数 - this(三)

转载 TypeScript基础入门 - 函数 - this(三) 项目实践仓库 https://github.com/durban89/typescript_demo.gittag: 1.2.4 为了保证后面的学习演示需要安装下ts-node,这样后面的每个操作都能...

durban
36分钟前
0
0
Spark core基础

Spark RDD的五大特性 RDD是由一系列的Partition组成的,如果Spark计算的数据是在HDFS上那么partition个数是与block数一致(大多数情况) RDD是有一系列的依赖关系,有利于Spark计算的容错 RDD中每...

张泽立
43分钟前
0
0
如何搭建Keepalived+Nginx+Tomcat高可用负载均衡架构

一.概述 初期的互联网企业由于业务量较小,所以一般单机部署,实现单点访问即可满足业务的需求,这也是最简单的部署方式,但是随着业务的不断扩大,系统的访问量逐渐的上升,单机部署的模式已...

Java大蜗牛
58分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部