ROT13 使用字节而不是字符串

ROT13 using bytes rather than strings

我正在尝试将 rot13 翻译添加到我的工具中。 客户端基本代码:

....
buf := make([]byte, 1024)

for {

    n, err := in.Read(buf)
    .....

    for _, chunk := range split(r, buf[:n], sizes) {
        if _, err := out.Write(chunk); err != nil {
        ......

因为我希望它使用字节而不是字符串,所以我想到了这个:

https://play.golang.org/p/m3NvoZIyS8g

这个例子有效,预计会有一些我不明白的额外字节,它们用***下划线:

bytes after  ***{***[89 111 117 32 99 114 97 99 107 101 100 32 116 104 101 32 99 111 
100 101 
32 32 32 32 32 32 32 239 191 189 85 239 191 189 239 191 189 239 191 189 74 40 239 191 
189 47 239 191 189 86 239 191 189 45 239 191 189 33] ***0 0}***

string after ***{***You cracked the code       �U���J(�/�V�-�! ***%!s(int=0)*** 
***%!s(bytes.readOp=0)}***

请忽略带有“��U����J(��/��V��-��!”的部分,我只是需要用这个“字符串”进行一些确认

如何摆脱这些多余的“东西”? 有没有更好的方法来实现我的想法?

这些是 fub 后备数组中剩余的可用字节。

而且因为你是原始打印,所以它显示了它的所有内部结构。

你想写 : fmt.Printf("bytes after %v\n", fub.Bytes()) 只得到写在上面的部分。

同样适用于字符串表示,使用fmt.Printf("string after %s\n\n", fub.String())

您看到的是 fmt.Printf 通过反射将此 struct type 的值呈现为字符串的最佳尝试。

你想要:

var fub bytes.Buffer

// fmt.Printf("string after  %s\n\n", fub)

fmt.Printf("string after  %s\n\n", &fub) // fix
fmt.Printf("string after  %s\n\n", fub.String()) // or this

为什么这行得通?检查 bytes.Bufferdocs 你可以看到 String() string 方法需要一个指针接收器,所以如果你想利用像 fmt.Printf 这样基于反射的函数来利用它,你必须传入一个 *bytes.Buffer 类型的值。