توضیحات/کامنت (C Comments)
توضیحات (Comments): نامههایی به آینده 📝✉️
کامنتها بخشهایی از کد هستند که کامپایلر کاملاً از آنها چشمپوشی میکند. آنها برایِ توضیح دادنِ "چرا" و "چگونه" در کد نوشته میشوند.
۱. کامنتهایِ تکخطی (Single-line)
با دو اسلش // شروع میشوند. هر چیزی بعد از آن تا انتهایِ همان خط نادیده گرفته میشود.
۲. کامنتهایِ چندخطی (Multi-line)
با /* شروع و با */ تمام میشوند. برایِ توضیحاتِ مفصل یا غیرفعال کردنِ تیکههایِ بزرگی از کد عالی هستند.
هنرِ نوشتنِ کامنتِ خوب:
در زبانِ C که مدیریتِ حافظه پیچیده است، نوشتنِ کامنت ضروری است. اما مراقب باشید:
- چیزهایِ واضح را نگویید: نوشتنِ
// x را برابر 5 قرار بدهکنارِx = 5بیهوده است. - منطقِ پیچیده را توضیح دهید: اگر یک الگوریتمِ ریاضیِ سنگین دارید، بگویید هدف از هر مرحله چیست.
بخش تخصصی: کالبدشکافیِ اجرایِ یک برنامه C 🛠️⚙️⚡
زبانِ C زبانِ نزدیک به سختافزار است. درکِ اینکه چطور کدهایِ متنیِ شما به سیگنالهایِ الکتریکی در CPU تبدیل میشوند، اولین قدم برایِ تبدیل شدن به یک مهندسِ حرفهای است.
۱. خطِ لوله (Pipeline) کامپایل
فرایندِ تبدیل کدِ C به فایلِ اجرایی (Executable) چهار مرحلهیِ حیاتی دارد:
- پیشپردازش (Preprocessing): دستوراتی که با
#شروع میشوند (مثل#include) پردازش میشوند. کدهایِ هدر به فایلِ اصلی چسبانده میشوند. - کامپایل (Compilation): کدهایِ سطحِ بالایِ C به زبانِ اسمبلی (Assembly) تبدیل میشوند که برایِ معماریِ آن CPU خاص (مثل x86 یا ARM) قابل فهم باشد.
- اسمبلی (Assembly): کدهایِ اسمبلی به کدهایِ ماشین (Binary) تبدیل میشوند. نتیجه یک فایلِ
.objیا.oاست. - لینک کردن (Linking): تمامِ فایلهایِ آبجکت و کتابخانههایِ استاندارد (مثل
stdio.h) به هم متصل میشوند تا یک فایلِ نهایی (مثل.exe) ساخته شود.
۲. ساختارِ حافظه در زمانِ اجرا (Runtime Memory)
وقتی برنامهیِ شما اجرا میشود، از چهار بخشِ اصلی در حافظه استفاده میکند:
- Text Segment: محلِ نگهداریِ دستوراتِ اجراییِ برنامه (کدهای ماشین).
- Data Segment: برایِ نگهداریِ متغیرهایِ سراسری (Global) و استاتیک.
- Stack: برایِ نگهداریِ متغیرهایِ محلی و پارامترهایِ توابع مدیریت میشود. این بخش سریع است اما فضایِ محدودی دارد.
- Heap: برایِ مدیریتِ حافظهیِ داینامیک (که با
mallocرزرو میکنید). این بزرگترین بخشِ حافظهیِ در دسترس است.
تمرینهای عملی
برای تثبیت یادگیری این درس تمرینهای زیر را حل کنید
ساختار شروع و پایان یک کامنتِ چندخطی را در خروجی چاپ کنید. خروجی باید دقیقاً /**/ باشد.
#include <stdio.h>
int main() {
printf("/**/");
return 0;
}
آماده رفتن به درس بعدی هستید؟
این درس را به پایان رساندید و میتوانید به درس بعدی بروید.