Qiyomat piramidasi (dasturlash) - Pyramid of doom (programming)

Yilda kompyuter dasturlash, halokat piramidasi dastur funktsiyaga kirishni boshqarish uchun ko'p darajadagi ichki chuqurlikdan foydalanganda paydo bo'ladigan keng tarqalgan muammo. Odatda tekshirayotganda ko'rinadi nol ko'rsatkichlar yoki ishlov berish qo'ng'iroqlar.[1] Terminning ikkita misoli ma'lum bir dasturlash uslubi bilan bog'liq JavaScript,[2] va uyasi agar bayonotlar bu sodir bo'ladi ob'ektga yo'naltirilgan dasturlash ob'ektlardan biri bo'sh ko'rsatgich bo'lishi mumkin bo'lgan tillar.[3][4]

Misollar

Eng zamonaviy ob'ektga yo'naltirilgan dasturlash tillari bir nechta usul qo'ng'iroqlarini bitta satrda yozish imkonini beradigan nuqta belgisi sifatida ma'lum bo'lgan kodlash uslubidan foydalaning, har bir chaqiriq nuqta bilan ajratilgan. Masalan; misol uchun:

kengligi = derazalar("Asosiy").qarashlar(5).hajmi().kengligi();

Ushbu kod to'rt xil ko'rsatmalarni o'z ichiga oladi; u avval "Asosiy" nomli oyna uchun derazalar to'plamini ko'rib chiqadi, so'ngra uning ichida joylashgan 5-subview uchun ushbu oynaning ko'rinishlar to'plamini ko'rib chiqadi, so'ngra hajmi ko'rinishni o'lchamlari bilan tuzilishni qaytarish usuli va nihoyat kengligi o'zgarmaydigan nomga berilgan natija chiqarish uchun ushbu tuzilishdagi usul kengligi.

Ushbu yondashuv bilan bog'liq muammo shundaki, kod ushbu qiymatlarning barchasi mavjudligini taxmin qiladi. Oynaning kattaligi va uning kengligi bo'lishini kutish oqilona bo'lsa-da, "Asosiy" deb nomlangan oyna mavjud bo'ladi va uning beshta subvizyoni mavjud deb taxmin qilish umuman o'rinli emas. Agar ushbu taxminlardan biri noto'g'ri bo'lsa, usullardan biri null-ga kiritilib, null-ko'rsatgich xatosini keltirib chiqaradi.

Ushbu xatoga yo'l qo'ymaslik uchun dasturchi har qanday usul chaqiruvini qiymatini qaytarishini tekshirish uchun tekshirishi kerak. Xuddi shu kodning xavfsiz versiyasi:

agar derazalar.o'z ichiga oladi("Asosiy") {    agar derazalar("Asosiy").qarashlar.o'z ichiga oladi(5) {        kengligi = derazalar("Asosiy").qarashlar(5).hajmi().kengligi();        // theWidth bilan ishlaydigan ko'proq kod    }}

Agar dasturchi ushbu qiymatdan mavjud yoki yo'qligiga qarab foydalanmoqchi bo'lsa, ichidagi funktsional kod agar bayonotlar barchasi o'ng tomonga surilib, uzunroq satrlarni o'qishni qiyinlashtiradi. Bu ko'pincha kodni "tekislash" urinishlariga olib keladi:

agar derazalar.o'z ichiga oladi("Asosiy") { deraza = derazalar("Asosiy") }agar deraza != bekor && deraza.qarashlar.o'z ichiga oladi(5) { theView = deraza.qarashlar(5) }agar theView != bekor {    kengligi = theView.hajmi().kengligi();    // qo'shimcha kod}

Yoki alternativa:

agar !derazalar.o'z ichiga oladi("Asosiy") {    // xato xato} boshqa agar !derazalar("Asosiy").qarashlar.o'z ichiga oladi(5) {    // xato xato} boshqa {    kengligi = derazalar("Asosiy").qarashlar(5).hajmi().kengligi();    // theWidth bilan ishlaydigan ko'proq kod}

Ushbu turdagi dasturlash juda keng tarqalgan va bir qator dasturlash tillari qandaydir qo'shilgan sintaktik shakar buni hal qilish uchun. Masalan, Apple-ning Tez tushunchasini qo'shdi ixtiyoriy zanjir if ifodalarida[5] Microsoftniki esa C # 6.0 va Visual Basic 14 qo'shildi nol-shartli operatorlar ?. va ?[ mos ravishda a'zolarga kirish va indekslash uchun.[6][7][8] Asosiy g'oya shundan iboratki, agar biron bir a'zosi null bo'lsa, darhol chaqiriladigan usul chaqiradi.

kengligi = derazalar("Asosiy")?.qarashlar(5)?.hajmi.kengligi;

ga null tayinlaydi kengligi agar "Asosiy" yoki beshinchi subview yo'q bo'lsa, yoki bayonotni to'ldiring va agar ularning ikkalasi ham to'g'ri bo'lsa, kenglikni qaytaring. Dasturchi ushbu ikki holatda turli xil harakatlarni amalga oshirishni istagan paytlar ko'p, shuning uchun Svift bu rol uchun sintaktik shakarning yana bir shaklini qo'shadi agar ruxsat berilsa bayonot, shuningdek "ixtiyoriy majburiy" deb nomlanadi:

agar ruxsat bering theView = derazalar("Asosiy")?.qarashlar(5) {    // ko'rinish mavjudligini biladigan narsalarni qilish ...    kengligi = theView.hajmi.kengligi}

Shuningdek qarang

Adabiyotlar

  1. ^ Deyv Xerman (2011 yil 14-dekabr). "Nima uchun koroutinlar Internetda ishlamaydi". Kichkina kalkulyator. Arxivlandi asl nusxasidan 2016-03-06.
  2. ^ "Qiyomat piramidasi: javaScript uslubidagi tuzoq". 27 Noyabr 2012. Arxivlangan asl nusxasi 2015-12-09 kunlari.
  3. ^ Eberxardt, Kolin (2014 yil 8-dekabr). "Sviftning ixtiyoriy qiyomat piramidasini buzish". Arxivlandi asl nusxasidan 2016-07-31.
  4. ^ "Visual Basic 14 da yangi til xususiyatlari". 2014 yil 9-dekabr. Arxivlandi asl nusxasidan 2014-12-25.
  5. ^ "Ixtiyoriy zanjir". olma.
  6. ^ "Nol shartli operatorlar (C # va Visual Basic)". Microsoft.
  7. ^ "Visual C # uchun yangilik". Microsoft.
  8. ^ "Visual Basic uchun qanday yangiliklar". Microsoft.
  9. ^ Djo Zimmerman (2013 yil 28 mart). "Va'dalarning mohiyati nimada?". telerik.com.

[1]