我曾经学习如何设置UG的后处理器,进入后处理构造器后,原来进行设置时,要用到tcl语言,自己不会但通过搜索网上的教程和程序,也能基本满足使用要求,但总是心里没底的感觉。
/ g6 f) i2 E0 G+ L7 d4 A原来这个tcl语言是可以学习的,有空下载点资料来学习一下。
- N+ w I( u# f6 l+ [6 d7 }资料:+ }8 p/ o/ b& k% r" Z
TCL语言 Tcl (最早称为“工具命令语言”"Tool Command Language", 但是目前已经不是这个含义,不过我们仍然称呼它为TCL)是一种 脚本语言。 由John Ousterhout创建。 TCL很好学,功能很强大。TCL经常被用于 快速原型开发,脚本编程, GUI和测试等方面。 Tcl (最早称为“工具命令语言”"Tool Command Language", 但是目前已经不是这个含义,不过我们仍然称呼它为TCL)是一种 脚本语言。 由John Ousterhout创建。 TCL很好学,功能很强大。TCL经常被用于 快速原型开发,脚本编程, GUI和测试等方面。TCL念作“踢叩” "tickle". Tcl的特性包括: * 任何东西都是一条命令,包括语法结构(for, if等)。 * 任何事物都可以重新定义和重载。 * 所有的数据类型都可以看作字符串。 * 语法规则相当简单 * 提供事件驱动给Socket和文件。基于时间或者用户定义的事件也可以。 * 动态的域定义。 * 很容易用C, C++,或者Java扩展。 * 解释语言,代码能够动态的改变。 * 完全的Unicode支持。 * 平台无关。Win32, UNIX, Mac 上都可以跑。 * 和Windows的GUI紧密集成。 Tk * 代码紧凑,易于维护。 TCL本身不提供面向对象的支持。但是语言本身很容易扩展到支持面向对象。许多C语言扩展都提供面向对象能力,包括XOTcl, Incr Tcl 等。另外SNIT扩展本身就是用TCL写的。 使用最广泛的TCL扩展是TK。 TK提供了各种OS平台下的图形用户界面GUI。连强大的Python语言都不单独提供自己的GUI,而是提供接口适配到TK上。另一个流行的扩展包是Expect. Expect提供了通过终端自动执行命令的能力,例如(passwd, ftp, telnet等命令驱动的外壳). 具体例子 下面是TCL程序的例子: #!/bin/sh # next line restarts using tclsh in path \ % k5 Y: i6 N) ^& q' W. V3 ]" x
exec tclsh ${1+"$@"} # echo server that can handle multiple # simultaneous connections. 8 R) b5 h/ U* K9 v9 B) V9 b, P
proc newConnection { sock addr port } { # client connections will be handled in # line-buffered, non-blocking mode
7 w/ n+ F; L& J( G6 d fconfigure $sock -blocking no -buffering line # call handleData when socket is readable " J. j* x% z4 B ]! w; D/ R* G W
fileevent $sock readable [ list handleData $sock ] }
$ n# I! Q$ T+ e0 c8 y. P. z proc handleData {
! v/ ^/ ]% x: h' ?7 r puts $sock [ gets $sock ] if { [ eof $sock ] } { close $sock } }
" M" A0 V; z! B3 \& G# l # handle all connections to port given # as argument when server was invoked # by calling newConnection
0 \ q9 ?- e% D* A4 Rset port [ lindex $argv 0 ] , D( Q" R4 j( R0 U8 c* A
socket -server newConnection $port # enter the event loop by waiting
+ P3 B% o- Y1 V1 N& z5 r5 Y # on a dummy variable that is otherwise # unused.
$ K: ~$ [* x4 `# L" N7 L C9 q0 X* v vwait forever
) Y7 J R7 C4 Z 另外一个TK的例子 (来自 A simple A/D clock) 它使用了定时器时间,3行就显示了一个时钟。 ' K- y- f) _6 U& m- y
proc every {ms body} {eval $body; after $ms [info level 0]} pack [label .clock -textvar time]
4 ]% f" \4 S" ]( j* v) x; s" h# o" k$ V every 1000 {set ::time [clock format [clock sec] 4 J9 p' j) ~: i2 v* n
-format %H:%M:%S]} # RS
) _8 N% m ? G8 r. E 解释:第一行定义了过程every, 每隔ms毫秒,就重新执行body代码。第二行创建了标签起内容由time变量决定。第3行中设置定时器,time变量从当前时间中每秒更新一次。
7 o( C1 k+ q' T- s) w8 f
* [; ?4 W0 Q" P7 y; Z8 F3 Y1 D
6 g9 X3 c0 T2 _3 F, P- Q
9 M( s) j' u- M |