编程语言
首页 > 编程语言> > Ruby中的常量:引号、%符号和heredoc

Ruby中的常量:引号、%符号和heredoc

作者:互联网

引号

引号和Perl中的引号类似。

例如,单引号不解释变量内插和反斜线序列等,双引号解释变量内插和反斜线序列等,反引号用于执行对应的命令。此外,反引号中可以进行变量内插,也就是说反引号中字符的会按照双引号进行解释,例如a=haha;str=`echo #{a} one line`得到的结果为str=haha one line

%符号

%用于简化常量的定义

下面的中括号边界符可以替换为其它对称符号或相同的符号。例如()<>||##

heredoc

heredoc和Perl的heredoc基本一样。

str1 = <<END
one line
END
# str1="one line"

a="one line"
str2 = <<"END"
#{a}
END
# str2="one line"

a="one line"
str3 = <<'END'
#{a}
END
# str3="#{a}"

a="one line"
str4 = <<`END`
echo haha #{a}
END
# str4="haha one line"

heredoc的起始符前可以加上一个短横线"-",使得终止符可以缩进编写,还可以使用~,使得正文和结束符都能缩进,但返回的结果不缩进。例如:

str1 = <<-ONE
one line
  ONE          # 终止符ONE缩进了

str2 = <<-"TWO"
two\nline      # 换行符被解释
  TWO

puts <<~END
  one line    # 结果中,这两行没缩进
  two line
END

heredoc的起始行中起始符后面的内容不会被解释。所以:

arr = [<<END, "two", "three"]  # END后面的不会解释
one line
END

# arr = ["one line", "two", "three"]

事实上,当Ruby解释器遇到<<的时候就立即跳转到它下面的行中读取数据直到遇到结尾符号,然后重新回到here doc的开头行继续向后读取,所以上面<<ENDEND中间的行先被读取,读取完END之后回头读two、three字符串。

heredoc可以堆叠多个doc栈。例如:

arr = [<<ONE, <<TWO, <<THREE,]
one line
ONE
two line
TWO
three line
THREE

# arr=["one line", "two line", "three line"]

标签:解释,shell,heredoc,引号,符号,Ruby,表达式
来源: https://www.cnblogs.com/f-ck-need-u/p/10805582.html