در حال بارگذاری...

سازنده‌ها و نابودگرها

سازنده‌ها (Constructors) و نابودگرها (Destructors) از ارکان اصلی برنامه‌نویسی شیءگرا در سی‌پلاس‌پلاس هستند. سازنده‌ها توابع ویژه‌ای هستند که هنگام ایجاد یک شیء به‌صورت خودکار فراخوانی می‌شوند و امکان مقداردهی اولیه به اعضای داده‌ای و تخصیص منابع مورد نیاز را فراهم می‌کنند. نابودگرها نیز هنگام پایان عمر یک شیء به‌صورت خودکار فراخوانی می‌شوند تا منابع تخصیص داده‌شده آزاد شوند و از نشت حافظه جلوگیری شود.
استفاده صحیح از سازنده‌ها و نابودگرها تضمین می‌کند که اشیاء همیشه در حالت معتبر ایجاد شوند و منابع به‌صورت امن مدیریت شوند. سازنده‌ها می‌توانند بارگذاری شوند، از جمله نسخه‌های پارامتردار، نسخه کپی و نسخه انتقالی، که انعطاف‌پذیری بالایی در ایجاد اشیاء ارائه می‌دهند. نابودگرها بدون پارامتر هستند و امکان بارگذاری مجدد ندارند تا اجرای آن‌ها قابل پیش‌بینی باشد.
در این آموزش، به بررسی سینتکس، ساختار داده‌ها، الگوریتم‌ها و اصول OOP می‌پردازیم که برای پیاده‌سازی مؤثر سازنده‌ها و نابودگرها ضروری هستند. شما با مدیریت ایمن حافظه دینامیک، جلوگیری از کپی سطحی یا عمیق اشتباه و اعمال الگوی RAII آشنا خواهید شد که باعث افزایش پایداری و کارایی برنامه‌های سی‌پلاس‌پلاس می‌شود. این مفاهیم در توسعه نرم‌افزار و معماری سیستم اهمیت بالایی دارند، زیرا مدیریت مؤثر چرخه حیات اشیاء و منابع برای موفقیت پروژه حیاتی است.

مثال پایه

text
TEXT Code
\#include <iostream>
\#include <string>

class Karshenas {
private:
std::string name;
int id;
public:
// سازنده پیش‌فرض
Karshenas() : name("ناشناخته"), id(0) {
std::cout << "سازنده پیش‌فرض فراخوانی شد\n";
}

// سازنده پارامتردار
Karshenas(const std::string& n, int i) : name(n), id(i) {
std::cout << "سازنده پارامتردار فراخوانی شد: " << name << "\n";
}

// سازنده کپی
Karshenas(const Karshenas& other) : name(other.name), id(other.id) {
std::cout << "سازنده کپی فراخوانی شد: " << name << "\n";
}

// نابودگر
~Karshenas() {
std::cout << "نابودگر فراخوانی شد: " << name << "\n";
}

void show() {
std::cout << "نام: " << name << ", ID: " << id << "\n";
}

};

int main() {
Karshenas k1;
Karshenas k2("علی", 101);
Karshenas k3 = k2;

k1.show();
k2.show();
k3.show();

return 0;

}

در این مثال، کلاس Karshenas انواع سازنده‌ها و نابودگرها را نشان می‌دهد. سازنده پیش‌فرض شیء را با مقادیر استاندارد مقداردهی می‌کند، سازنده پارامتردار امکان تعیین مقادیر خاص را فراهم می‌کند و سازنده کپی داده‌ها را به‌درستی هنگام ایجاد یک شیء جدید از شیء موجود کپی می‌کند. نابودگر به‌طور خودکار در پایان چرخه حیات شیء فراخوانی می‌شود تا منابع آزاد شوند.
با اعمال الگوی RAII (Resource Acquisition Is Initialization) اطمینان حاصل می‌شود که منابع اختصاص یافته در سازنده به‌طور ایمن در نابودگر آزاد شوند. این روش در کار با حافظه دینامیک، فایل‌ها، اتصالات شبکه و سایر منابع محدود اهمیت دارد و پایداری و عملکرد کد سی‌پلاس‌پلاس را افزایش می‌دهد.

مثال کاربردی

text
TEXT Code
\#include <iostream>
\#include <vector>
\#include <memory>

