CAL (dasturlash tili) - CAL (programming language)

CAL, qisqasi Suhbatlashuvchi algebraik til, edi a dasturlash tili va tizim tomonidan ishlab chiqilgan va ishlab chiqilgan Butler Lempson da Berkli 1967 yilda SDS 940 asosiy kompyuter. CAL - bu seminalning bir versiyasi JOSS SDS platformasidan foydalanish uchun bir qator tozalash va yangi xususiyatlarga ega til.

Berkli SDS-dan foydalanish uchun ishlatilgan Timshare tijorat vaqtni taqsimlash platformasi va CAL-ning takomillashtirilgan versiyasi 1969 yilda o'z mijozlariga dasturlash muhiti sifatida taqdim etilgan. Garchi CAL "deyarli foydasiz" ko'rinishga ega bo'lsa-da, uning dizayniga ta'sir qilib doimiy ta'sir ko'rsatdi. Tymshare SUPER BASIC uning bir qator xususiyatlarini nusxalashgan. Ushbu xususiyatlarning ba'zilari, o'z navbatida, paydo bo'ldi BASIC-PLUS ustida PDP-11 ning to'g'ridan-to'g'ri ajdodi bo'lgan Microsoft BASIC.[1]

Tavsif

Asosiy tushunchalar

JOSS dasturi dasturlashtirmaydiganlar tomonidan ishlatilishi uchun mo'ljallangan edi AQSh havo kuchlari va ichida Rand korporatsiyasi va bunga yordam berish uchun Rand odatiy ravishda ishlab chiqilgan kompyuter terminallari o'rnatish va ulardan foydalanish osonroq bo'lgan. Ga asoslangan ushbu terminallar IBM Selectric yozuv mashinasi, shuningdek, odat tusiga kiritilgan belgilar to'plami kabi umumiy matematik belgilarni amalga oshirgan va .

Katta darajada, CAL JOSS versiyasi bo'lib, bu kabi xususiylashtirishlarni odatdagidek echimlar bilan almashtirdi >= va # shuning uchun ular umumiy terminallarda ishlashlari mumkin edi.[2] Boshqa sezilarli farqlar shundaki, CAL JOSS-dagi jumlaga qarama-qarshi bo'lganidan farqli o'laroq, katta harflar bilan yozilgan va bu satr oxirida muddatni talab qilmagan.[3] Buyruqlar deyarli bir xil edi va umumiy tuzilish va sintaksis bir xil edi.

JOSS-da bo'lgani kabi, CAL ham interaktiv edi foydalanuvchi interfeysi bu foydalanuvchiga "to'g'ridan-to'g'ri rejimda" bayonotlarni yoki "bilvosita rejimda" ishlaydigan dasturlarni yozishga imkon berdi. BASIC-da birinchisi ko'proq "tezkor rejim" deb nomlanadi. Ham CAL, ham JOSS ikki qismdan foydalangan qator raqami, nuqta bilan ajratilgan qism va qadam sifatida tanilgan, masalan, 1.100 1-qism uchun 100-qadam. Odatda qismlar tegishli bayonotlarni pastki dasturlarga guruhlash uchun ishlatilgan. CAL-da qism raqami 0 dan 999999 gacha, qadam esa 0 dan 99999 gacha bo'lishi mumkin.[4]

1967 va 1969 yillarda chiqarilgan CAL-ning ikkita asosiy versiyasi mavjud edi. Quyidagi tavsif asosan boshqacha ko'rsatilmagan bo'lsa, avvalgi versiyasiga asoslangan bo'ladi.

O'tish va pastki dasturlar

JOSS-da bo'lgani kabi, CAL ham qo'llab-quvvatladi TO ko'rsatilgandek, taqdim etilgan qismga yoki pog'onaga tarmoqlanish buyrug'i 3 QISMGA yoki 4.5 QADAMva QILING kabi subroutine qo'ng'iroqlari uchun 9-QISMNI QILING butun qismini bajarish uchun yoki 5.1 QADAMNI QO'YING bitta qadamni bosib, keyin qaytish uchun. Keyinchalik sintaksis juda kichik kichik dasturlar mavjud bo'lganda foydalandi, chunki ular bir satrda bog'lanmasdan amalga oshirilishi mumkin edi QAYTISH yoki shunga o'xshash tushuncha.[5]

Shartli dallanma va tayinlash

