اصل Dependency Inversion یا معکوس سازی وابستگی در SOLID چیست؟

حتما در طول یادگیری برنامه نویسی، عبارت کد تمیز را بارها و بارها شنیده اید. کد تمیز ویژگی اسرار آمیزی است که باعث می‌شود کدهای شما خوانا و تغییر پذیر شوند. با کد تمیز شما تبدیل به شوالیه ای می‌شوید که همیشه آماده جنگ با اژدها است! بایید ببینیم که Dependency Inversion چیست؟

ما آیا تا به حال فکر کرده اید چه چیزی باعث می‌شود یک کد تمیز باشد یا نباشد؟ پیدا کردن کد کثیف با دنبال کردن بوی بد کد (Code Smell) ممکن می‌شود. در برنامه نویسی به علائمی که نشان می‌دهند یک کد تمیز نیست اصطلاحا بوی بد می‌گوییم. این علائم عبارت اند از:

  • سفتی یا Rigidity: ایجاد تغییر در کدها مشکل است
  • شکنندگی یا Fragility: طراحی کد برنامه به راحتی در هم می‌شکند و به هم می‌ریزد
  • بی تحرکی یا Immobility: به سختی می‌توان کدها را دوباره استفاده کرد. اصطلاحا Usability کد پایین است
  • چسبندگی یا Viscosity: انجام کار درست در کدها مشکل است!

به محض استشمام این بوهای بد در کدهای خودتان، باید به فکر یادگیری طراحی کد تمیز بیفتید. برای طراحی کد تمیز باید از یک سری اصول یا فوت کوزه گری پیروی کنید! یکی از این اصول SOLID است. SOLID بر پنج اصل استوار است:

  • Single Responsibility Principle یا اصل تک وظیفگی (SRP)
  • Open/Closed Principle یا اصل باز و بسته بودن (OCP)
  • Liskov Substitution Principle یا اصل جانشینی لیسکف (LSP)
  • Interface Segregation Principle یا اصل تفکیک Interface (ISP)
  • Dependency Inversion Principle یا اصل وارونه کردن وابستگی (DIP)

در این مطلب به معرفی اصل آخر SOLID یعنی اصل Dependency Inversion می‌پردازیم.

اصل Dependency Inversion چیست؟

اصل وارونگی وابستگی یا Dependency Inversion Principle تاکید می‌کند که ماژول‌های سطح بالای برنامه نباید به ماژول‌های سطح پایین آن وابسته باشند.

یک پریز برق را در نظر بگیرید. تمام جزئیات سیم کشی برق در پشت پریز تعریف شده است. مثل اتصالات، سیم‌های در هم پیچیده و…. تمام این‌ها ماژول‌های سطح پایین سیستم برق هستند. سوکت‌های برق دستگاه‌های مختلف الکترونیکی را هم ماژول‌های سطح بالا در نظر می‌گیریم. با این تعریف در صورت نبود پریز، برای دریافت برق از سیم کشی ساختمان مجبور بودیم خودمان به طریقی سیم‌های دستگاه‌ها را به سیم‌های سیم کشی برق متصل نگه داریم! بنابراین ماژول‌های سطح بالا (سیم دستگاه‌های الکترونیکی) به ماژول‌های سطح پایین (سیم کشی ساختمان) وابسته بودند.

اما به لطف پریز که یک Interface محسوب می‌شود، این وابستگی وارونه شده است. یعنی سیم کشی ساختمان طبق اصول این Interface قادر به اتصال برق به دستگاه‌ها می‌شود. تمام دستگاه‌ها نیز برای اتصال به سوراخ‌های این پریز باید قوانین آن را رعایت کنند. یعنی باید سوکت یا تبدیل مناسب با نوع پریز داشته باشند.

مثالی از اصل Dependency Inversion

در دنیای واقعی برنامه نویسی این اصل یکی از پرکاربرد‌ترین اصول در برنامه نویسی شی گراست. هر زمان که برای قطع وابستگی کدهای برنامه به یکدیگر از Interface‌ها و Abstract‌ها استفاده می‌کنید در حال پیاده سازی این اصل هستید.

