Filial (informatika) - Branch (computer science)

A filial a ko'rsatmasi kompyuter dasturi bu kompyuterning boshqa buyruqlar ketma-ketligini bajarishni boshlashiga va shu bilan ko'rsatmalar tartibida bajarilishining odatiy harakatlaridan chetga chiqishiga olib kelishi mumkin.[a] Filial (yoki dallanma, tarvaqaylab ketgan) shuningdek, filial buyrug'ini bajarish natijasida bajarilishini boshqa ko'rsatmalar ketma-ketligiga o'tkazish aktiga murojaat qilishi mumkin. Amalga oshirish uchun filial ko'rsatmalaridan foydalaniladi oqim oqimi dastur tsikllarida va shartli holatlarda (ya'ni, ma'lum bir ko'rsatmalar ketma-ketligini faqat ma'lum shartlar bajarilgan taqdirda bajarish).

Filial ko'rsatmasi ham bo'lishi mumkin shartsiz filial, bu har doim dallanishga olib keladi yoki shartli filial, bu ba'zi bir holatlarga qarab dallanishga olib kelishi mumkin yoki bo'lmasligi mumkin. Shuningdek, yangi ko'rsatmalar ketma-ketligining manzilini ("maqsadli" manzil) qanday belgilashiga qarab, filial ko'rsatmasi odatda quyidagicha tasniflanadi: to'g'ridan-to'g'ri, bilvosita yoki nisbiy, ya'ni ko'rsatma maqsadli manzilni o'z ichiga olganligini yoki maqsadli manzilni qaerda topilishini (masalan, registr yoki xotira joyini) yoki joriy va maqsadli manzillar orasidagi farqni bildirishini anglatadi.[1]

Amalga oshirish

Mexanik ravishda filial ko'rsatmasi o'zgarishi mumkin dastur hisoblagichi (Kompyuter) a Markaziy protsessor. Dastur hisoblagichida bajariladigan navbatdagi ko'rsatmaning xotira manzili saqlanadi. Shuning uchun, filial protsessorga o'z ko'rsatmalarini boshqa xotira hujayralari ketma-ketligidan olishni boshlashiga olib kelishi mumkin.

Qachon filial olingan, protsessorning dastur hisoblagichi o'rnatilgan dalil sakrash buyrug'i. Shunday qilib, keyingi ko'rsatma ushbu manzil bo'yicha ko'rsatma bo'ladi xotira. Shuning uchun boshqaruv oqimi o'zgaradi.

Qachon filial olinmadi, protsessorning dastur hisoblagichi o'zgarmagan. Shuning uchun, bajarilgan navbatdagi ko'rsatma filial buyrug'idan keyingi ko'rsatma. Shuning uchun boshqaruv oqimi o'zgarmaydi.

Atama filial yuqori darajadagi tillardagi dasturlarga, shuningdek yozilgan dasturlarga murojaat qilishda foydalanish mumkin mashina kodi yoki assambleya tili. Yilda yuqori darajadagi dasturlash tillari, filiallar odatda shaklini oladi shartli gaplar shartlar bajarilgan taqdirda bajariladigan ko'rsatmalar ketma-ketligini o'z ichiga olgan har xil shakllardan. Kabi shartsiz filial ko'rsatmalari GOTO boshqa ko'rsatmalar ketma-ketligiga shartsiz "sakrash" (bajarishni boshlash) uchun ishlatiladi.

Ba'zan mashina darajasidagi filial ko'rsatmalari deyiladi sakramoq ko'rsatmalar. Odatda mashina darajasidan sakrash bo'yicha ko'rsatmalar mavjud shartsiz va shartli ikkinchisi bo'lishi mumkin bo'lgan shakllar olingan yoki olinmadi ba'zi bir holatga qarab. Odatda tez-tez chaqiriladigan bir tomonlama o'tish uchun alohida shakllar mavjud sakramoq va ma'lum bo'lgan subroutine chaqiruvlari qo'ng'iroq qiling avtomatik ravishda boshlang'ich manzilni stekdagi qaytarish manzili sifatida saqlaydi va bu kodning bir nechta joylaridan bitta subroutine-ni chaqirishga imkon beradi.

