Effective Go(官方文档)笔记
Effective Go(官方文档)笔记
- 自己主动局部变量提升(编译期完毕?):return &...;
- 内置函数:
- new/make
- copy, append
- delete
- range(这是keyword吧?由于后面没有())
- array是值对象
- slice:引用array
- 2维切片(略)
- map
- if seconds, ok := timezone[tz]; ok { ...
- func (f *File) Read(buf []byte) (n int, err error) { ...
- 注意这里给*File类型添加了一个Read方法,buf是传出參数(slice是引用!
)
- 注意这里给*File类型添加了一个Read方法,buf是传出參数(slice是引用!
- fmt.Printf("...%d...", 1); //C风格的;
- fmt.Printf(os.stdout, args, ...); //C++风格的?这里args须要实现io.Writer接口(序列化?)
- %v, %#v
- %T
- type MyString string
- switch t := t.(type){ ... //Go的执行时内省是怎么实现的?这意味着每个value/ref都包括了一个type域字段吗?
- 变參:v ...interface{} ==> v... (不加...的单独v可看作slice,可应用range操作)
- func append(slice []T, elements ...T) []T
- append:实际上不能在执行时决定T的类型。需编译器在编译时的支持(所谓的builtin函数)
- defer:推迟到func结束前运行。即使是panic(函数作用域。非block)
- C/C++/Java程序猿能够理解为func内部总体包以try{...}finally{...}?
- 枚举:const { _= iota \n A B C ... }
- 变量组声明:var { ... }
- 每一个文件里的init():用于验证初始状态?
- sort回调:Len() int, Less(i, j int) bool, Swap(i, j int) //这相当于把排序对象当作一个C++里的RandomAccessIterator接口?
- 类型转换
- str := value.(string) //如类型不匹配则runtime error;
- net/http
- type Handler interface {
- ServHTTP(w ResponseWriter, req *Request)
- => 一旦有了Handler实例,向http注冊:http.Handle("/path", handler)
- type Handler interface {
- tie a channel to web page ?
- 为func扩展方法:
- type HandlerFunc func(ResponseWriter, *Request)
- func (f HandlerFunc) ServHTTP(w ..., req ...) { f(w, req) }
- _ = fd //unused, WebKit/Chromium里常常能够见到这样的写法,未使用的变量显式标记。未用到的代码要删除
- Embedding(type的组合)
- type struct里能够直接增加其它type的名字,无需变量名字。此时相当于type traits的mixin了?
- Share by communicating
- Goroutines:the stack starts small(可动态调整的栈)——这可能就是Go支持大规模并发程序的原因了
- <-chan:等待完毕消息(自己主动堵塞)
- * for循环变量(设为i)是重用的?=>
- go func(i ...){ ... )(i) //传递进闭包,产生新的副本
- i := i //名字的shadowing(这个特性C语言是没有的。C++的namespace能够觉得类似?)
- Channels of channels
- 并行:runtime.GOMAXPROCS(ncpu)
- panic/recover
- recover在unwinding时运行,即defer func() {...}中。
Effective Go(官方文档)笔记的更多相关文章
- docker官方文档笔记
Docker在 CentOS7.X上运行.Docker可能在其他EL7的兼容版本中成功安装,但是官方并未进行测试,因此也不提供任何支持. 系统环境要求 docker必须运行在64-bit的系统上,对于 ...
- Vue官方文档笔记(二)
23.$refs是什么东东? 通过在标签上设置ref属性,然后在Vue实例方法中可以通过$refs拿到这些标签,如: <input ref="input"> metho ...
- React官方文档笔记之快速入门
快速开始 JSFiddle 我们建议在 React 中使用 CommonJS 模块系统,比如 browserify 或 webpack. 要用 webpack 安装 React DOM 和构建你的包: ...
- Vue官方文档笔记
1.如何创建一个Vue实例对象? var vm = new Vue({ el: "#app", //标签id 或 标签类名 data:{ //双向绑定的数据 message: &q ...
- Spring 官方文档笔记---Bean
In Spring, the objects that form the backbone of your application and that are managed by the Spring ...
- pm2 官方文档 学习笔记
一.安装 1.安装 npm install pm2 -g 2.更新 npm install pm2 -g && pm2 update pm2 update 是为了刷新 PM2 的守护进 ...
- vue.js 2.0 官方文档学习笔记 —— 01. vue 介绍
这是我的vue.js 2.0的学习笔记,采取了将官方文档中的代码集中到一个文件的形式.目的是保存下来,方便自己查阅. !官方文档:https://cn.vuejs.org/v2/guide/ 01. ...
- Swift -- 官方文档Swift-Guides的学习笔记
在经历的一段时间的郁闷之后,我发现感情都是虚伪的,只有代码是真实的(呸) 因为看了swift语法之后依然不会用swift,然后我非常作死的跑去看官方文档,就是xcode里自带的help>docu ...
- ios学习笔记第四天之官方文档总结
start developing ios app today. 官方文档的体系结构为: 各层的主要框架图: objectice-c是动态语言 Objective-C 为 ANSI C 添加了下述语法和 ...
随机推荐
- python闭包函数、装饰器
闭包函数的传值方式: 方式1:通过参数传值 def func(x): print(x)func(1) 方式2:闭包函数传值 def outter(x): def inner(): print(x) r ...
- Wannafly挑战赛3
B遇见 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 65536K,其他语言131072K64bit IO Format: %lld 题目描述 A和B在同一条路上,他们之间的距离为 k ...
- C语言遇到的小问题
堆栈区内存大小,2M或者4M,如果char够用,你就按照char去开,就只有int的1/4啦 printf("%s",s[i])不能运行 case 's': s = va_arg( ...
- cf- 297 < a >--字符串操作技巧
A. Vitaliy and Pie time limit per test 2 seconds memory limit per test 256 megabytes input standard ...
- [HDNOIP2017提高组]题解
(送给外省的同学们:HD = 海淀) [HDNOIP201701]小鱼干 试题描述 小喵喵有 n 个小鱼干排成一列,其中第 i 个小鱼干有两种属性,美味度 ai 和特殊度 bi. 现在小喵喵要吃掉一些 ...
- java面试题之什么是多线程上下文切换
多线程会共同使用一组计算机上的CPU,而线程数大于给程序分配的CPU数量时,为了让各个线程都有执行的机会,就需要轮流使用CPU.不同的线程切换使用CPU发生的数据切换等就是上下文切换
- 【HDOJ5971】Wrestling Match(二分图,并查集)
题意:有n个人,m场比赛,x个人为good player,y个人为bad player, 每场比赛两个人分分别为good和bad,问good和bad是否会冲突 1 ≤ N≤ 1000,1 ≤M ≤ 1 ...
- 最有用的java面试题
1.什么是线程局部变量?(答案) 线程局部变量是局限于线程内部的变量,属于线程自身所有,不在多个线程间共享.Java 提供 ThreadLocal 类来支持线程局部变量,是一种实现线程安全的方式.但是 ...
- python print 在命令行打印带颜色
红色 :print "\033[1;31m%s\033[0m" %("ALY : %s" %(['a','b']))
- LeetCode OJ--Permutation Sequence *
求第k个排列. 刚开始按照一个排列一个排列的求,超时. 于是演算了一下,发下有数学规律,其实就是康托解码. 康托展开:全排列到一个自然数的双射 X=an*(n-1)!+an-1*(n-2)!+...+ ...