Blok (programlama) - Block (programming)

İçinde bilgisayar Programlama, bir blok veya kod bloğu sözcüksel bir yapıdır kaynak kodu birlikte gruplandırılmış. Bloklar bir veya daha fazla beyannameler ve ifadeler. Diğer blokların içine yerleştirilmiş bloklar da dahil olmak üzere blokların oluşturulmasına izin veren bir programlama dili, blok yapılı programlama dili. Bloklar temeldir yapısal programlama, nerede Kontrol Yapıları bloklardan oluşur.

Programlamada blokların işlevi, ifade gruplarının tek bir ifadeymiş gibi ele alınmasını sağlamak ve sözcük kapsamı Bir blokta bildirilen değişkenler, prosedürler ve işlevler gibi nesnelerin başka bir yerde kullanılan aynı ada sahip olanlarla çelişmemesi için. Blok yapılı bir programlama dilinde, dış bloklarda isimlendirilen nesneler, olmadıkları sürece iç blokların içinde görülebilir. maskeli aynı isimle bildirilmiş bir nesne tarafından.

Tarih

Blok yapı fikirleri, 1950'lerde ilkinin gelişimi sırasında geliştirildi. otomatik kodlar ve resmileştirildi Algol 58 ve Algol 60 raporlar. Algol 58, yalnızca aşağıdakilerle ilgili olan "bileşik ifade" kavramını tanıttı kontrol akışı.[1] Sonraki Revize Rapor Algol 60'ın sözdizimini ve anlambilimini tanımlayan, bir blok kavramını tanıttı ve blok kapsamı, "[e] bildiriminin bu şekilde bir blok içinde göründüğü ve yalnızca bu blok için geçerli olduğu" [e] ifadesinin bir dizi ifadeyi takip ettiği ve başlangıç ​​ve bitiş arasında yer alan bir bildirimler dizisinden oluşan bir blok ile. "[2]

Sözdizimi

Bloklar, farklı dillerde farklı sözdizimi kullanır. İki geniş aile şunlardır:

  • Algol blokların anahtar kelimelerle ayrıldığı aile "başla" ve "son"veya eşdeğeri. İçinde C, bloklar kaşlı ayraçlarla sınırlandırılır - "{" ve "}". ALGOL 68 parantez kullanır.
  • Parantez - "(" ve ")", MS-DOS'ta kullanılır toplu dil
  • girinti, de olduğu gibi Python
  • s-ifadeleri gibi sözdizimsel bir anahtar kelimeyle lambda veya İzin Vermek (olduğu gibi Lisp aile)
  • 1968'de ( ALGOL 68 ), daha sonra Edsger W. Dijkstra 'ler 1974 Korunan Komut Dili koşullu ve yinelemeli kod bloğu, alternatif olarak blok ayrılmış kelime ile sonlandırılır ters: Örneğin. Eğer ~ sonra ~ elif ~ Başka ~ fi, durum ~ içinde ~ dışarı ~ esac ve için ~ süre ~ yapmak ~ od

Sınırlamalar

Bildirimlerle blokları destekleyen bazı diller tüm bildirimleri tam olarak desteklemez; örneğin birçok C'den türetilmiş dil bir blok içinde bir fonksiyon tanımına izin vermez (yuvalanmış işlevler ). Ve atası Algol'dan farklı olarak, Pascal, mevcut bir bloğun başında ve sonunda kendi bildirimleri olan blokların kullanılmasını desteklemez, yalnızca ifade dizilerinin birlikte gruplanmasını sağlayan bileşik ifadeler Eğer, süre, tekrar et ve diğer kontrol ifadeleri.

Temel anlambilim

Bir bloğun anlamsal anlamı iki yönlüdür. İlk olarak, programcıya, birimler olarak ele alınabilecek, keyfi olarak büyük ve karmaşık yapılar oluşturmanın bir yolunu sağlar. İkinci olarak, programcının değişkenlerin kapsamını ve bazen bildirilen diğer nesneleri sınırlamasını sağlar.

Erken dönem gibi ilkel dillerde Fortran ve TEMEL, birkaç yerleşik ifade türü vardı ve bunları yapılandırılmış bir şekilde genişletmenin çok az yolu veya hiç yolu yoktu. Örneğin, 1978 yılına kadar standart Fortran'ın "varsa engelle" ifadesi yoktu, bu nedenle programcının başvurması gereken basit kararları uygulamak için standartlara uygun bir kod yazmak için Gotos:

C     DİL: ANSI STANDART FORTRAN 66C     BAŞLAT DEĞERLER KİME BE HESAPLANMIŞ      PAYSTX = .YANLIŞ.      PAYSST = .YANLIŞ.      VERGİ = 0.0      SUPTAX = 0.0C     ATLA VERGİ İNDİRİM EĞER ÇALIŞAN KAZANÇLAR DAHA AZ THAN VERGİ EŞİK      EĞER (ÜCRETLER .LE. TAXTHR) GİT 100      PAYSTX = .DOĞRU.      VERGİ = (ÜCRETLER - TAXTHR) * BASCRTC     ATLA SUPERTAX İNDİRİM EĞER ÇALIŞAN KAZANÇLAR DAHA AZ THAN SUPERTAX EŞİK      EĞER (ÜCRETLER .LE. SUPTHR) GİT 100      PAYSST = .DOĞRU.      SUPTAX = (ÜCRETLER - SUPTHR) * SUPRAT  100 VERGİLİ = ÜCRETLER - VERGİ - SUPTAX

Fortran 66 standardına yazılan bu çok kısa Fortran fragmanında bile programın yapısını görmek kolay değil çünkü bu yapı dile yansımıyor. Dikkatli bir çalışma olmadan, belirli bir ifadenin yürütüldüğü koşulları görmek kolay değildir.