Bilan protsessorlarda bayroq registrlari, oldingi buyruq bayroq registrida shart qo'yadi. Oldingi ko'rsatma bo'lishi mumkin arifmetik yoki mantiq ko'rsatma. Odatda filialga yaqin, ammo ko'rsatma bo'lishi shart emas darhol filial oldida. Saqlangan holat keyinchalik filialda ishlatiladi haddan tashqari bayroq o'rnatilgan bo'lsa sakrash. Ushbu vaqtinchalik ma'lumot ko'pincha bayroq registrida saqlanadi, lekin boshqa joyda ham bo'lishi mumkin. Bayroq registri dizayni sekinroq va oddiy kompyuterlarda oddiy. Tezkor kompyuterlarda bayroq registri tezlikka to'siq qo'yishi mumkin, chunki aks holda parallel ravishda ishlashi mumkin bo'lgan ko'rsatmalar (bir nechtasida) ijro birliklari ) bayroq bitlarini ma'lum bir ketma-ketlikda o'rnatish kerak.

Shuningdek, vaziyatni sakrash buyrug'i tomonidan tekshirilishi mumkin bo'lgan mashinalar (yoki alohida ko'rsatmalar) mavjud filial , agar registr X salbiy bo'lsa. Oddiy kompyuter konstruktsiyalarida taqqoslash tarmoqlari ko'proq arifmetikani bajaradi va bayroq registrlari filiallaridan ko'ra ko'proq quvvat ishlatishi mumkin. Tezkor kompyuter konstruktsiyalarida taqqoslash shoxlari bayroq registrlari shoxlariga qaraganda tezroq ishlashi mumkin, chunki taqqoslash shoxlari registrlarga ko'proq parallellik bilan kira oladi va hisoblash bilan bir xil protsessor mexanizmlaridan foydalanadi.

Hali ham mikrokontrollerlarda mavjud bo'lgan ba'zi bir erta va oddiy protsessor arxitekturalari shartli sakrashni amalga oshirmasligi mumkin, aksincha faqat "keyingi ko'rsatmalarni o'tkazib yuborish" operatsiyasini bajarishi mumkin. Shartli sakrash yoki qo'ng'iroq shu tariqa shartsiz sakrash yoki chaqiruv buyrug'ining shartli o'tkazib yuborilishi sifatida amalga oshiriladi.

Misollar

Ga qarab kompyuter arxitekturasi, assambleya tili mnemonik chunki sakrash buyrug'i odatda so'zning qisqartirilgan shakli hisoblanadi sakramoq yoki so'z filial, ko'pincha shartni ifodalovchi boshqa ma'lumotli harflar (yoki qo'shimcha parametr) bilan birga. Ba'zan boshqa tafsilotlar ham kiradi, masalan, sakrash diapazoni (ofset hajmi) yoki haqiqiy effektli ofsetni topish uchun ishlatilishi kerak bo'lgan maxsus adreslash rejimi.

Ushbu jadvalda bir nechta taniqli arxitekturalarda topilgan mashina darajasidagi filial yoki sakrash ko'rsatmalari keltirilgan:

