İsim çözümlemesi (programlama dilleri) - Name resolution (programming languages)

İçinde Programlama dilleri, Ad çözümlemesi program ifadeleri içindeki belirteçlerin amaçlanan program bileşenlerine çözümlenmesidir.

Genel Bakış

İfade bilgisayar programlarında değişkenler, veri türleri, işlevler, sınıflar, nesneler, kitaplıklar, paketler ve diğer varlıkları isme göre referans alır. Bu bağlamda, ad çözümlemesi, benzersiz olması gerekmeyen adların amaçlanan program varlıkları ile ilişkilendirilmesini ifade eder. algoritmalar belirli bağlamlarda bu tanımlayıcıların neyi ifade ettiğini belirleyen, dil tanımının bir parçasıdır.

Bu algoritmaların karmaşıklığı, dilin karmaşıklığından etkilenir. Örneğin, ad çözümlemesi montaj dili genellikle sadece tek bir basit içerir tablo araması isim çözümleme C ++ içerdiği için son derece karmaşıktır:

  • ad alanları, bir tanımlayıcının ilişkili ad alanına bağlı olarak farklı anlamlara sahip olmasını mümkün kılan;
  • kapsamlar, bir tanımlayıcının farklı kapsam seviyelerinde farklı anlamlara sahip olmasını mümkün kılan ve çeşitli kapsam geçersiz kılma ve gizleme kuralları içeren. En temel düzeyde ad çözümlemesi genellikle bağlayıcı en küçük çevreleyen kapsamda, böylece örneğin yerel değişkenler genel değişkenlerin yerini alır; buna denir gölgeleme.
  • görünürlük kuralları, belirli ad alanlarından veya kapsamlardan tanımlayıcıların geçerli bağlamdan görünür olup olmadığını belirleyen;
  • aşırı yükleme, bir tanımlayıcının tek bir ad alanında veya kapsamda bile nasıl kullanıldığına bağlı olarak farklı anlamlara sahip olmasını mümkün kılar;
  • ulaşılabilirlik, aksi halde görünür bir kapsamdaki tanımlayıcıların gerçekten erişilebilir olup olmadığını ve ad çözümleme sürecine katılıp katılmadığını belirler.

Statik ve dinamik

İçinde Programlama dilleri ad çözümlemesi şu adresten yapılabilir: Derleme zamanı veya Çalışma süresi. İlki denir statik ad çözümlemesi, ikincisi denir dinamik ad çözümlemesi.

Biraz yaygın bir yanılgı şudur: dinamik yazım dinamik ad çözümlemesi anlamına gelir. Örneğin, Erlang dinamik olarak yazılır ancak statik ad çözümlemesine sahiptir. Ancak, statik yazım, statik ad çözümlemesi anlamına gelir.

Statik ad çözümlemesi, derleme zamanında kapsamda olmayan değişkenlerin kullanımını yakalar; programcı hatalarını önlemek. Dinamik kapsam çözünürlüğüne sahip diller, daha fazla esneklik için bu güvenliği feda eder; tipik olarak çalışma zamanında aynı kapsamdaki değişkenleri ayarlayabilir ve alabilir.

Örneğin, Python etkileşimli REPL:

>>> numara = 99>>> first_noun = "sorunlar">>> second_noun = "tazı">>> # Hangi değişkenlerin kullanılacağına çalışma zamanında karar verilir>>> Yazdır(f"Bende var {numara}{first_noun} ancak {second_noun} biri değil. ")99 problemim var ama bir tazı değil.

Bununla birlikte, kodda dinamik ad çözümlemesine güvenmek Python topluluğu tarafından önerilmemektedir.[1][2] Özellik, Python'un sonraki bir sürümünde de kaldırılabilir.[3]

Statik ad çözümlemesini kullanan dil örnekleri şunları içerir: C, C ++, E, Erlang, Haskell, Java, Pascal, Şema, ve Smalltalk. Dinamik ad çözümlemesini kullanan dil örnekleri arasında bazı Lisp lehçeler Perl, PHP, Python, REBOL, ve Tcl.

Ad maskeleme