Bloklar, programcının bir grup ifadeyi bir birim olarak ele almasına izin verir ve bu programlama tarzında başlatmada görünmesi gereken varsayılan değerler, bir blok yapısı ile karara daha yakın yerleştirilebilir:

    {Dil: Jensen ve Wirth Pascal}    Eğer ücretler > tax_threshold sonra        başla        maaş vergisi := doğru;        vergi := (ücretler - tax_threshold) * vergi oranı        {Blok yapısı, kodun nasıl olabileceğini görmeyi kolaylaştırır.          anlaşılır olması için yeniden düzenlenmeli ve ayrıca yapılması daha kolay hale getirilmelidir,          çünkü iç koşullu yapısı kolaylıkla hareket ettirilebilir          tamamen dış koşulların dışında ve yapmanın etkileri          bu yüzden kolayca tahmin edilebilir. }        Eğer ücretler > supertax_threshold sonra            başla            pays_supertax := doğru;            süper vergi := (ücretler - supertax_threshold) * supertax_rate            son        Başka başla            pays_supertax := yanlış;            süper vergi := 0            son        son    Başka başla        maaş vergisi := yanlış; pays_supertax := yanlış;        vergi := 0; süper vergi := 0        son;    vergilendirilmiş := ücretler - vergi - süper vergi;

Yukarıdaki parçadaki blokların kullanımı Pascal programcının amacını açıklığa kavuşturur ve ortaya çıkan blokların iç içe geçmiş bir hiyerarşide birleştirilmesini sağlar. şartlı ifadeler. Kodun yapısı, programcının düşüncesini daha yakından yansıtır ve anlaşılmasını ve değiştirilmesini kolaylaştırır.

Yukarıdaki kaynak kodu, iç if ifadesini dış olandan tamamen çıkararak, iki bloğu arka arkaya çalıştırılacak şekilde birbiri ardına yerleştirerek daha da netleştirilebilir. Anlamsal olarak bu durumda çok az fark vardır ve okunabilirlik için girintileme ile desteklenen blok yapısının kullanılması, programcının kodu yeniden düzenlemesini kolaylaştırır.

İlkel dillerde değişkenlerin geniş kapsamı vardı. Örneğin, IEMPNO adlı bir tam sayı değişkeni, bir çalışan sosyal güvenlik numarasını (ssn) belirtmek için bir Fortran alt yordamının bir bölümünde kullanılabilir, ancak aynı alt yordam üzerindeki bakım çalışması sırasında, bir programcı yanlışlıkla aynı değişkeni, IEMPNO farklı bir amaç ve bu, izlenmesi zor bir hataya neden olabilir. Blok yapısı, programcıların kapsamı bir dakika düzeyinde kontrol etmesini kolaylaştırır.

;; Dil: R5RS Standart Şema(İzin Vermek ((empno (ssn-of İşçi adı)))  (süre (yönetici empno)    (İzin Vermek ((çalışanlar (uzunluk (astları empno))))      (printf "~ a'nın ~ altında çalışan bir çalışanı var: ~%" İşçi adı çalışanlar)      (her biri için        (lambda(empno)          ;; Bu lambda ifadesi içinde empno değişkeni ssn'yi ifade eder          ;; bir astın. Dış ifadede empno değişkeni,          ;; yöneticinin SSn'sine atıfta bulunarak gölgelendirilir.          (printf "Ad: ~ a, rol: ~ a ~%"                  (adına empno)                  (rolü empno)))        (astları empno)))))

Yukarıda Şema fragment, empno, hem yöneticiyi hem de onun alt gruplarını kendi ssn'lerine göre tanımlamak için kullanılır, ancak temel ssn bir iç blok içinde bildirildiği için, yöneticinin ssn'sini içeren aynı isimli değişkenle etkileşime girmez. Pratikte, netlik hususları muhtemelen programcının farklı değişken isimleri seçmesine yol açacaktır, ancak onun seçimi vardır ve yanlışlıkla bir hatayı ortaya çıkarmak daha zordur.

Kaldırma

Birkaç durumda, bir bloktaki kod, kod gerçekten bloğun tepesindeymiş veya bloğun dışındaymış gibi değerlendirilir. Bu genellikle halk dilinde kaldırmave şunları içerir:

  • Döngüde değişmeyen kod hareketi döngüdeki değişmez kodun döngüden önce değerlendirildiği bir derleyici optimizasyonu;
  • Değişken kaldırma, JavaScript'te, değişkenlerin işlev kapsamına sahip olduğu ve bir işlevin tepesinde bildirilmiş (ancak tanımlanmamış) gibi davranan bir kapsam kuralı.

Ayrıca bakınız

Referanslar

  1. ^ Perlis, A. J.; Samelson, K. (1958). "Ön rapor: uluslararası cebir dili". ACM'nin iletişimi. New York, NY, ABD: ACM. 1 (12): 8–22. doi:10.1145/377924.594925.
  2. ^ Backus, J. W.; Bauer, F.L.; Green, J .; Katz, C .; McCarthy, J .; Perlis, A. J .; Rutishauser, H.; Samelson, K .; Vauquois, B .; Wegstein, J. H .; van Wijngaarden, A .; Woodger, M. (Mayıs 1960). Naur, Peter (ed.). "Algoritmik Dil ALGOL 60 Raporu". 3 (5). New York, NY, ABD: ACM: 299–314. doi:10.1145/367236.367262. ISSN  0001-0782. Alındı 2009-10-27. Alıntı dergisi gerektirir | günlük = (Yardım)