panic!
panic! マクロを使うと、パニックを生成し、そのスタックの巻き戻しを開始できます。巻き戻し中、ランタイムはそのすべてのオブジェクトのデストラクタを呼び出すことで、スレッドが_所有_するすべてのリソースの解放を処理します。
ここではスレッドが1つだけのプログラムを扱っているため、panic! はプログラムにパニックメッセージを報告させて終了させます。
// 整数除算 (/) の再実装 fn division(dividend: i32, divisor: i32) -> i32 { if divisor == 0 { // ゼロ除算はパニックを引き起こします panic!("division by zero"); } else { dividend / divisor } } // `main` タスク fn main() { // ヒープに割り当てられた整数 let _x = Box::new(0i32); // この操作はタスクの失敗を引き起こします division(3, 0); println!("This point won't be reached!"); // この時点で `_x` は破棄されるはずです }
panic! がメモリをリークしないことを確認してみましょう。
$ rustc panic.rs && valgrind ./panic
==4401== Memcheck, a memory error detector
==4401== Copyright (C) 2002-2013, and GNU GPL'd, by Julian Seward et al.
==4401== Using Valgrind-3.10.0.SVN and LibVEX; rerun with -h for copyright info
==4401== Command: ./panic
==4401==
thread '<main>' panicked at 'division by zero', panic.rs:5
==4401==
==4401== HEAP SUMMARY:
==4401== in use at exit: 0 bytes in 0 blocks
==4401== total heap usage: 18 allocs, 18 frees, 1,648 bytes allocated
==4401==
==4401== All heap blocks were freed -- no leaks are possible
==4401==
==4401== For counts of detected and suppressed errors, rerun with: -v
==4401== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)