holat yoki natijax86PDP-11, VAXARM (qisman 6502)tenglama
nol (sub / cmp uchun teng degani)JZ; JNZBEQ; BNEBEQ; BNEnol; nol emas
salbiy (N), belgi (S) yoki minus (M)JS; JNSBMI; BPLBMI; BPLsalbiy; salbiy emas
arifmetik toshish (O yoki V deb nomlangan bayroq)JO; JNOBVS; BVCBVS; BVCtoshib ketish; toshib ketmaslik
ko'chirish (add, cmp, shift va boshqalardan)JK; JNCBCS; BCCBCS; BCCko'tarish; olib bormang
imzosiz pastda (pastki)JBBLOBLO *qarz olish
imzosiz pastda yoki teng (pastki yoki bir xil)JBEBLOSBLS *qarz yoki nol
imzosiz yuqoriroq yoki teng (yuqori yoki bir xil)JAEBHISBHS *qarz olmang
imzosiz yuqorida (yuqoriroq)JABHIBHI *qarz olmang va nolga teng emas
imzolangan dan kamJLBLTBLTbelgi ≠ toshib ketgan
imzolangan kamroq yoki tengJLEBLEBLE(≠ belgisi) yoki nol
imzolangan katta yoki tengJGEBGEBGEishora = toshib ketish
imzolangan dan kattaJGBGTBGT(belgisi = toshib ketish) va nol emas

* x86, PDP-11, VAX va boshqalar, ko'tarish bayrog'ini signal berish uchun o'rnatgan qarz olish va signal berish uchun bayroqchani tozalang qarz yo'q. ARM, 6502, PIC va boshqalar, olib tashlash operatsiyalari uchun aksini qiladi. Belgilangan ko'rsatmalar uchun ko'chirish bayrog'ining bu teskari funktsiyasi (bilan belgilanadi)*), anavi, qarz =emas olib yurmoq jadvalning ba'zi qismlarida, lekin boshqacha ko'rsatilmagan bo'lsa, qarz olib o'ting. Biroq, qo'shimcha operatsiyalarni davom ettirish ko'pgina arxitekturalar tomonidan xuddi shu tarzda amalga oshiriladi.

Filial ko'rsatmalaridagi ishlash muammolari

Yuqori ishlashga erishish uchun zamonaviy protsessorlar quvurli. Ular bir nechta qismlardan iborat bo'lib, ularning har biri ko'rsatmalarni qisman qayta ishlaydi, natijalarini quvur liniyasining keyingi bosqichiga etkazadi va dasturning keyingi ko'rsatmasi bilan ishlashni boshlaydi. Ushbu dizayn ko'rsatmalarning o'zgarmaydigan ketma-ketlikda bajarilishini kutmoqda. Shartli filial ko'rsatmalari ushbu ketma-ketlikni bilishning iloji yo'q. Shunday qilib, shartli filiallar dasturning boshqa qismida quvurlarni qayta ishga tushirishga majbur bo'lgan "to'xtash joylari" ni keltirib chiqarishi mumkin.

Filiallardan to'xtash joylarini kamaytirish orqali ish faoliyatini yaxshilash

Bir nechta texnikalar tezlikni shartli filiallardan to'xtash joylarini kamaytirish orqali yaxshilaydi.

Filialni bashorat qilish bo'yicha maslahatlar

