Go简单字符串插值特性实例分析
这篇文章主要讲解了“Go简单字符串插值特性实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go简单字符串插值特性实例分析”吧!
fmt.Printf 或 fmt.Sprintf 写拼装字符串业务
在日常开发 Go 工程中,我们经常会用 fmt.Printf
或 fmt.Sprintf
去写类似的拼装字符串的业务。
如下代码:
fmt.Printf("Hello Gopher %s, you are %d years old and you're favorite food is %s", name, age, favoriteFood)
这业务迭代迭代着,日积月累的,有一部分常变的拼装逻辑会来越长。小小的电脑显示屏已经不足以让代码在一行内显示了。
有许多特性会把字符串转为变量,但后面那串又臭又长的变量依然无法简单甩掉,因此有大部分同学会选择把代码格式化了。
如下代码:
s := "Hello Gopher %s, you are %d years old and you're favorite food is %s"fmt.Printf( s, name, age, favoriteFood,)
你可能以为这是个例?实际并不,很多人都遇到了。
简单字符串插值
这个新特性,类似于 Swift 中的字符串插值的简单版本。我们直接看例子:
fmt.Println("\(person.Name()) is \(person.Age()) years old")fmt.Println("The time is \(time.Now().Round(0))")
对应的输出结果:
Ken Thompson is 79 years old
The time is 2023-01-04 16:22:01.204034106 -0800 PST
提案计划新增的 “字符串插值”,规范如下:
新转义语法:
\(xxxx)
,开头是\(
,结尾是)
,成对出现。在格式上,一个有效的
\(
,后面必须有一个表达式和一个尾部的)
,这样才能生效。
上面的例子中,以下几个都是字符串插值:
\(person.Name())\(person.Age())\(time.Now().Round(0))
会有同学疑惑像 person
看起来就是结构体的是怎么取值的?
Go 有一个神奇的约定方法,像结构体这类类型,如果有 String() string
方法,将会调用该方法以获取字符串值。
如果没有 String 方法,需要是字符串、整数、浮点数、复数、常量或布尔值等类型,可以取值后格式化。否则将会报错。
其他语言例子
Swift
let multiplier = 3let message = "\(multiplier) times 2.5 is \(Double(multiplier) * 2.5)"// message is "3 times 2.5 is 7.5"
Kotlin
var age = 21println("My Age Is: $age")
C
string name = "Mark";var date = DateTime.Now;Console.WriteLine($"Hello, {name}! Today is {date.DayOfWeek}, it's {date:HH:mm} now.");
Rust
let person = get_person();println!("Hello, {person}!"); // captures the local `person`println!("Hello, {}!", get_person()); // implicit positionprintln!("Hello, {0}!", get_person()); // explicit indexprintln!("Hello, {person}!", person = get_person()); // namedlet (width, precision) = get_format();for (name, score) in get_scores() { println!("{name}: {score:width$.precision$}");}
争论矛盾点
当前的主要争论点之一,像是 fmt.Sprintf
等方法也可以完成字符串插值一模一样的效果,为什么还要新增这个功能特性(或是语法糖)?
主流观点是现有的格式化字符串的方法,在参数数量多了后,很容易出错(例如:顺序搞错),也比较松散,一大坨代码。
在新增字符串插值的特性/语法糖后,可以更好阅读、更好修改,不需要过于依赖编写变量的顺序、更紧凑。
具体的例子如下,现有版本代码:
errorf(pos, "arguments to copy %s and %s have different element types %s and %s", x, &y, dst.elem, class="lazy" data-src.elem)
应用新特性后会变成:
error(pos, "arguments to copy \(x) and \(&y) have different element types \(dst.elem) and \(class="lazy" data-src.elem)")
感谢各位的阅读,以上就是“Go简单字符串插值特性实例分析”的内容了,经过本文的学习后,相信大家对Go简单字符串插值特性实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341