CLU (programlama dili) - CLU (programming language)

CLU
Paradigmaçoklu paradigma: nesne odaklı, prosedürel
Tarafından tasarlandıBarbara Liskov ve onun öğrencileri
GeliştiriciMassachusetts Teknoloji Enstitüsü
İlk ortaya çıktı1975; 45 yıl önce (1975)
Kararlı sürüm
Yerel CLU 1.5 (SPARC, VAX ) / 26 Mayıs 1989; 31 yıl önce (1989-05-26)[1]

Taşınabilir CLU / 6 Kasım 2009; 11 yıl önce (2009-11-06)[2]

Yazma disiplinikuvvetli
İnternet sitesiwww.pmg.lcs.mit.edu/ CLU.html
Majör uygulamalar
Yerel CLU,[1] Taşınabilir CLU,[2] clu2c[3]
Tarafından etkilenmiş
ALGOL 60, Lisp, Simula, Alphard
Etkilenen
Ada, Argus, C ++, Lua, Python,[4] Yakut, Sather, Swift[5]

CLU bir Programlama dili yaratıldı Massachusetts Teknoloji Enstitüsü (MIT) tarafından Barbara Liskov ve öğrencileri 1974-1975 yılları arasında. Kapsamlı bir kullanım bulmasa da, şu anda yaygın olarak kullanılan birçok özelliği tanıttı ve gelişiminde bir adım olarak görülüyor. nesne yönelimli programlama (OOP).

Önemli katkılar şunları içerir: soyut veri türleri,[6] paylaşarak arama, yineleyiciler, birden çok dönüş değeri (bir paralel atama ), tür açısından güvenli parametreli türler ve tür açısından güvenli varyant türleri. Ayrıca kullanımı ile de dikkat çekicidir. sınıflar ile inşaatçılar ve yöntemler, ancak olmadan miras.

Kümeler

sözdizimi CLU'nun temel aldığı Algol, daha sonra çoğu yeni dil tasarımı için başlangıç ​​noktası. Anahtar ekleme, bir küme, CLU'nun tür genişletme sistemi ve dil adının kökü (CLUster).[7] Kümeler genellikle bir OO dilinde bir "sınıf" kavramına karşılık gelir. Örneğin, işte bir küme için CLU sözdizimi Karışık sayılar:

    karmaşık_sayı = küme toplama, çıkarma, çarpma, ... rep = kayıt [gerçek_bölüm: gerçek, resim_bölüm: gerçek] add = proc ... son ekleme; çıkarma = proc ... end çıkarma; multiply = proc ... end multiply; ... karmaşık_sayıyı sonlandır;

Küme, "is" yan tümcesinde açıkça belirtilenler dışında tüm bileşenlerini kapsayan bir modüldür. Bunlar, son OO dillerinde bir sınıfın genel bileşenlerine karşılık gelir. Bir küme aynı zamanda kümenin dışında adlandırılabilen bir türü de tanımlar (bu durumda, "karmaşık_sayı"), ancak temsil türü (rep) harici istemcilerden gizlenir.

Küme adları geneldir ve kümeleri gruplamak veya diğer kümelerin içinde "yerel olarak" oluşturulmalarına izin vermek için hiçbir ad alanı mekanizması sağlanmamıştır.

CLU gerçekleştirmiyor örtük tür dönüştürmeleri. Bir kümede, açık tür dönüşümleri yukarı ve aşağı soyut tür ve temsil arasında değişiklik. Evrensel bir türü var hiçve bir nesnenin belirli bir tip olup olmadığını kontrol etmek için bir prosedür gücü []. Nesneler değişebilir veya değişmez olabilir, ikincisi baz türleri tamsayılar, mantıksal değerler, karakterler ve dizeler gibi.[7]

Diğer özellikler

CLU tipi sistemin bir diğer önemli özelliği de yineleyiciler, bir koleksiyondaki nesneleri arka arkaya seri olarak döndüren.[7] Yineleyiciler, aynı uygulama programlama Arayüzü (API) hangi verilerle kullanılırsa kullanılsın. Böylece bir koleksiyon için yineleyici karmaşık sayıs bir dizi için bunun yerine kullanılabilir tamsayıs. CLU yineleyicilerin ayırt edici bir özelliği, her değerin arayan kişiye bir Yol ver Beyan. CLU'dakiler gibi yineleyiciler artık C #, Ruby ve Python gibi birçok modern dilin ortak bir özelliğidir, ancak son zamanlarda bunlara genellikle üreticiler olarak atıfta bulunulmaktadır.

CLU ayrıca şunları içerir: istisna işleme, diğer dillerdeki çeşitli girişimlere dayanarak; istisnalar kullanılarak ortaya çıkar sinyal ve ele alındı dışında. İstisna işlemeye sahip diğer birçok dilden farklı olarak, istisnalar çağıran zincirde dolaylı olarak yeniden işaretlenmez. Ayrıca, istisna işleme sağlayan diğer birçok dilden farklı olarak, CLU'daki istisnalar sıradan yürütme akışının bir parçası olarak kabul edilir ve döngüleri kırmak veya işlevlerden geri dönmek için "normal" ve verimli bir tür güvenli yolu olarak kabul edilir; bu, diğer koşulların geçerli olduğu durumlar dışında, dönüş değerlerinin doğrudan atanmasına izin verir. Yakalanmayan veya açıkça yeniden işaretlenmeyen istisnalar, hemen, programı tipik olarak sonlandıran özel bir hata istisnasına dönüştürülür.

CLU genellikle tür güvenliğine sahip ilk dil olarak kabul edilir varyant türleri, aranan Oneofs, dilden önce ML onlara sahipti.