JOSS-ning diqqatga sazovor bo'lgan sintaktik xususiyatlaridan biri bu boshqa bayonotlarning ishlashini boshqaradigan "bayonot modifikatorlari" tushunchasi edi. JOSS buni shartli dallanish uchun ishlatgan.

Ko'pgina tillarda "agar bu ifoda to'g'ri bo'lsa, unda buni bajaring ..." degan ma'noni anglatadi. JOSS-da ushbu buyruq bekor qilindi va bunday bayonotlar "agar bu to'g'ri bo'lsa, buni bajaring" shaklini oldi, masalan, Agar X = 5 bo'lsa, "HELLO" yozing.. CAL biroz qo'shdi sintaktik shakar yangi modifikatorni qo'shish orqali ushbu asosiy tushunchaga BELGISIZ, bu kontekstga qarab, aniqroq kodga olib keldi; X = 5 BILMAYDIGAN "BESHMOQ Teng emas" turi.[6]

Shunday qilib, A o'zgaruvchiga 5 qiymatini berish uchun, agar B qiymati 10 dan katta bo'lsa, aks holda 0, kod quyidagicha bo'ladi:

Agar B> 10. bo'lsa A = 5 ni o'rnating, agar B <= 10 bo'lsa, A = 0 ni o'rnating.

CAL ham qo'llab-quvvatlanadi shartli iboralar:[7]

A = IF B> 10 UNDAN 5 BOShQA 0

Shunga o'xshash o'zgartirish Qaerda iborasi, if yoki for ning bir qismi sifatida o'zgaruvchilarni o'rnatish uchun ishlatiladi. Bu kontseptsiya jihatidan if / then / else tuzilmasiga o'xshash edi, lekin har qanday sonli elementga ega bo'lishi mumkin edi. Masalan; misol uchun,= A * B Qaerda A = B A> 20 gacha, Qaerda A = 1 A> 100 gacha.[8]

Ko'chadan

JOSS-da tsikl ham modifikator tomonidan boshqarilgan Uchun. Bunda biroz tushunarsiz sintaksis ishlatilgan; I = 1 (2) 10 uchun i yozing. 1 dan 10 gacha bo'lgan ko'chadan 2 ga qadam bosadi, shuning uchun 1,3,5,7,9 ni bosib chiqaradi. Bundan tashqari, aniq qiymatlarni etkazib berish mumkin, I = 1,5,6,7,10 uchun i turini yozing.yoki ikkalasini aralashtiring, I = 1,5 (1) 7,10 uchun i turini yozing.

CAL-ni joriy qilish orqali JOSS sintaksisida yaxshilandi BILAN va TO kalit so'zlar, shuning uchun CAL-dagi ekvivalent kod bo'ladi I toifa I = 1 2 dan 10 gacha. JOSS-da, qadam qiymati atrofidagi qavs ikki chegarani ajratuvchi edi, shuning uchun uni ixtiyoriy qilib bo'lmaydi. Ajratish orqali TO chegaralar aniq bo'ldi va BILAN 1 deb taxmin qilinganidek ixtiyoriy qilingan; I TURI I = 1 dan 10 gacha. JOSS-da bo'lgani kabi, aniq qiymatlar va diapazonlardan foydalanish mumkin; I TURI I = 1,5 TO7, 10. Dan foydalanib, CAL shartli chiqishlarni qo'shib for forni yanada o'zgartirdi VAQTDA va TO'G'RISIDA. Masalan; misol uchun, A <= 50 bo'lganda A = 1 BY 1 uchun 1 turi yoki A = 50 gacha B = 1 UChUN B turi.[9]

Foydalanuvchi tomonidan belgilangan funktsiyalar

JOSS foydalanuvchiga funktsiyalarni Ruxsat bering bayonot. Sintaksis funktsional imzoda mahalliy o'zgaruvchilarning nomlanishiga imkon berdi; F (X, Y) = X + Y bo'lsin. Keyin dasturlar ushbu funktsiyalarni xuddi o'rnatilgan kabi chaqirishi mumkin, A = F (1,5) ni o'rnating.

CAL o'zgartirildi Ruxsat bering ga Aniqlang, bu juda aniq va parametrlarni parantez o'rniga qavs yordamida o'tkazishda kichikroq o'zgarishlarni amalga oshirdi, shuning uchun ekvivalent ta'rif bo'ladi F [X, Y] = X + Y ni aniqlang va xuddi shu tarzda chaqirildi, SET A = F [1,5].[10]

