بازسازی کد جایگزینی داده با شیء، معمولا در طراحی موجودیتهای قابل ذخیره و بازیابی سیستمهای اطلاعاتی مورد نیاز قرار میگیرید. این بازسازی کد معمولا زمانی مورد نیاز است که آیتم دادهای نیاز به اطلاعات بیشتر یا رفتاری خاص دارد. در این صورت باید آن آیتم دادهای را به شیء از کلاس یا ساختار (struct) تبدیل کرد.
معمولا زمانیکه توسعه محصول انجام میگیرد، ممکن است آیتمهای دادهای در ابتدا ساده دیده شوند و طراحی سادهای برای آنها در نظر گرفته شود. به طور مثال در یک سیستم فرضی رسیدگی به تیکت، ممکن است با اقلام اطلاعاتی مانند آیتمهای زیر روبرو باشیم:
شماره تلفن، به صورت رشته کاراکتری
آدرس، به عنوان رشته کاراکتری
نام مسئول رسیدگی به تیکت، به صورت رشته کاراکتری
با توجه به مثال بالا، در طراحی اولیه AgentName، فیلدی از نوع رشته کاراکتری برای نگهداری نام مسئول رسیدگی به تیکت در نظر گرفته شده است (فرض میکنیم در این طراحی موضوعات مربوط به نرمال سازی پایگاههای داده را در نظر نگرفتهایم و تکرار شدن نام مسئول رسیدگی به تیکت اشکالی نداشتهاست). کلاس زیر نشان دهنده چنین طراحیای است.
اما بعد از سپری شدن مدتی از توسعه محصول ممکن است اقلام اطلاعاتی خاصی بر روی هر یک از آیتمهای بالا نیاز شود. به طور مثال برای آدرس نیاز باشد اطلاعات استان و شهر جداگانه قابل ذخیره سازی و گزارش گیری باشند و یا در کنار نام مسئول رسیدگی به تیکت، شماره تلفن او نیز وجود داشته باشد.
در چنین شرایطی، یک اقدام ممکن، افزودن اقلام اطلاعاتی مورد نیاز در همان مکان آیتم قبلی است؛ به طور مثال اگر نام مسئول بر روی موجودیت تیکت باشد، شماره تلفن مسئول نیز در همان موجودیت تیکت اضافه شود.
راه حل مناسبتر برای حل این نوع مشکلات ایجاد کلاس خاص آیتم اطلاعاتی و استفاده از شیء آن بهجای مقدار مربوطه است. به طور مثال به طراحی زیر دقت نمایید. در طراحی زیر کلاس دیگری به نام Agent ایجاد و در کلاس تیکت از آن استفاده کردهایم.
این بازسازی کد دو مزیت کلی دارد:
راه را برای توسعه آینده آیتمهای دادهای باز میکند
از تکرار آیتمهای دادهای جلوگیری میکند (به طور مثال زمانیکه از پایگاه دادههای رابطهای جهت ذخیره سازی، استفاده شود)
در مثال بالا علارغم اینکه قادر بودیم آیتم اطلاعاتی مسئول رسیدگی را به صورت ساختار (struct) تعریف کنیم، این آیتم اطلاعاتی را به صورت کلاس تعریف کردیم. تعریف به صورت کلاس امکان استفاده از رفرنس را بهجای مقدار شیء، به ما خواهد داد. در اکثر بازسازیهای کد، استفاده از کلاسها مزیتهای بیشتری نسبت به استفاده از ساختار دارد. برای مطالعه بیشتر در این مورد میتوانید به اینجا مراجعه نمایید.