基礎概念
程式塊 (chunk)
定義
- lua 中的每一個源代碼檔案或在互動模式(Cmd)中輸入的一行代碼都稱之為程式塊
- 一個程式塊就是一連串陳述句或者命令
- lua 中連續的陳述句不需要分隔符,但為了可讀性可以加換行,或者分隔符分號 ; 來分割陳述句
- 但是換行在代碼中沒有任何作用,僅僅是為了提高可讀性
a = 1
b = a * 2
a = 1;
b = a * 2
a = 1; b = a * 2
a = 1 b = a * 2
一個程式塊可以僅包含一條陳述句,也可以由多條不同的陳述句或函式的定義構成
- 程式塊可以是任意大小的
- 可以將程式塊保存在檔案中然后再執行
- 也可以將程式塊放到互動模式中運行解釋器
當不使用任何引數直接運行解釋器時會看到這樣得提示符
Lua 5.1.5 Copyright (C) 1994-2012 Lua.org Puc-Rio
>
- 在這種模式下輸入得每條命令都將立即被執行
- 要退出互動模式和解釋器
- 可以呼叫作業系統庫的 exit 函式,輸入 os.exit()
- 或者 end-of-file 控制字符,在 DOS/Windows 中是 Ctrl + Z
- 在互動模式中解釋器通常將所輸入的內容當作一個完整的程式塊來解釋
- 如果解釋器檢測到某行所輸入的內容不足以構成一個完整的程式塊,那么它就會等待輸入
- 這種機制的存在使得我們可以在互動模式中輸入某些函式的多行定義
但將多行內容放入檔案中才是更常見的做法
- 在互動模式中通過呼叫解釋器來執行檔案
-- fact.lua 階乘檔案
function fact(n)
if n == 0 then
return 1 --0的階乘是1
else
return n * fact(n - 1) --輸入3會執行 3 * 2 * 1
end
end
print("Enter a number:")
a = io.read("*number")
print(fact(a))
-i 引數
- 通過 -i 引數來啟動解釋器
- lua -i prog
- 這樣會先運行檔案 prog 中的程式塊后再進入互動模式
讀取用戶輸入并指定格式
- io.read("*number") 讀取數字格式
dofile 函式
- 立即執行一個函式檔案
- 運行后如果無報錯
- 相當于加載了這個lua 檔案中的函式庫
- 就可以在后續的互動模式中直接呼叫這個函式庫里定義的方法
- 方便測驗新的代碼,在代碼編輯器中修改后在互動模式中執行dofile即加載修改后新的代碼
- 使用 dofile 后里面字串檔案路徑的 \ 記得再用一次 \ 進行轉義
- 如:dofile("d:\\demo\\a.lua")
-- lib1.lua
-- 計算兩個數的平方和在開平方根
function norm(x, y)
return (x ^ 2 + y ^ 2) ^ 0.5
end
-- 計算某數的兩倍
function twice(n)
return n * 2
end
> dofile("lib1.lua") -- 加載你撰寫的程式庫,需要填完整的檔案路徑
> n = norm(3.14, 1.0) -- 3.2953907203851
> print(twice(4)) -- 8
詞法規范
識別符號
- 可以由任意字母、下劃線、數字構成的字串
- 但不可以由數字開頭
避免使用以一個下劃線開頭之后跟著一個或多個大寫字母的識別符號
- lua 會將這些識別符號保留,用作特殊用途
- 如 _VERSION, _PROMPT
- 因為這是 lua 中的啞變數
區域設定(Locale)
- 在 lua 中什么是字母的概念依賴于區域設定(Locale)
- 如果設定了對應的區域如希臘,就可以使用希臘字母作為變數名了
- 但這樣的變數可能無法在不支持該區域的系統上運行
保留字
- and
- break
- do
- else
- elseif
- end
- false
- for
- function
- id
- in
- local
- nil
- not
- or
- repeat
- return
- then
- true
- until
- while
lua中區分大小寫,如 "And" "AND" 是可以作為變數的,且與保留字 and 完全不同
注釋的寫法
- 單行注釋:--code block
- 多行注釋:--[[ code block ]]
- 一旦寫了注釋后面的代碼將不會起作用,解釋器會將其忽略
- 小技巧:建議這樣寫多行注釋 --[[ code block --]]
- 可以在塊注釋前加一個連字符 - 即可啟用代碼塊中的代碼
--[[
print(222)
print(666) --都不起作用(因為塊注釋注釋掉了其中的代碼)
--]]
-- 常規寫法加一個連字符寫塊注釋
---[[
print(222)
print(666) --會報錯
]]
-- 推薦寫法加一個連字符寫塊注釋
-- 因為這樣寫的話,第一行和最后一行就變成了兩個彼此獨立的單行注釋
---[[
print(222)
print(666)
--]]
-- 在注釋塊中包含注釋,在不加 = 的時候會報錯
-- 可以在注釋 --[任意個=[]]與之前匹配的任意等號]
--[==[
--[[
print("在多行注釋中輸入多行注釋")
--]]
-- print("在多行注釋中輸入單行注釋")
--]==]
全域變數
- 全域變數不需要宣告
- 只需要將一個值賦給這個全域變數即可創建
- 在 lua 中訪問一個未初始化的變數并不會發生錯誤
- 但訪問的結果是一個特殊的值 nil ,也就是空值
- 洗掉全域變數,將它賦值為 nil
print(b) -- nil
b = 10
print(b) -- 10
-- 洗掉全域變數
b = nil
print(b) -- nil
解釋器程式
- [] 代表可選項
- lua [選項引數] [腳本[引數]]
- 不使用引數會直接進入互動模式
- -e 直接在命令列中輸入代碼
- 如果只有 -e ,沒有 -i 那么就不會進入互動模式,而是運行后直接結束
- -l 用于加載庫檔案
_PROMPT
- 修改這個全域變數,就會修改互動模式下的命令提示符
- 外面的雙引號用于阻止 shell 誤解內層的單引號
lua -i -e "_PROMPT = 'lua>'"
Lua 5.1.5 Copyright (C) 1994-2012 Lua.org, PUC-Rio
lua>
在互動模式中列印任何運算式的值
- print()
- 也可以使用等號開頭后面跟一個運算式 =
在解釋器執行其引數前
- 先會尋找一個 LUA_INIT 的環境變數
- 如果找到了,并且它的內容為 @檔案名 的話
- 解釋器就會先執行這個檔案
- 如果 LUA_INIT 沒有以 @ 開頭,解釋器就假設變數內容為 lua 代碼,并運行這段 lua 代碼
- LUA_INIT 可以靈活地配置解釋器,并且可以完全控制如何配置它
- 比如:可以預先加載一個程式包(Package)、修改命令提示符和路徑、定義函式、對函式進行改名或洗掉等,
運行腳本前的引數
- 在腳本代碼中,可以通過全域變數 arg 來檢索腳本的啟動引數
- 解釋器在運行腳本前,會用所有的命令列引數創建一個名為 arg 的 table
- 腳本名稱位于索引 0 上
- 它的第一個引數(示例中的 a) 位于索引1 ,以此類推
- 而在 腳本檔案(示例中的 script ) 之前的的所有選項引數位于負數索引上
lua 腳本 a b c
lua -e "sin = math.sin" script a b
-- 解釋器將所有引陣列織排列為:
arg[-3] = "lua"
arg[-2] = "-e"
arg[-1] = "sin = math.sin"
arg[0] = "script"
arg[1] = "a"
arg[2] = "b"
- 通常腳本只會使用正數索引(示例中的 arg[1] 和 arg[2])
- 在 lua 5.1 中,一個腳本還可以通過 “變長引數語法” 來檢索其引數
- 在腳本主體中,運算式 "..." 3個點表示所有傳遞給腳本的引數
心得體會
第一日復習
- local 區域變數使用
- return 用于回傳
- if, elseif, then, end, 用于條件判斷程式結構
- for, while, then, end 用于回圈程式結果
- and, not, or 用于邏輯判斷
- function 用于定義函式
- true false 用于條件值的判斷
- nil 用于將全域變數、table中的元素銷毀,也是變數在未賦值之前的默認值
沒有熟練掌握的保留字
- break
- true
- false
- in
- local
- nil
- not
- return
- while
第二日復習
流程控制保留字
- if
- then
- end
- elseif
- for
- do
- while
- until
- repeat
- break
條件判斷保留字
- true
- false
邏輯判斷保留字
- and
- or
- not
其他保留字
- in
- return 回傳
- function 函式
沒記住的保留字
- id
- nil 表示為空,用于清除變數、table元素
- local 區域變數
在 解釋器執行引數前
概念錯誤,且沒有記住后續步驟
- LUA_INIT的變數
- 找到了 @檔案名
- 沒找到
在 lua 運行腳本前的引數
沒有記住所有的內容和概念
程式塊、互動模式、解釋器
記憶的概念沒有匹配對應名稱,記憶混亂的情況
第三日復習
流程控制保留字
if, elseif, then ,end, break, for, do, return, while, until, repeat
型別保留字
nil, function, local
其他
in, id
邏輯判斷
and, or, not
條件判斷
true, false
在解釋器執行引數前
- 會先尋找一個名為 LUA_INIT 的環境變數
- 找到了并且內容為 @檔案名,就會執行這個檔案
- 沒找到,就執行解釋器中輸入的內容 【錯誤】
沒找到,就假設這個變數為 lua 代碼,并執行
第三步記憶和理解出錯
運行腳本前的引數
- 會建立一個名為 arg 的 table 把這些引數全部存進去
- 腳本名 為索引 0, 其后的引數以此類推
- 腳本名前的引數為負數
- 一般不會使用負數索引
- 可變長度引數 ... 【記憶混亂】
需要記憶的點
-
【全域變數 arg】 檢索啟動引數
-
... 表示所有傳遞給腳本的引數
-
腳本可通過變長引數語法來檢索引數
-
全域變數的創建概念和宣告
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/5311.html
標籤:其他
上一篇:DirectX11 With Windows SDK--30 計算著色器:高斯模糊、索貝爾算子
下一篇:lua學習之運算式篇