CAL funktsiyalarining muhim o'zgarishi - bu subroutines-ni ta'riflardan chaqirish qobiliyati TO, kabi F (X, Y) TA'RIFI: 5-QISMGA.[a] Natijada, hisoblangan qiymatni funktsiyaga qaytarish masalasini qoldirdi, bu esa kiritilishi bilan hal qilindi Qaytish Z qism oxirida bayonot, bu erda Z - qaytariladigan yakuniy qiymat.[10]

Boshqa o'zgarishlar

CAL JOSS-ning matematik funktsiyalarini o'z ichiga olgan, ammo bir qator yangilarini qo'shgan ABS, TAN, ATANva LOG10.[11] Bu yangi operatorni ham qo'shdi, MOD, bu uning ikkita operandasi bo'linmasining qolgan qismini qaytarib berdi.[12]

To'g'ridan-to'g'ri rejim

CAL oz sonli to'g'ridan-to'g'ri rejim buyruqlari va tegishli bayonotlarni qo'shdi.

PAUSE, dasturda duch kelganda, "STEP 1.1 STEP AT" xabarini chop etdi va keyin to'g'ridan-to'g'ri rejimga qaytdi. Bu o'xshash edi TO'XTA BASIC-da buyruq. Bu foydalanuvchiga qiymatlarni yozishga va bajarishni davom ettirishga imkon berdi GO.[13] To'g'ridan-to'g'ri rejimda foydalanuvchi mumkin edi QADAM dasturning bajarilishini kuzatish uchun bir vaqtning o'zida bitta qator bilan.[13]

CAL JOSS-ni o'zgartirdi ' Ruxsat bering foydalanuvchi tomonidan aniqlangan funktsiya biroz aniqroq Aniqlang, () o'rniga [] ishlatish uchun parametrlar ro'yxatini o'zgartirganda. JOSS-da ular odatda to'g'ridan-to'g'ri rejimda, CAL-da esa faqat to'g'ridan-to'g'ri rejimda topilgan. Masalan, mumkin F [N] = PROD (I = 1 dan N gacha). Ushbu misol, shuningdek, JOSS ning funktsiyaga kirish sifatida pastadir oralig'idan foydalanish qobiliyatini namoyish etadi.[14] JOSS-dan farqli o'laroq, CAL ko'p bosqichli funktsiyalarga ko'p sonli nuqta bilan ajratilgan qo'shimcha so'zlarni qo'shish orqali ruxsat berdi, masalan, X [A, B, C] TA'RIFI: 5-QISMNI QILING. E'tibor bering, ushbu misolda tanasi yo'q, shunchaki c ni chaqiradi

CAL 1969-dagi yaxshilanishlar

1969 yilgi versiyadagi kichik o'zgarishlardan biri bu bekor qilingan O'rnatish uchun buyruq o'zgaruvchan tayinlash. Bu to'g'ridan-to'g'ri rejimda JOSS-da ixtiyoriy edi, ammo dastur bayonotlarida talab qilingan va 1967-yilgi CAL versiyasi ushbu qoidaga amal qilgan.[15] 1969 yilgi versiya uni ikkala holatda ham ixtiyoriy qildi.

Izohlar

  1. ^ DO odatda subroutines-ga qo'ng'iroq qilish uchun ishlatilishini hisobga olsak, nima uchun ular bu holatda TO ni tanlagani aniq emas.

Adabiyotlar

Iqtiboslar

  1. ^ Lempson, "Tizimlar", Tadqiqot, Microsoft.
  2. ^ 1969 yilda qo'llanma, p. 7.
  3. ^ 1969 yilda qo'llanma, p. 23.
  4. ^ 1969 yilda qo'llanma, p. 11.
  5. ^ 1969 yilda qo'llanma, p. 15, 26.
  6. ^ 1969 yilda qo'llanma, p. 12.
  7. ^ 1969 yilda qo'llanma, p. 14.
  8. ^ 1969 yilda qo'llanma, p. 21.
  9. ^ 1969 yilda qo'llanma, p. 13.
  10. ^ a b Qo'llanma 1967 yil, p. 27.
  11. ^ Qo'llanma 1967 yil, p. 9.
  12. ^ Qo'llanma 1967 yil, p. 10.
  13. ^ a b Qo'llanma 1967 yil, p. 25.
  14. ^ Qo'llanma 1967 yil, p. 26.
  15. ^ Qo'llanma 1967 yil, p. 8.

Bibliografiya