一个想当然的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{""}

  • https://github.com/golang/go/issues/11139
  • https://golang.org/pkg/fmt/?m=all#hdr-Printing

更多文章
  • Golang实现平滑重启(优雅重启)
  • traefik 教程
  • Web开发系列(十):事务和锁
  • Web开发系列(十一):数据库扩展
  • Web开发系列(九):消息队列,异步任务
  • Nginx作为TCP/UDP的负载均衡
  • Web开发简介系列
  • Web开发系列(八):单点故障,负载均衡
  • Web开发系列(七):缓存,CDN
  • Nginx 请求匹配规则