我已经离开 ruby 一段时间了,我注意到 1.9.3 中有一些非常奇怪的东西(至少对我来说是这样)。也许有人可以向我解释一下。
我试图将一个字符串分成几行,所以我做了 string.split('\n')
,但这让我很痛苦。
最终我找到了使用单引号而不是双引号的问题。即 string.split("\n")
在追踪的过程中,我注意到了一些事情
'\n'.ord == 92
"\n".ord == 10
'\'.ord
不是有效的 ruby'\\'.ord == 92
我的唯一理论是单引号导致 ruby 不解析字符串,因此将 \n
视为两个字符。但是,如果是这种情况,为什么 '\'
没有通过处理器?
我错过了什么吗?为什么 split 不能将字符串转换为正确的 ascii?
附言这是一些测试代码来说明我的观点
"asdf\nasdf".split('\n').size #=> 1
"asdf\nasdf".split("\n").size #=> 2
最佳答案
'\n'
是一个包含 2 个字符 \
和 n
的字符串。
"\n"
是一个包含 1 个字符的字符串,新行字符 (LF),ASCII 码 10
。
当您使用双引号时,\
用于转义特殊字符。
关于ruby - "\n"与 '\n' 的奇怪之处,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11641950/