萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> 淺析Lua編程中的異常處理

淺析Lua編程中的異常處理

   這篇文章主要介紹了淺析Lua編程中的異常處理,是Lua入門學習中的基礎知識,要的朋友可以參考下

  需要進行錯誤處理

  錯誤處理是必要的,因為真實世界中的操作通常需要使用復雜的操作,包括文件操作,數據庫事務和web服務調用。沒人關心錯誤的業務,涉及保密信息或金錢交易時造成大的損失。

  在任何編程,總是有錯誤處理的要求。錯誤可以是兩種類型,其中包括,

  語法錯誤

  運行時錯誤

  語法錯誤

  因使用不當造成的各種程序組件,如運算符和表達式中出現語法錯誤。一個簡單的例子中的語法錯誤如下所示。

   代碼如下:

  a == 2

  如你所知,有使用單一等於和雙等於之間的差異。使用一個替代其他可導致錯誤。等於是指分配,比較。同樣,表示和有其預定實施這些方式的功能。

  另一例為語法錯誤如下所示。

  代碼如下:

  for a= 1,10

  print(a)

  end

  當我們運行上面的程序,會得到下面的輸出。

  代碼如下:

  lua: test2.lua:2: 'do' expected near 'print'

  語法錯誤更容易處理程序不是運行時錯誤,因為,Lua解釋更清楚地定位誤差比的情況下運行時錯誤。從上面的錯誤,我們可以很容易知道,添加do語句之前print語句,每個Lua結構所需要的。

  運行時錯誤

  如果運行時錯誤,程序執行成功,但它可能會導致在輸入或處理不當,功能運行時錯誤是由於錯誤。一個簡單的例子來顯示的運行時間誤差如下所示。

   代碼如下:

  function add(a,b)

  return a+b

  end

  add(10)

  當我們建立的程序,它會成功地建立並運行。一旦運行,它會運行並顯示一個運行時錯誤。

  代碼如下:

  lua: test2.lua:2: attempt to perform arithmetic on local 'b' (a nil value)

  stack traceback:

  test2.lua:2: in function 'add'

  test2.lua:5: in main chunk

  [C]: ?

  發生因不是通過兩個變量的運行時錯誤。 b參數的預期值是nil,並產生一個錯誤。

  維護和故障功能

  為了處理錯誤時,我們經常使用的兩個函數斷言和錯誤。一個簡單的例子如下所示。

   代碼如下:

  local function add(a,b)

  assert(type(a) == "number", "a is not a number")

  assert(type(b) == "number", "b is not a number")

  return a+b

  end

  add(10)

  當我們運行上面的程序,會得到下面的錯誤輸出。

   代碼如下:

  lua: test2.lua:3: b is not a number

  stack traceback:

  [C]: in function 'assert'

  test2.lua:3: in function 'add'

  test2.lua:6: in main chunk

  [C]: ?

  錯誤error (message [, level])結束最後一個被叫保護功能,並返回信息的錯誤消息。這個函數的錯誤不會返回。通常情況下,錯誤增加了約在郵件的開頭錯誤位置的一些信息。level參數指定如何得到錯誤的位置。級別1(默認值),錯誤位置是誤差函數被調用。 2級分錯誤的地方調用錯誤的函數被調用等等。傳遞一個0級可避免增加錯誤的位置信息的消息。

  pcall和xpcall

  在 Lua 編程,以避免引發這些錯誤和處理錯誤,需要使用的功能 pcall 或 xpcall。

  pcall (f, arg1, ...)函數調用保護模式所要求的功能。如果函數f 出現了一些錯誤,但不會引發錯誤。它只是返回錯誤的狀態。使用pcall 一個簡單的例子如下所示。

  代碼如下:

  function myfunction ()

  n = n/nil

  end

  if pcall(myfunction) then

  print("Success")

  else

  print("Failure")

  end

  當我們運行上面的程序,會得到下面的輸出。

  代碼如下:

  Failure

  xpcall (f, err) 函數調用所要求的功能,還設置了錯誤處理程序。f 任何錯誤不傳播; 相反,xpcall 捕獲錯誤,要求與原來的錯誤對象Err函數,並返回一個狀態代碼。

  一個簡單的例子為 xpcall 如下所示。

    代碼如下:

  function myfunction ()

  n = n/nil

  end

  function myerrorhandler( err )

  print( "ERROR:", err )

  end

  status = xpcall( myfunction, myerrorhandler )

  print( status)

  當我們運行上面的程序,會得到下面的輸出。

    代碼如下:

  ERROR: test2.lua:2: attempt to perform arithmetic on global 'n' (a nil value)

  false

  作為一個程序員最重要的是要確保正確的錯誤處理。使用錯誤處理可以確保超出邊界條件意想不到的條件,而不會干擾該程序的用戶進行處理。

copyright © 萬盛學電腦網 all rights reserved