احتمالا شما هم مانند بسیاری از برنامه نویسان در شروع کار، به روش سنتی به پایگاه داده متصل می‌شدید و اطلاعات را از آن دریافت و به آن ارسال می‌کردید. یعنی در بین کدهای در هم و برهم برنامه یک کد اتصال به دیتابیس می‌نوشتید و در جای جای برنامه به تناسب نیاز از آن استفاده می‌کردید. کوئری‌های مختلف را می‌شد در هر جای کد شما به صورت پراکنده دید.

با در نظر گرفتن درایور پایگاه داده ای که استفاده می‌کردید (مثل MySQL، SQLServer، Oracle و…) به عنوان ماژول سطح پایین، ماژول‌های سطح بالای شما یعنی کدهای برنامه به شدت به ماژول‌های سطح پایین وابسته بود. فقط در ذهنتان تصور کنید چه می‌شد اگر می‌خواستید از MySQL به یک پایگاه داده NOSQL مثل MongoDB مهاجرت کنید؟ فاجعه! شما باید تمام کوئری‌های وابسته را از جای جای برنامه پیدا می‌کردید و آن‌ها را یکی یکی تغییر می‌دادید.

روش درست این است که یک Interface برای پایگاه داده در نظر بگیریم. تمام درایورهای مختلف برای استفاده شدن موظف می‌شوند این Interface را پیاده سازی یا Implement کنند. از آن پس کدهای برنامه فقط به آن رابط‌ها متصل می‌شوند. به این ترتیب این وابستگی را وارونه کرده ایم!

نتیجه گیری Dependency Inversion

با اهمیت کدهای تمیز و یاد گرفتن روش رسیدن به آن آشنا شدید. به نشانه‌های یک کد کثیف بوی بد کد می‌گوییم. این بوهای بد عبارت اند از: سفتی، شکنندگی، بی تحرکی و چسبندگی که هرکدام معنی خاص خود را دارند. یکی از موارد لازم برای رسیدن به کد تمیز، رعایت اصول SOLID در کدنویسی است. در این مطلب با اصل آخر از اصول SOLID یعنی اصل Dependency Inversion یا DIP آشنا شدید.

Erfan Akbarieh

Recent Posts

معرفی بهترین پلاگین های افزایش امنیت وردپرس

اگر به سئو سایت وردپرسی خود اهمیت می دهید، مطمئناً معیارهای مهمی مثل سرعت و…

2 ماه ago

مقایسه بهترین هوش مصنوعی؛ کدام انتخاب مناسب شماست؟ مقایسه تکمیلی

در عصر حاضر، فناوری اطلاعات و هوش مصنوعی (AI) به سرعت در حال دگرگون‌سازی جنبه‌های…

7 ماه ago

eSIM در ایران؛ تحول بزرگ سیم‌کارت‌ها با عرضه آیفون 17 و ورود اپراتورها

دنیای تکنولوژی همیشه در حال تغییر است و هر روز یک فناوری تازه جایگزین روش‌های…

8 ماه ago

آموزش جامع نصب جنگو (Django) بر روی اوبونتو | راهنمای گام به گام برای مبتدیان تا حرفه‌ای ها

آموزش جامع نصب Django روی اوبونتو مقدمه اگر به دنبال ساخت یک وب‌سایت یا اپلیکیشن…

8 ماه ago

رفع خطای لایسنس در ویندوز سرور

آموزش گام‌به‌گام حذف محدودیت Grace Period در Remote Desktop Services یکی از مشکلات رایج در…

9 ماه ago

آموزش تغییر پورت ریموت دسکتاپ (RDP) در ویندوز سرور

پروتکل Remote Desktop Protocol (RDP) یکی از متداول‌ترین روش‌ها برای مدیریت سرورهای ویندوزی از راه…

9 ماه ago