Maskeleme örtüşen sözcük kapsamlarında farklı varlıklar için aynı tanımlayıcı kullanıldığında oluşur. Değişkenler düzeyinde (isimlerden ziyade), bu, değişken gölgeleme. Bir tanımlayıcı I '(değişken X' için), iki koşul karşılandığında bir tanımlayıcıyı (X değişkeni için) maskeler

  1. Benimle aynı isme sahibim
  2. I ', I kapsamının bir alt kümesi olan bir kapsamda tanımlanmıştır.

Dış değişken X'in gölgeli iç değişken X 'ile.

Örneğin, "foo" parametresi, bu yaygın modelde yerel "foo" değişkenini gölgeler:

özel int foo;  // "foo" adı dış kapsamda bildirildihalka açık geçersiz setFoo(int foo) {  // "foo" adı iç kapsamda bildirilir ve işlev yereldir.    bu.foo = foo;  // "foo" ilk olarak "en içteki" kapsamda bulunacağından (ve çözüleceğinden),                     // "foo" özniteliğinin saklanan değerinin başarıyla üzerine yazmak için                     // gelen "foo" parametresinin yeni değeri ile bir ayrım yapılır                     // "this.foo" (nesne niteliği) ve "foo" (işlev parametresi) arasında. }halka açık int getFoo() {    dönüş foo;}

Ad maskeleme neden olabilir fonksiyon aşırı yüklemesinde komplikasyonlar, bazı dillerde, özellikle C ++ kapsamlarında aşırı yüklemenin gerçekleşmemesi nedeniyle, tüm aşırı yüklenmiş işlevlerin yeniden bildirilmesi veya belirli bir ad alanına açıkça içe aktarılması gerekir.

Ad çözümlemesini önemsiz hale getirmek için alfa yeniden adlandırma

İle programlama dillerinde sözcük kapsamı bu değil yansıtmak değişken isimler üzerinde, α-dönüşümü (veya α-yeniden adlandırma), hiçbir değişken adının olmamasını sağlayan bir ikame bularak ad çözümlemesini kolaylaştırmak için kullanılabilir. maskeler içeren bir kapsamda başka bir isim. Alfa-yeniden adlandırma yapabilir statik kod analizi Daha kolay çünkü yalnızca alfa yeniden adlandırıcının dilin kapsam kurallarını anlaması gerekir.

Örneğin, bu kodda:

sınıf Nokta {özel:  çift x, y;halka açık:  Nokta(çift x, çift y) {  // x ve y burada özelleri maskeler    setX(x);    setY(y);  }  geçersiz setX(çift newx) { x = newx; }  geçersiz setY(çift yeni y) { y = yeni y; }}

içinde Nokta kurucu sınıf değişkenleri x ve y vardır gölgeli aynı isimdeki yerel değişkenlere göre. Bu, alfa olarak şu şekilde yeniden adlandırılabilir:

sınıf Nokta {özel:  çift x, y;halka açık:  Nokta(çift a, çift b) {    setX(a);    setY(b);  }  geçersiz setX(çift newx) { x = newx; }  geçersiz setY(çift yeni y) { y = yeni y; }}

Yeni versiyonda maskeleme yoktur, bu nedenle hangi kullanımların hangi beyanlara karşılık geldiği hemen anlaşılır.

Ayrıca bakınız

Referanslar

  1. ^ "[Python-Ideas] str.format yardımcı program işlevi". 9 Mayıs 2009. Alındı 2011-01-23.
  2. ^ "8.6. Sözlüğe dayalı dize biçimlendirme". diveintopython.org. Mark Pilgrim. Alındı 2011-01-23.
  3. ^ "9. Sınıflar - Python belgeleri". Alındı 2019-07-24. Kapsamların metinsel olarak belirlendiğini anlamak önemlidir: Bir modülde tanımlanan bir işlevin genel kapsamı, işlevin nereden veya hangi takma adla çağrıldığına bakılmaksızın, o modülün ad alanıdır. Öte yandan, gerçek ad araması çalışma zamanında dinamik olarak yapılır - ancak, dil tanımı "derleme" zamanında statik ad çözümlemesine doğru gelişmektedir, bu nedenle dinamik ad çözümlemesine güvenmeyin! (Aslında, yerel değişkenler zaten statik olarak belirlenmiştir.)