CLU'daki son ayırt edici özellik, paralel atama (çoklu atama), burada birden fazla değişkenin bir sayfanın sol tarafında görünebileceği Görev Şebeke. Örneğin, yazmak x, y: = y, x değerleri değiş tokuş ederdi x ve y. Aynı şekilde, işlevler gibi birkaç değer döndürebilir x, y, z: = f (t). Paralel atama (birden fazla dönüş değeri olmasa da), CLU'dan önce gelir. CPL (1963), adlı eşzamanlı atama,[8] ancak CLU onu popüler hale getirdi ve genellikle sonraki dillerde paralel atamaya yol açan doğrudan etki olarak kabul edildi.

Bir CLU programındaki tüm nesneler yığın içinde yaşar ve bellek yönetimi otomatiktir.

CLU destekler tür parametreleştirilmiş kullanıcı tanımlı veri soyutlamaları. Yapıyı kullanarak tür güvenli sınırlı parametreli türler sunan ilk dildi nerede hükümler gerçek tür argümanları üzerindeki kısıtlamaları ifade etmek için.

Etkilemek

CLU ve Ada büyük ilham kaynağıydı C ++ şablonlar.[kaynak belirtilmeli ]

CLU'nun istisna işleme mekanizmaları, C ++ ve Java.[kaynak belirtilmeli ]

Sather, Python, ve C # Dahil etmek yineleyiciler, ilk olarak CLU'da ortaya çıktı.[kaynak belirtilmeli ]

Perl ve Lua CLU'dan birden çok atama ve işlev çağrılarından birden çok dönüş aldı.[9]

Python ve Yakut ödünç paylaşarak aramak, Yol ver Beyan,[10] ve çoklu atama.[11]

Referanslar

  1. ^ a b Curtis, Dorothy (2009-11-06). "CLU ana sayfası". Programlama Metodolojisi Grubu, Bilgisayar Bilimleri ve Yapay Zeka Laboratuvarı. Massachusetts Teknoloji Enstitüsü. Alındı 2016-05-26.
  2. ^ a b Curtis, Dorothy (2009-11-06). "/ Pub / pclu dizini". Programlama Metodolojisi Grubu, Bilgisayar Bilimleri ve Yapay Zeka Laboratuvarı. Massachusetts Teknoloji Enstitüsü. Alındı 2016-05-26.
  3. ^ Ushijima, Tetsu. "clu2c". clu2c. woodsheep.jp. Alındı 2016-05-26.
  4. ^ Lundh, Fredrik. "Nesneye Göre Çağrı". effbot.org. Alındı 21 Kasım 2017. "CLU" yu "Python" ile, "kayıt" ı "örnek" ile ve "yordamı" "işlev veya yöntem" ile değiştirin ve Python'un nesne modelinin oldukça doğru bir tanımını elde edersiniz.
  5. ^ Lattner, Chris (2014-06-03). "Chris Lattner'ın Ana Sayfası". Chris Lattner. Alındı 2014-06-03. Swift dili, bir dil uzmanları, dokümantasyon uzmanları, derleyici optimizasyon ninjaları ve fikirlerin iyileştirilmesine ve test edilmesine yardımcı olmak için geri bildirim sağlayan inanılmaz derecede önemli bir dahili test sürümü grubunun yorulmak bilmeyen çabalarının ürünüdür. Tabii ki, aynı zamanda bu alandaki diğer birçok dil tarafından zor kazanılan deneyimlerden, Objective-C, Rust, Haskell, Ruby, Python, C #, CLU ve listelenemeyecek kadar çok diğerlerinden fikirlerin alınmasından büyük ölçüde yararlandı.
  6. ^ Liskov, Barbara; Zilles, Stephen (1974). "Soyut veri türleri ile programlama". ACM SIGPLAN sempozyumunun Çok yüksek seviyeli diller üzerine bildirileri. sayfa 50–59. CiteSeerX  10.1.1.136.3043. doi:10.1145/800233.807045.CS1 bakimi: ref = harv (bağlantı)
  7. ^ a b c Liskov, B.; Snyder, A .; Atkinson, R .; Schaffert, C. (Ağustos 1977). "CLU'da soyutlama mekanizmaları". ACM'nin iletişimi. 20 (8): 564–576. CiteSeerX  10.1.1.112.656. doi:10.1145/359763.359789.
  8. ^ Barron, D. W .; Buxton, J. N .; Hartley, D. F .; Nixon, E .; Strachey, C. (1963). "CPL'nin temel özellikleri". Bilgisayar Dergisi. 6 (2): 134–143. doi:10.1093 / comjnl / 6.2.134.
  9. ^ Ierusalimschy, R .; De Figueiredo, L. H .; Celes, W. (2007). "Lua'nın evrimi". Üçüncü ACM SIGPLAN Programlama Dilleri Tarihi Konferansı Bildirileri - HOPL III (PDF). s. 2-1–2-26. doi:10.1145/1238844.1238846. ISBN  978-1-59593-766-7.
  10. ^ "Ruby'nin Kökleri ve Matz'ın Liderliği". Appfolio Mühendisliği. 2019-11-08. Alındı 2019-11-15. Matz blokların Ruby'nin en büyük icadı olduğunu düşünüyor (Katılıyorum.) Fikri 1970'lerin dilinden CLU adlı MIT'den aldı ve onlara 'yineleyiciler' adını verdi ...
  11. ^ "Fonksiyonel Programlama NASIL - Python 3.8.3 belgeleri". docs.python.org. Alındı 2020-05-25.

Dış bağlantılar