تبديل المرجع إلى قيمة (Change Reference to Value)

من موسوعة حسوب
< Refactoring
مراجعة 09:49، 2 مارس 2019 بواسطة جميل-بيلوني (نقاش | مساهمات) (مراجعة وتدقيق)
(فرق) → مراجعة أقدم | المراجعة الحالية (فرق) | مراجعة أحدث ← (فرق)
اذهب إلى التنقل اذهب إلى البحث

المشكلة

وجود كائن مرجع صغير جدًا نادرًا ما يتغيَّر لتبرير إدارة دورة حياته.

الحل

تحويله إلى كائن قيمة (value object).

مثال

قبل إعادة التصميم

مخطط يوضح كيفية ارتباط الصنفين Currency و Customer:

مخطط يوضح كيفية ارتباط الصنفين Currency و Customer.
مخطط يوضح كيفية ارتباط الصنفين Currency و Customer.

بعد إعادة التصميم

إعادة تصميم المخطط السابق للتتحول العلاقة الرابطة للصنفين Currency و Customer إلى علاقة has a (أي بمجرد وجود كائن Customer فلا بد من وجود كائن Currency له).

مخطط يوضح كيفية ارتباط الصنفين Currency و Customer بعلاقة has a (أي بمجرد وجود كائن Customer فلا بد من وجود كائن Currency له).
مخطط يوضح كيفية ارتباط الصنفين Currency و Customer بعلاقة has a (أي بمجرد وجود كائن Customer فلا بد من وجود كائن Currency له).

لم إعادة التصميم؟

قد يرجع التبديل من مرجع إلى قيمة إلى عدم ملائمة العمل مع المرجع. تتطلب المراجع إدارة من جهتك:

  • فهي تتطلب دائمًا طلب الكائن اللازم من الذاكرة المُخزَّن فيها.
  • قد يكون من غير المريح العمل مع المراجع في الذاكرة.
  • يكون العمل مع المراجع صعبًا للغاية مقارنةً بالقيم، في الأنظمة الُموزَعة والموازية.

تكون القيم مفيدة بشكل خاص إذا كنت تُفضِّل أن يكون لديك كائنات غير قابلة للتغيير، عن الكائنات التي قد تتغير حالتها أثناء دورة حياتها.

فوائد تطبيق الحل

  • أحد الخواص المهمة للكائنات أن تكون غير قابلة للتغيير. يجب الحصول على نفس النتيجة عند كل استعلام يُعيد قيمة كائن. إذا كان ذلك صحيحًا، لا تنشأ مشاكل إذا كان هناك العديد من الكائنات التي تمثِّل نفس الشيء.
  • من السهل جدًا تنفيذ القيم.

مساوئ تطبيق الحل

  • إذا كانت القيمة قابلة للتغيير، يجب التأكد من أنه إذا تغير أي كائن، فستُحدََّث القيم الموجودة في كافة الكائنات الأخرى التي تمثل نفس الكيان. وهو أمر مرهق جدًا إذ من الأسهل إنشاء مرجع لهذا الغرض.

آلية الحل

  1. جعل الكائن غير قابل للتغيير. يجب ألَّا يكون للكائن أي ضابط أو تابع آخر يُغيّر من حالته وبياناته (قد يساعد هنا تابع إزالة الإعدادات). ويكون الباني هو المكان الوحيد الذي يجب تعيين بيانات حقول كائن قيمة فيه.
  2. إنشاء تابع مقارنة لتكون قادرًا على مقارنة قيمتين.
  3. التحقق ما إذا كان يمكن حذف تابع إعادة التصميم وجعل باني الكائن عامًا.

انظر أيضًا

مصادر