19 August 2015
这个问题困扰了我很久,去看了官方文档,看不懂。。。

昨天遇到一个问题,strings.TrimRight("cyeamblog.go", ".go")结果居然是"cyeambl",这让我百思不得其解。当然,要看官方文档的解释:

func TrimRight(s string, cutset string) string TrimRight returns a slice of the string s, with all trailing Unicode code points contained in cutset removed.

func TrimSuffix(s, suffix string) string TrimSuffix returns s without the provided trailing suffix string. If s doesn’t end with suffix, s is returned unchanged.

TrimSuffix能看明白,这也是我想要用的,符合我的要求。但是这个TrimRight怎么看也不知道有啥区别。除了代码结果不一样以别的都不清楚了。今天去大Google上面去搜,看到这个标题Is this a bug? strings.TrimRight seems to be cutting too much,乐死我了。我也是这样想的呀,只不过不好意思上去问。

看了这个算是弄明白了。大概解释说明一下,TrimRight会把第二个参数字符串里面所有的字符拿出来处理,只要与其中任何一个字符相等,将其删除。也就是cutset参数所有字符排列组合的形式进行删除。

最否附上一个例子:

package main

import (
	"log"
	"strings"
)

func main() {
	log.Println(strings.TrimRight("abba", "ba"))
	log.Println(strings.TrimRight("abcdaaaaa", "abcd"))
	log.Println(strings.TrimSuffix("abcddcba", "dcba"))
}

结果:

2015/08/13 15:56:30
2015/08/13 15:56:30
2015/08/13 15:56:30 abcd

本文所涉及到的完整源码请参考


参考文献
  1. Is this a bug? strings.TrimRight seems to be cutting too much.. - golang-nuts

原文链接:Golang strings包的TrimRight和TrimSuffix的区别,转载请注明来源!

EOF