مدیریت خطاها
خطاها واقعیتی در نرمافزار هستند، بنابراین Rust تعدادی ویژگی برای مدیریت شرایطی که در آنها چیزی اشتباه میرود ارائه میدهد. در بسیاری از موارد، Rust شما را مجبور میکند امکان وقوع خطا را تشخیص داده و اقدامی انجام دهید تا کد شما کامپایل شود. این الزام برنامه شما را مقاومتر میکند زیرا اطمینان حاصل میکند که قبل از انتشار کد به تولید، خطاها را کشف کرده و آنها را به درستی مدیریت میکنید!
Rust خطاها را به دو دسته اصلی تقسیم میکند: خطاهای قابل بازیابی و خطاهای غیرقابل بازیابی. برای یک خطای قابل بازیابی، مانند خطای فایل یافت نشد، احتمالاً میخواهیم مشکل را به کاربر گزارش دهیم و عملیات را دوباره انجام دهیم. خطاهای غیرقابل بازیابی همیشه نشانههای باگها هستند، مانند تلاش برای دسترسی به مکانی خارج از انتهای یک آرایه، بنابراین میخواهیم بلافاصله برنامه را متوقف کنیم.
بیشتر زبانها بین این دو نوع خطا تفاوت قائل نمیشوند و هر دو را به یک شکل مدیریت میکنند،
با استفاده از مکانیزمهایی مانند استثناها. Rust استثناها ندارد. در عوض، نوع Result<T, E>
برای
خطاهای قابل بازیابی و ماکروی panic!
که اجرای برنامه را زمانی که با یک خطای غیرقابل بازیابی
روبرو میشود متوقف میکند، ارائه میدهد. این فصل ابتدا به فراخوانی panic!
میپردازد و سپس
در مورد بازگرداندن مقادیر Result<T, E>
صحبت میکند. علاوه بر این، ملاحظاتی را هنگام تصمیمگیری
در مورد اینکه آیا سعی در بازیابی از یک خطا کنیم یا اجرای برنامه را متوقف کنیم، بررسی خواهیم کرد.