前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >变量赋值

变量赋值

作者头像
Lauren的FPGA
发布2019-10-31 00:25:14
2.5K0
发布2019-10-31 00:25:14
举报
文章被收录于专栏:Lauren的FPGALauren的FPGA

上期内容:Tcl是什么?

Tcl脚本的构成如图所示,可以只包含一条命令,也可以包含多条命令,命令之间可以是分号隔开,也可以是换行。如下图所示。

采用分号或换行作为命令之间的分隔符,其区别在于分号促使其左侧命令不会显示输出结果。如下图所示。由此可见,尽管以分号作为命令之间的分隔符可使代码更为紧凑,但也降低了调试过程中命令结果的可视性。从代码风格的角度将,换行可提升代码的可读性。

Tcl中的命令是由一个或多个单词构成,单词之间以空格或TAB键隔开,且第一个单词为命令名,其余单词为该命令的参数。如下图所示。该命令由3个单词构成,其中命令名为set,该命令包含两个参数,第1个参数为变量名,第2个参数为变量值。

若给命令set提供额外的参数,则会报错,如下图所示。

Tcl中的变量名并不遵循C语言中变量名的命名规则,如下图所示。可以看到,变量名以下划线作为开头是可以接受的。这也反应了Tcl的特征“一切都是字符串”。

Tcl对命令的求值过程分为两步:解析和执行。在解析阶段,Tcl解释器运用规则把命令分解为一个个独立的单词,同时进行必要的置换(Substitution,关于置换将在下一篇文章中介绍);在执行阶段,Tcl解释器会把第一个单词当作命令名,并查看该命令是否有定义,同时查找完成该命令功能的命令过程。如果有定义,Tcl解释器就调用该命令过程,把命令中的全部单词传递给该过程。命令过程会根据自己的需求来分辨这些单词的具体含义。

unset命令与set命令相反,该命令将取消变量定义并释放该变量所占的内存空间,但取消未定义的变量是不合法的。如下图所示。

结论:

-Tcl命令 = 命令名+ 命令参数

-Tcl命令求值过程:解析 + 执行

-两个命令:set, unset

如果文章对你有收获,欢迎转发~

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Lauren的FPGA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档