Tarixiy jihatdan, filialni bashorat qilish statistikani oldi va natijani kodni optimallashtirish uchun ishlatdi. Dasturchi dasturning sinov versiyasini tuzadi va uni test ma'lumotlari bilan ishlaydi. Sinov kodi filiallarning aslida qanday olinganligini hisobladi. Keyinchalik test kodidan olingan statistika kompilyator tomonidan chiqarilgan kodning tarmoqlarini optimallashtirish uchun ishlatilgan. Optimallashtirish eng tez yo'nalish yo'nalishini (qabul qilingan yoki olinmagan) har doim eng tez-tez boshqariladigan oqim oqimi bo'lishini tashkil qiladi. Bunga ruxsat berish uchun protsessorlar prognoz qilinadigan filial vaqtlari bilan ishlab chiqilishi kerak (yoki hech bo'lmaganda). Ba'zi protsessorlarda ko'rsatmalar to'plami mavjud (masalan Quvvat ISA ) kompilyator har bir filialni qanday qabul qilish kerakligini CPUga aytib berishi uchun "filial ko'rsatmalari" bilan yaratilgan.

Dasturiy ta'minot sohasini bashorat qilish bilan bog'liq muammo shundaki, u dasturiy ta'minotni ishlab chiqishning murakkab jarayonini talab qiladi.

Uskuna tarmog'ining predikatorlari

Har qanday dasturiy ta'minotni, apparatni ishlatish uchun filialni bashorat qiluvchilar statistikani elektronikaga o'tkazdi. Filialni bashorat qiluvchilar - bu shartli tarmoq natijasini taxmin qiladigan protsessor qismlari. Keyin protsessorning mantig'i taxmin qilingan buyruqlar oqimini bajarishni boshlash bilan taxmin qilish bo'yicha o'ynaydi. Oddiy uskuna tarmog'ini bashorat qilish sxemasining misoli shundan iboratki, barcha orqaga burilgan filiallar (ya'ni kichikroq dastur hisoblagichiga) olinadi (chunki ular tsiklning bir qismi) va oldinga yo'naltirilgan barcha tarmoqlar (kattaroq dastur hisoblagichiga) olinmaydi. (chunki ular loop qoldiradilar). Yaxshi filiallarni bashorat qiluvchilarni turli xil test dasturlarida simulyatsiya qilish orqali ishlab chiqiladi va statistik jihatdan tasdiqlanadi. Yaxshi bashorat qiluvchilar odatda filialni oldingi qatl natijalarini hisoblashadi. Keyinchalik tezroq va qimmatroq bo'lgan kompyuterlar, bashorat qilinadigan elektronika sohalariga sarmoya kiritish orqali tezroq ishlashi mumkin. Uskuna tarmog'ini bashorat qiladigan protsessorda filial ko'rsatmalari kompilyatorning taxmin qilinadigan ustun bo'linmasining qo'shimcha qurilmaning soddalashtirilgan filiali bashoratini bekor qilishiga imkon beradi.

Filialsiz kod

Ba'zi mantiqlarni shoxlarsiz yoki kamroq shoxlar bilan yozish mumkin. Ko'pincha foydalanish mumkin bitli operatsiyalar, shartli harakatlar yoki boshqa predikatsiya filiallar o'rniga.[2][3] Aslida, filialsiz kod kriptografiya uchun zarurdir hujumlarni vaqtini belgilash.[4]

Kechikish uyasi

Boshqa usul - bu filialni kechiktirish uyasi. Ushbu yondashuvda filialdan keyin bitta ko'rsatma doimo bajariladi. Shuning uchun, kompyuter ushbu yo'riqnomadan foydalanib, uning quvur liniyasi to'xtab qolishidan qat'iy nazar foydali ishlarni amalga oshirishi mumkin. Ushbu yondashuv tarixiy jihatdan mashhur bo'lgan RISC kompyuterlar. Uyg'un protsessorlar oilasida bu ko'p velosipedli protsessorlarni (quvur liniyasi bo'lmagan holda), kutilganidan uzoqroq quvur liniyalariga ega tezroq protsessorlarni va superskali protsessorlarni (ko'rsatmalarni tartibsiz bajarishi mumkin) murakkablashtiradi.

Shuningdek qarang

Izohlar

  1. ^ Hech bo'lmaganda kontseptual; qarang buyurtmadan tashqari ijro.

Adabiyotlar

  1. ^ "Dinamik tarmoqlarni bashorat qilish usullari bo'yicha so'rov ", S. Mittal, CPE 2018
  2. ^ Knuth, Donald (2008). Kompyuter dasturlash san'ati. 4-jild, fasadgacha 1A (6-tahrirdagi tahrir). 48-49 betlar.
  3. ^ "Filiallardan saqlanish". Chessprogramming wiki.
  4. ^ "Doimiy ishlaydigan kripto". BearSSL.

Tashqi havolalar