文章摘要
这篇文章介绍了一个使用Go语言的格式化字符串实现动态效果的代码示例。通过在控制台中使用“r”命令符,可以在每次循环中输出特定字符,从而覆盖之前的输出并实现动态效果。代码中使用了递归方法计算斐波那契数列来延缓程序退出,并通过协程和睡眠函数来实现长时间的动态输出。文章还解释了格式化字符串的基本概念和工作原理,强调了占位符和修饰符的作用。
目录序原理效果实验代码
格式化字符串(Format String)是在编程过程中,允许编码人员通过特殊的占位符,将相关对应的信息整合或提取的规则字符串。
简单地说,也就是我们编程过程中常用的空格附、换行符、制表符等。
格式化字符串包括格式化输入和格式化输出。
格式化字符串的本质,可以理解为是编码过程中,程序员调用相关格式化字符串的一个操作协议规定。
在这个协议规定中,程序员必须严格依照格式化字符中的占位符,严格进行相关的信息配置。错误的或者不当的信息配置,会导致程序运行失效,甚至未定义行为产生。
在编译过程中,编译器通常会首先对格式化字符串进行加载解析,获取其中的占位符以及各个占位符(可为空)的修饰符,针对占位符以及修饰符的要求,对后续的参数进行读取。通常,对于绝大多数库函数而言,这个过程通常是没有验证的。1
起的作用是回到行首,当前控制台输出,输出完以后回到当前行的行首。
具体示例如下,这样可以起到对输出字符的覆盖作用,进而实现如下动态效果:

这是一个利用go语言书写的代码,代码的主要作用如上面动态图所示。
其原理为,通过采用递归方式求解斐波那契数列,使得主程序在较长时间内不会结束。
在这期间,开辟一个协程,在协程内通过“\r”实现不断返回行首,进行不同字符的输出,进而实现程序运行效果。
package main
import (
“fmt”
“time”
)
func main() {
go spinner(100 * time.Millisecond)
const n=45
fibN :=fib(n) // slow
fmt.Printf(“\rFibonacci(%d)=%d\n”, n, fibN)
}
func spinner(delay time.Duration) {
for {
for _, r :=range `-\|/` {
fmt.Printf(“\r%c”, r)
time.Sleep(delay)
}
}
}
func fib(x int) int {
if x < 2 {
return x
}
return fib(x-1) + fib(x-2)
}
import (
“fmt”
“time”
)
func main() {
go spinner(100 * time.Millisecond)
const n=45
fibN :=fib(n) // slow
fmt.Printf(“\rFibonacci(%d)=%d\n”, n, fibN)
}
func spinner(delay time.Duration) {
for {
for _, r :=range `-\|/` {
fmt.Printf(“\r%c”, r)
time.Sleep(delay)
}
}
}
func fib(x int) int {
if x < 2 {
return x
}
return fib(x-1) + fib(x-2)
}
到此这篇关于Goland字符串格式化样式中“\r“的作用的文章就介绍到这了,更多相关字符串格式化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:Go 字符串格式化的实例代码详解
© 版权声明
文章版权归作者所有,未经允许请勿转载。