标签:style blog http color strong io for cti
This tutorial will give a brief overview of the defun function and moreover explain why localising variables is a good habit to get into.
(defun <symbol> ([arguments] [/ variables]) <expressions>)
Here:
(defun test ( arg1 arg2 / var1 var2 ) ;; Function taking two arguments, with two local variables ;; Expressions (setq var1 (* arg1 2.0) var2 (+ arg2 3)) (print (- var2 var1)) (princ) ) ;; End of defun
(defun c:MyCommand ( / a b c ) ;; Function with three local variables (setq a 1.0 b 2 c 3) (print (- b (/ a c))) (princ) )
(defun myfunc ( x y ) ... ) ;; Function takes two arguments (defun myfunc ( / a b ) ... ) ;; Function has two local variables (defun myfunc ( x / temp ) ... ) ;; One argument, one local variable (defun myfunc ( ) ... ) ;; No arguments or local variables
Take this example (Notice no variables are localised):
(defun c:test ( ) (foreach x ‘(1 2 3 4 5) (setq lst (cons x lst)) ) (print lst) (princ) )
Return:
(5 4 3 2 1)
if we run the code again, we receive:
(5 4 3 2 1 5 4 3 2 1)
The list has doubled! This is because the variable lst still holds the list data even after the function has completed.
Hence, when evaluated for the second time, new values are added the existing list.
;;x可认为是foreach的形参,调用的时候IDE自动声明为局部变量了。
This certainly highlights one major issue, but what if we had another function, also without localised variables, using the same symbol for a variable name?
(defun c:test1 ( ) (foreach x ‘("1" "2" "3" "4" "5") (setq lst (cons x lst)) ) (print lst) (princ) )
Upon running the above code, we now have a list containing a mixture of data types:
("5" "4" "3" "2" "1" 5 4 3 2 1 5 4 3 2 1)
To avoid these issues, we localise the variables:
(defun c:test ( / lst ) (foreach x ‘(1 2 3 4 5) (setq lst (cons x lst)) ) (print lst) (princ) )
Localising Variables 局部变量,布布扣,bubuko.com
标签:style blog http color strong io for cti
原文地址:http://www.cnblogs.com/Giraffie/p/3875046.html