一个想当然的bug

许久不写Python,"".split(",") 的结果我已经不能脑内运算了:

In [1]: "".split(",")
Out[1]: ['']

我记成了 "".split(",") 的运算结果是 [],因此,昨天在debug这段代码(Golang)的时候花了我好一会儿:

$ cat main.go
package main

import (
	"fmt"
	"strings"
)

func main() {
	l := strings.Split("", ",")
	if len(l) > 0 {
		fmt.Printf("l: %+v\n", l)
	}
}

执行一下:

$ go run main.go
l: []

问题主要在于:

  • 我想当然的以为 "".split(",") 的结果会是一个空list
  • go的 fmt.Printf 真是一个大坑,空字符串你为啥不给我打出来?[""] 才是正确的打印方式呀!

解决方案

使用 %#v 替代 %+v:

$ cat main.go
package main

import (
	"fmt"
	"strings"
)

func main() {
	l := strings.Split("", ",")
	if len(l) > 0 {
		fmt.Printf("l: %#v\n", l)
	}
}
$ go run main.go
l: []string{""}


微信公众号
关注公众号,获得及时更新

更多文章
  • 使用Dropbox来备份服务器文件
  • 《计算机网络-系统方法》读书笔记
  • Y Combinator《如何创业》笔记
  • Go类型嵌套
  • etcd源码阅读与分析(五):mvcc
  • etcd源码阅读与分析(四):lease
  • 干了这碗叔本华牌毒鸡汤 --- 《人生的智慧》
  • Memory leak in net/http
  • etcd源码阅读与分析(三):wal
  • etcd源码阅读与分析(二):raft
  • etcd源码阅读与分析(一):raftexample
  • 虚拟机里的Ubuntu sudo时卡住
  • Go访问私有变量
  • Raft论文阅读笔记
  • 避免全局变量