不可恢復的錯誤是檢測到的錯誤,程式員無法處理它。 當發生這種錯誤時,panic!
宏會被執行。panic!
列印失敗消息。 panic!
清理堆疊然後退出。
展開(Unwinding):展開是一個清理它遇到的每個函數的堆疊記憶體中的數據的過程。 但是,展開過程需要大量工作。Unwinding
的替代方案是Aborting
。
中止(Aborting):中止是在不清除堆疊記憶體中的數據的情況下結束程式的過程。操作系統將刪除數據。如果從展開切換到中止,那麼需要添加以下語句:
panic = 'abort';
下麵來看一個panic!
宏的簡單示例:
fn main()
{
panic!(?No such file exist?);
}
執行上面示例代碼,得到如下結果 -
在上面的輸出中,第一行顯示錯誤消息,它傳達兩個資訊,即panic
消息和錯誤的位置。 panic
消息是“沒有這樣的檔存在” 和 error.rs:3:5
表示檔的第三行和第五個字元。
注意:一般來說,不實現
panic!
在程式代碼中,包含檔案名和行號的錯誤消息可以在其他人的代碼中調用panic!
宏。
panic!的好處
Rust語言沒有緩衝區重讀問題。緩衝區重寫是一種情況,當從緩衝區讀取數據並且程式超出緩衝區時,即它讀取相鄰的記憶體。 這導致違反記憶體安全。
下麵來看一個簡單的例子:
fn main()
{
let v = vec![20,30,40];
print!("element of a vector is :",v[5]);
}
執行上面示例代碼,得到以下結果 -
在上面的例子中,試圖訪問索引5
所在的第六個元素。在這種情況下,Rust會因為訪問無效索引而引發panic
。 因此,Rust不會返回任何內容。
但是,對於其他語言(如C和C++),它們會返回一些內容,儘管該向量不屬於該記憶體。 這稱為緩衝區重寫,它會導致安全問題。
Rust回溯
Rust回溯是調用的所有函數的列表,用於瞭解“導致錯誤的原因”。 需要設置RUST_BACKTRACE
環境變數來獲取回溯。
上一篇:
Rust錯誤處理
下一篇:
Rust可恢復的錯誤