1)简单变量
一个TCL简单变量包含两个部分:名字和值。
名字和值都可以是任意字符串,可以包含任意字符和长度。但是变量名称最好按C/C++语言中标识符的命名规则命名。
Tcl解释器在分析一个变量置换时,只把从$符号往后直到第一个不是字母、下划线或数字的字符之间的单词符号作为要被置换的变量的名字。
来看例子:
set用于指定变量的值。
语法:set varname value
在最后一个命令行,我们希望将变量a.1的值赋给b,但是TCL解释器在分析时只把$符号之后直到第一个不是字母、数字或下划线的字符(这里是‘.’)之间的单词符号
(这里是‘a’)当作要被置换的变量的名字。
所以TCL解释器把a置换成5,然后把字符串”5.1”赋给变量b。
若变量名中含有不是字母、数字或下划线的字符时,又要用置换怎么办呢?
可以用花括号{}将变量名括起来。
2)局部变量和全局变量
对于在过程proc中定义的变量,因为它们只能在过程中被访问,过程结束时会被自动删除,所以称为局部变量。
在所有过程之外定义的变量我们称为全局变量。
TCL中,局部变量和全局变量可以同名,两者的作用域的交集为空。
局部变量的作用域是它所在的过程的内部,全局变量的作用域则不包括所有过程的内部。这一点和C语言有很大的不同。
如果我们想在过程内部引用一个全局变量的值,可以使用global命令。
全局变量b在过程add中被访问。
在过程add中对b的改变会直接反映到全局上,如果去掉语句global b,TCL会出错,因为在过程add中不认识变量b。
expr用于计算求值。
3)Tcl中,可以用set_precision来设置精度
对于无穷小数,TCL标准输出为12位有效数字,对于一般计算来说足够了。
如果觉得不够,我们可以使用内置的变量tcl_precison来控制精度,不过纵然使用了tcl_precison,最高也只能设置为17(有效数字,不包括小数点)。
但是目前当我们没有设置tcl_precision时,解释器自带的是0.
如何让两个整数相除得到一个浮点数呢?
1)一种方法是对两个整数的任意一个(或两个)添加.0
2)使用double进行转化。