مدیریت پروژههای بزرگ با بستهها، جعبهها (crates) و ماژولها
با نوشتن برنامههای بزرگتر، سازماندهی کد شما اهمیت بیشتری پیدا میکند. با گروهبندی قابلیتهای مرتبط و جدا کردن کدی که ویژگیهای متمایزی دارد، میتوانید مشخص کنید که کد یک ویژگی خاص در کجا پیادهسازی شده و کجا میتوان آن را تغییر داد.
برنامههایی که تاکنون نوشتهایم در یک ماژول و یک فایل بودهاند. همانطور که پروژه رشد میکند، باید کد را با تقسیم آن به ماژولهای مختلف و سپس فایلهای مختلف سازماندهی کنید. یک بسته میتواند شامل چندین جعبه (crate) باینری و به صورت اختیاری یک جعبه (crate) کتابخانه باشد. همانطور که بسته رشد میکند، میتوانید بخشهایی را به جعبهها (crates)ی جداگانهای که به عنوان وابستگیهای خارجی عمل میکنند استخراج کنید. این فصل تمام این تکنیکها را پوشش میدهد. برای پروژههای بسیار بزرگ که شامل مجموعهای از بستههای مرتبط است که با یکدیگر تکامل مییابند، Cargo ویژگیهایی به نام فضای کاری ارائه میدهد که در بخش «فضای کاری Cargo» فصل ۱۴ به آن میپردازیم.
همچنین درباره جزئیات پیادهسازی که به شما امکان میدهد کد را در سطح بالاتری بازاستفاده کنید صحبت خواهیم کرد: وقتی یک عملیات را پیادهسازی کردهاید، سایر کدها میتوانند از طریق رابط عمومی کد شما آن را فراخوانی کنند بدون این که لازم باشد بدانند چگونه پیادهسازی شده است. نحوه نوشتن کد شما مشخص میکند که کدام بخشها برای سایر کدها عمومی و قابل استفاده هستند و کدام بخشها جزئیات پیادهسازی خصوصی هستند که میتوانید هر زمان بخواهید تغییر دهید. این رویکرد یکی دیگر از روشهایی است که مقدار جزئیاتی که باید به خاطر بسپارید را محدود میکند.
یک مفهوم مرتبط، محدوده (scope) است: زمینهای که در آن کد نوشته شده است و مجموعهای از نامها که به عنوان «در محدوده» تعریف میشوند. هنگام خواندن، نوشتن و کامپایل کد، برنامهنویسان و کامپایلرها باید بدانند که آیا یک نام خاص در یک مکان خاص به متغیر، تابع، ساختار، enum، ماژول، ثابت یا مورد دیگری اشاره دارد و معنای آن مورد چیست. شما میتوانید محدودهها ایجاد کنید و مشخص کنید که کدام نامها در محدوده هستند یا خارج از آن. نمیتوانید دو مورد با نام یکسان در یک محدوده داشته باشید؛ ابزارهایی برای رفع تعارض نامها در دسترس هستند.
Rust مجموعهای از ویژگیها دارد که به شما امکان میدهد سازماندهی کد خود را مدیریت کنید، از جمله جزئیاتی که آشکار میشوند، جزئیاتی که خصوصی هستند، و نامهایی که در هر محدوده در برنامههای شما قرار دارند. این ویژگیها که گاهی به صورت جمعی سیستم ماژول نامیده میشوند شامل موارد زیر هستند:
- بستهها: ویژگیای در Cargo که به شما امکان ساخت، تست و اشتراکگذاری جعبهها (crates) را میدهد.
- جعبهها (crates): درختی از ماژولها که یک کتابخانه یا یک اجرایی تولید میکنند.
- ماژولها و use: به شما اجازه میدهند سازماندهی، محدوده و حریم خصوصی مسیرها را کنترل کنید.
- مسیرها: راهی برای نامگذاری یک مورد مانند یک ساختار، تابع یا ماژول.
در این فصل، تمام این ویژگیها را پوشش خواهیم داد، نحوه تعامل آنها را توضیح میدهیم و نحوه استفاده از آنها برای مدیریت محدوده را بررسی میکنیم. تا پایان، باید درک جامعی از سیستم ماژول داشته باشید و بتوانید با محدودهها مانند یک حرفهای کار کنید!