Ob'ekt orgiyasi - Object orgy

Yilda kompyuter dasturlash, ob'ekt orgiyasi da keng tarqalgan atama Perl dasturiy ta'minot hamjamiyati, umumiy muvaffaqiyatsizlikni tavsiflovchi (yoki naqshga qarshi ) ichida ob'ektga yo'naltirilgan dizayn yoki ob'ektga yo'naltirilgan dasturlash. Ob'ekt orgiyasida ob'ektlar etarli emas kapsulalangan orqali ma'lumotni yashirish, ularning ichki qismlariga cheklovsiz kirishga ruxsat berish, odatda parvarishlash ehtiyojlari va muammolarini ko'payishiga olib keladi va hatto qiyin bo'lmaydigan murakkablik.

Oqibatlari

Ob'ekt orgiyasi natijalari asosan kapsulaning afzalliklarini yo'qotishdir, shu jumladan:

  • Cheklovsiz kirish o'quvchiga ob'ektning xatti-harakatlari to'g'risida fikr yuritishni qiyinlashtiradi. Buning sababi shundaki, uning ichki holatiga to'g'ridan-to'g'ri kirish tizimning boshqa har qanday qismi uni boshqarishi, tekshiriladigan kod miqdorini oshirishi va kelajakda suiiste'mol qilish uchun vositalarni yaratishi mumkin.
  • Fikrlashning qiyinligi natijasida, shartnoma bo'yicha loyihalash amalda imkonsizdir.
  • Agar ko'p kodlar inkapsulyatsiya etishmasligidan foydalansa, natijada o'zaro ta'sirlar labirinti bo'ladi, odatda " kalamush uyasi yoki spagetti kodi.
  • Asl dizayn ob'ektlar uchun haddan tashqari keng interfeyslar bilan yashiringan.
  • Keng interfeyslar tizimning qolgan qismiga xalaqit bermasdan sinfni qayta amalga oshirishni qiyinlashtiradi. Bu, ayniqsa, sinf mijozlari boshqa jamoa yoki tashkilot tomonidan ishlab chiqilganida juda qiyin.

Shakllar

Enkapsulyatsiya bir necha usul bilan zaiflashishi mumkin, jumladan:

  • Ichki a'zolarni ommaviy deb e'lon qilish yoki jamoat orqali ma'lumotlarga bepul kirishni ta'minlash mutator usullari (setter yoki getter).
  • Umumiy bo'lmagan kirishni ta'minlash orqali. Masalan, qarang: Java kirish modifikatorlari va kirish darajasi yilda C #[1]
  • Yilda C ++, yuqoridagi ba'zi vositalar orqali va e'lon qilish orqali do'stim sinflar yoki funktsiyalar.

Ob'ekt o'z ichki ma'lumotlarini havolalarni saqlab qolishi mumkin bo'lgan boshqa sinflarning uslublari yoki konstruktorlari uchun argument sifatida havolalar berish orqali ularga kirish imkoniyatini yaratishi mumkin.

Aksincha, bir-birlariga havola qilingan narsalar, ba'zida ob'ektlar orgiyasining shakli deb ta'riflangan bo'lsa ham, o'z-o'zidan inkapsulatsiyani buzmaydi.

Sabablari

A'zolar, ular uchun tegishli kiruvchi vositalarni taqdim etish harakatlaridan yoki sintaktik ortiqcha xarajatlardan qochish uchun ommaviy deb e'lon qilinishi mumkin. Bu sinfning o'qilishini kuchaytirishi mumkin, ammo yuqorida tavsiflangan oqibatlarga olib keladi.

Ba'zi bir tillar uchun boshqa ob'ektlar tomonidan o'qilishi mumkin bo'lgan a'zoni o'zgartirish mumkin, chunki tilda faqat o'qish uchun kirish uchun qulay tuzilma mavjud emas.

Dizayner ob'ektlar o'rtasidagi o'zaro ta'sirlarni etarli darajada tahlil qilmaganida, ob'ekt orgiyasi etuk bo'lmagan dizaynga kodlashning alomati bo'lishi mumkin. Bu, shuningdek, dizaynni amalga oshirishda dangasalik yoki shoshqaloqlikdan kelib chiqishi mumkin, ayniqsa dasturchi dizayner bilan etarlicha aloqa qilmasa yoki muammolar yuzaga kelsa, dizaynni qayta ko'rib chiqishni istamaslik, bu boshqa ko'plab anti-naqshlarni rag'batlantiradi.

Yechimlar

Umuman olganda, kapsula buziladi, chunki boshqa sinflarning dizayni shuni talab qiladi va uni qayta ishlab chiqish zarur. Agar bunday bo'lmasa, tizimni eng yaxshi amaliyotlarga muvofiq qayta kodlash kifoya qiladi. Interfeyslar qaytarilmasdan nashr etilgandan so'ng, ularni tuzatish uchun kech bo'lishi mumkin.

Adabiyotlar

Tashqi havolalar