Geç bağlama - Late binding


Geç bağlama, dinamik bağlama,[1] veya dinamik bağlantı[2]- aynı süreç olmasa da dinamik olarak bağlanma içe aktarılan kod kitaplıkları — bir nesneye çağrılan yöntemin veya argümanlarla çağrılan işlevin, adıyla arandığı bir bilgisayar programlama mekanizmasıdır. Çalışma süresi. Başka bir deyişle, bir ad, derleme sırasında değil, çalışma zamanında belirli bir işlem veya nesne ile ilişkilendirilir.

İle erken bağlama veya statik bağlama içinde nesne yönelimli dil, derleme aşaması hepsini düzeltir türleri değişkenler ve ifadeler. Bu genellikle derlenmiş programda bir ofset olarak saklanır. sanal yöntem tablosu ("v-tablo").[3] Bunun aksine, geç bağlama ile derleyici, yöntemin var olduğunu doğrulamak için yeterli bilgiyi okumaz veya v-tablosundaki yuvasını bağlar. Bunun yerine, yöntem çalışma zamanında ada göre aranır.

Geç bağlama kullanmanın birincil avantajı Bileşen Nesne Modeli (COM) programlaması, derleyicinin aşağıdaki nesneyi içeren kitaplıklara başvurmasını gerektirmemesidir. Derleme zamanı. Bu, derleme sürecini, sınıfın v tablosunun yanlışlıkla değiştirilebileceği sürüm çakışmalarına karşı daha dirençli hale getirir. (Bu bir endişe değil tam zamanında derleme - .NET veya Java gibi derlenmiş platformlar, çünkü v tablosu çalışma zamanında sanal makine çalışan uygulamaya yüklenirken kitaplıklara karşı.[4])

Tarih

"Geç bağlama" terimi, en azından 1960'lara dayanır ve burada bulunabilir. ACM'nin iletişimi. Terim, genellikle performansla ilgili olumsuz çağrışımlara sahip olsa da, Lisp gibi dillerdeki arama kurallarını tanımlamak için yaygın olarak kullanılmıştır.[5]

1980'lerde Smalltalk popüler nesne yönelimli programlama (OOP) ve bununla birlikte geç bağlanma. Alan Kay bir keresinde şöyle demişti: "Benim için OOP, yalnızca mesajlaşma, yerel tutma ve durum sürecinin korunması ve gizlenmesi ve her şeyin aşırı geç bağlanması anlamına gelir. Smalltalk ve LISP'de yapılabilir. Bunun olduğu başka sistemler de olabilir. mümkün, ancak bunların farkında değilim. "[6]

1990'ların başından ortasına kadar Microsoft, COM standardını farklı OOP programlama dilleri arasında ikili bir arayüz olarak yoğun bir şekilde tanıttı. COM programlaması, her iki sözdizimi düzeyinde destekleyen birçok dil ile erken ve geç bağlamayı eşit derecede destekledi.

2000 yılında, Alex Martelli "terimini icat ettiördek yazarak "benzer bir kavrama atıfta bulunmak, ancak farklı bir vurguyla. Geç bağlama genellikle uygulama ayrıntılarına odaklanırken, duck typing türleri yok sayma ve bir nesnenin şu anda sahip olduğu yöntemlere konsantre olma becerisine odaklanır.

Geç bağlama uygulamaları

Dinamik olarak yazılmış nesne yönelimli dillerde geç bağlama

Çoğunlukla dinamik olarak yazılmış diller, bir nesnedeki yöntemlerin listesi çalışma zamanında değiştirilebilir. Bu, geç bağlanmayı gerektirir.

Lisp'te geç bağlama

İçinde Lisp. Geç bağlanan global işlev çağrıları, çalışma zamanında bir sembol işlev hücresi. Bu işlev bağlamaları değiştirilebilir.

Etkileşimli kullanım örneği Clozure Yaygın Lisp oturum, toplantı, celse:

? (defun foo ()    (bar pi))   ; hala tanımlanmamış bir işlev BAR çağrılıyorDerleyici uyarıları:; FOO'da: Tanımsız işlev BARFOO? (defun bar (x)   ; şimdi onu tanımlıyoruz    (* x 2))BAR? (foo)    ; foo çağırır ve BAR'ın son tanımını kullanır6.283185307179586D0? (defun bar (x)   ; şimdi BAR'ı yeniden tanımlıyoruz    (* x 1000))BAR? (foo)    ; FOO artık yeni işlevi çağırıyor, FOO'yu yeniden derlemeye / bağlamaya / yüklemeye gerek yok3141.592653589793D0? (bir çeşit 'bar)   ; BAR bir semboldürSEMBOL? (sembol işlevi 'bar)  ; BAR sembolünün bir işlevi vardır# BAR # x302000D1B21F>

C ++ 'da geç bağlama

C ++ 'da, geç bağlama ("dinamik bağlama" olarak da adlandırılır), normalde gerçek anahtar kelime, bir yöntemin bildiriminde kullanılır. C ++ daha sonra, çağrıldıklarında her zaman başvurulacak bu tür işlevler için bir arama tablosu olan sanal bir tablo oluşturur.[7] Genellikle, "geç bağlama" terimi "lehine kullanılır"dinamik gönderim ".

COM dillerinde geç bağlama

COM programlamasında, sonradan bağlanan bir yöntem çağrısı, IDispatch arayüz. Visual Basic 6 gibi bazı COM tabanlı diller, bu arabirimi çağırmak için sözdizimsel desteğe sahiptir.[8] Bu, değişkenin türünü Nesne olarak tanımlayarak yapılır. C ++ gibi diğerleri, bir yöntemi aramak için GetIDsOfNames'i açıkça çağırmanızı ve çağırmak için çağırmanızı gerektirir.

.NET'te geç bağlama

.NET'te geç bağlama, bir gerçek C ++ gibi bir yöntem veya bir arabirim uygulama. Derleyici, çalıştırılacak uygulamayı belirlemek için çalışma zamanında kullanılan her sanal veya arabirim yöntemi çağrısı için sanal tablolar oluşturur.

Ayrıca COM ve Java gibi, Ortak Dil Çalışma Zamanı, geç bağlama çağrıları yapabilen yansıma API'leri sağlar. Bu aramaların kullanımı dile göre değişir.

C # 4 ile, dil ayrıca "dinamik" sözde türü de ekledi. Bu, geç bağlanmanın istendiğini belirtmek için Nesne türü yerine kullanılacaktır. İhtiyaç duyulan spesifik geç bağlama mekanizması, başlangıç ​​noktası olarak Dinamik Dil Çalışma Zamanı kullanılarak çalışma zamanında belirlenir.

Visual Basic bunları, değişken Object türünde olduğunda ve derleyici yönergesi "Option Strict Off" yürürlükte olduğunda kullanır. Bu, yeni bir VB projesi için varsayılan ayardır. Sürüm 9'dan önce, yalnızca .NET ve COM nesneleri geç bağlanabiliyordu. VB 10 ile bu, DLR tabanlı nesnelere genişletildi.

Java'da geç bağlama

Java'da geç bağlama için üç tanım vardır.

Java ile ilgili ilk belgeler, sınıfların derleme sırasında nasıl birbirine bağlanmadığını tartıştı. Türler derleme zamanında statik olarak kontrol edilirken, sınıflar için farklı uygulamalar çalışma zamanından hemen önce sınıf dosyasının üzerine yazılarak değiştirilebilir. Yeni sınıf tanımı aynı sınıf ve yöntem adlarına sahip olduğu sürece, kod yine de çalışır. Bu anlamda, geç bağlanmanın geleneksel tanımına benzer.

Şu anda, Java programlamasında geç bağlama terimini eşanlamlı olarak kullanmak popülerdir. dinamik gönderim. Bu özellikle Java'nın tek gönderim sanal yöntemlerle kullanılan mekanizma.

Son olarak Java, yansıma API'lerini kullanarak geç bağlamayı kullanabilir ve iç gözlem yazın COM ve .NET programlamasında olduğu gibi. Genel olarak sadece Java'da program yapanlar bu geç bağlama demezler. Benzer şekilde "ördek yazma" tekniklerinin kullanımı Java programlamasında hoş karşılanmaz, bunun yerine soyut arayüzler kullanılır.

Java'nın şu anki sahibi olan Oracle'ın, aynı dokümantasyonda hem Java'yı hem de diğer dilleri tartışırken "ördek yazma" anlamında geç bağlama terimini kullandığı bilinmektedir.[9]

PL / SQL ve Ada'da erken ve geç bağlama

Ada ile veritabanında depolanan bir prosedür arasında erken bağlanma kullanılırken, bir zaman damgası kontrol edilerek saklı yordam kod derlendiğinden beri değişmedi. Bu, daha hızlı yürütme sağlar ve uygulamanın, saklı yordamın yanlış sürümüyle çalışmasını engeller.[10]

Geç bağlama kullanılırken zaman damgası denetimi gerçekleştirilmez ve saklı yordam, anonim bir PL / SQL bloğu aracılığıyla yürütülür. Bu daha yavaş olabilse de, bir saklı yordam değiştiğinde tüm istemci uygulamalarını yeniden derleme ihtiyacını ortadan kaldırır.

Bu ayrım PL / SQL ve Ada'ya özgü görünmektedir. Diğer veritabanı motorlarının yanı sıra PL / SQL prosedürlerini çağırabilen diğer diller yalnızca geç bağlamayı kullanır.

Eleştiri

Geç bağlama, erken bağlanan yöntem çağrısından daha düşük performansa sahiptir. Çoğu uygulamada, doğru yöntem adresi her aramada isme göre aranmalıdır, nispeten pahalı sözlük araması ve muhtemelen aşırı çözüm mantığı gerektirir, ancak modern bilgisayarlarda genellikle ihmal edilebilir.

Bazı derleyiciler için geç bağlama, statik tür denetiminin kullanılmasını engelleyebilir. Geç bağlanan bir çağrı yaparken, derleyicinin yöntemin var olduğunu varsayması gerekir. Bu, basit bir yazım hatasının bir çalışma zamanı hatasının atılmasına neden olabileceği anlamına gelir. Tam istisna dile göre değişir, ancak genellikle "Yöntem Bulunamadı" veya "Yöntem Eksik" gibi bir adla adlandırılır. Modern derleyiciler, derleme sırasında olası her çağrının bir uygulamaya sahip olmasını sağlayarak bundan kaçınır.

Geç bağlanma formlarını engelleyebilir statik analiz tarafından ihtiyaç duyulan entegre geliştirme ortamı (IDE). Örneğin, IDE'nin çağrının hangi sınıfa başvurabileceğini bilmesinin bir yolu yoksa, bir IDE'nin "tanıma git" özelliği geç bağlanan bir çağrıda çalışmayabilir. Modern bir IDE bunu özellikle nesne yönelimli diller için kolayca çözer, çünkü geç bağlanmış bir yöntem her zaman bir arabirimi veya temel sınıfı belirtir, bu "tanıma git" in önderlik ettiği ve "tüm başvuruları bul" tüm uygulamaları bulmak için kullanılabilir veya geçersiz kılmalar.

Benzer bir sorun, bilgi yazmanın olası eksikliğinin bağımlılık grafiklerinin oluşturulmasını engelleyebilmesidir. Bununla birlikte, soyut arayüzler gibi diğer programlama yöntemleri aynı sorunlara neden olabilir. Modern bir IDE, "tüm referansları bul" u işlediği kadar kolay bir şekilde bu tür bağımlılık grafikleri oluşturabilir.

Ayrıca bakınız

Referanslar

  1. ^ Booch, Grady. Nesneye Yönelik Analiz ve Tasarım. Addison-Wesley, 1994. s71
  2. ^ Schreiner, Axel-Tobias (1994). ANSI-C ile Nesne Tabanlı Programlama (PDF). Münih: Hanser. s. 15. ISBN  3-446-17426-5.
  3. ^ "Otomasyonda erken bağlama ve geç bağlama kullanma". Microsoft. 2003-09-06. Alındı 2014-06-27.
  4. ^ "Java Sanal Makinesinin Yapısı: Dinamik Bağlama". Sun Microsystems. 1999. sn. 3.6.3. Alındı 2013-09-21.
  5. ^ Yazılım mühendisliği teknikleri, J.N. Buxton, Brian Randell, NATO Bilim Komitesi, NATO Bilim Komitesi, 1970
  6. ^ "Dr. Alan Kay" Nesne Tabanlı Programlamanın Anlamı Üzerine"". Purl.org. Alındı 2013-08-16.
  7. ^ "12.5 - Sanal tablo" C Öğrenin ". Learncpp.com. 2008-02-08. Alındı 2013-08-16.
  8. ^ "Otomasyonda erken bağlama ve geç bağlama kullanma". Support.microsoft.com. Alındı 2011-01-15.
  9. ^ "COM İstemci Uygulamasından WebLogic Sunucusuna Çağrı". Download.oracle.com. Alındı 2013-08-16.
  10. ^ "Erken ve Geç Bağlama, Ada Programcı Kılavuzu için Oracle SQL * Modülü". Download.oracle.com. Alındı 2011-01-15.