class ConnectionDB {
private:
std::string connStr;
public:
// ایجاد اتصال در سازنده
ConnectionDB(const std::string& cs) : connStr(cs) {
std::cout << "اتصال برقرار شد: " << connStr << "\n";
}

// بستن اتصال در نابودگر
~ConnectionDB() {
std::cout << "اتصال بسته شد: " << connStr << "\n";
}

void query(const std::string& sql) {
std::cout << "اجرای پرس‌وجو: " << sql << "\n";
}

};

int main() {
std::vector\<std::unique_ptr<ConnectionDB>> connections;

connections.push_back(std::make_unique<ConnectionDB>("Server=DB1;User=Admin;"));
connections.push_back(std::make_unique<ConnectionDB>("Server=DB2;User=Guest;"));

for (auto& conn : connections) {
conn->query("SELECT * FROM Users;");
}

// نابودگرها به‌طور خودکار فراخوانی می‌شوند
return 0;

}

در این مثال پیشرفته، سازنده‌ها و نابودگرها در مدیریت اتصالات دیتابیس کاربرد دارند. سازنده اتصال را برقرار و منابع را تخصیص می‌دهد و نابودگر اتصال را می‌بندد و حافظه آزاد می‌کند. استفاده از std::unique_ptr نشان می‌دهد که چگونه حافظه دینامیک به‌طور ایمن مدیریت می‌شود و از نشت حافظه جلوگیری می‌شود. این روش قابل استفاده برای فایل‌ها، شبکه و رشته‌های پردازشی است و پایداری و عملکرد برنامه را تضمین می‌کند.

بهترین شیوه‌ها شامل مقداردهی اولیه تمام اعضا در سازنده، استفاده از لیست مقداردهی اولیه، آزادسازی منابع در نابودگر و بهره‌گیری از smart pointers مانند std::unique_ptr و std::shared_ptr است. اشتباهات رایج: نشت حافظه، اشیاء مقداردهی نشده، کپی ناقص اشیاء و حلقه‌های مرجع در smart pointerها. برای دیباگ توصیه می‌شود از log و الگوی RAII استفاده شود. برای بهینه‌سازی، تخصیص‌های پویا را کاهش داده، از move semantics استفاده کنید و از کانتینرهای مدرن بهره ببرید. برای امنیت، نابودگرها نباید اطلاعات حساس را فاش کنند و مدیریت منابع در محیط‌های چندریسمانی باید صحیح انجام شود. این شیوه‌ها پایداری، عملکرد و نگهداری کد را افزایش می‌دهند.

📊 جدول مرجع

سی‌پلاس‌پلاس Element/Concept Description Usage Example
سازنده پیش‌فرض مقداردهی اولیه شیء با مقادیر استاندارد Karshenas k1;
سازنده پارامتردار مقداردهی اولیه با مقادیر مشخص Karshenas k2("علی",101);
سازنده کپی ایجاد کپی عمیق از شیء Karshenas k3 = k2;
نابودگر آزادسازی منابع در پایان عمر شیء \~Karshenas();
لیست مقداردهی اولیه مقداردهی به اعضا به‌صورت بهینه Karshenas() : name("ناشناخته"), id(0) {}
RAII مدیریت خودکار منابع با سازنده/نابودگر std::unique_ptr<ConnectionDB> conn = std::make_unique<ConnectionDB>("DB");

سازنده‌ها و نابودگرها امکان مدیریت ایمن چرخه حیات اشیاء و منابع را در سی‌پلاس‌پلاس فراهم می‌کنند. درک سازنده کپی، لیست مقداردهی اولیه و الگوی RAII برای افزایش کارایی و پایداری ضروری است. گام بعدی شامل مطالعه بارگذاری عملگرها، سازنده‌های امن برای استثنا، move semantics و مدیریت پیشرفته حافظه است. این مهارت‌ها به ایجاد پروژه‌های پایدار، کارآمد و قابل نگهداری در سی‌پلاس‌پلاس منجر می‌شوند.

🧠 دانش خود را بیازمایید

آماده شروع

Test Your Knowledge

Test your understanding of this topic with practical questions.

4
سوالات
🎯
70%
برای قبولی
♾️
زمان
🔄
تلاش‌ها

📝 دستورالعمل‌ها

  • هر سوال را با دقت بخوانید
  • بهترین پاسخ را برای هر سوال انتخاب کنید
  • می‌توانید آزمون را هر چند بار که می‌خواهید تکرار کنید
  • پیشرفت شما در بالا نمایش داده می‌شود