Kırılgan ikili arabirim sorunu - Fragile binary interface problem

kırılgan ikili arabirim sorunu veya FBI kesin bir eksiklik nesne yönelimli programlama dil derleyiciler, temeldeki bir sınıf kitaplığındaki dahili değişiklikler, alt kitaplıkların veya programların çalışmayı durdurmasına neden olabilir. Bu bir örnek yazılım kırılganlığı.

Bu soruna daha çok kırılgan temel sınıf sorun veya FBC; ancak bu terimin daha geniş bir anlamı vardır.

Sebep olmak

Sorun, birçok yaygın nesne yönelimli (OO) dil için derleyicilerde kullanılan bir "kısayol" nedeniyle oluşur; bu, OO dilleri daha önceki OO olmayan dillerden gelişirken tutulan bir tasarım özelliği yapısal programlama gibi diller C ve Pascal.

Bu dillerde modern anlamda hiçbir nesne yoktu, ancak benzer bir yapı vardı. kayıt (veya C'deki "yapı"), çeşitli ilgili bilgileri tek bir bellekte tutan. Belirli bir kayıttaki bölümlere, kaydın başlangıç ​​konumu takip edilerek ve ofset bu başlangıç ​​noktasından söz konusu kısma. Örneğin, bir "kişi" kaydının, programcının yazdığı baş harflere erişmek için bir adı, soyadı ve ikinci adının baş harfi olabilir. thisPerson.middleInitial hangi derleyici gibi bir şeye dönüşür a = konum (thisPerson) + uzaklık (middleInitial). Modern CPU'lar tipik olarak bu yaygın erişim türü için talimatlar içerir.

Nesne yönelimli dil derleyicileri ilk geliştirilirken, mevcut derleyici teknolojisinin çoğu kullanıldı ve nesneler kayıt konseptinin üzerine inşa edildi. Bu dillerde nesnelere başlangıç ​​noktaları ile atıfta bulunulur ve "alanlar" olarak bilinen halka açık verilerine, bilinen ofset yoluyla erişilirdi. Aslında, tek değişiklik kayda, değişmez bir alanı işaret edecek şekilde ayarlanmış başka bir alan eklemekti. sanal yöntem tablosu her sınıf için, kayıt hem verilerini hem de yöntemlerini (işlevlerini) açıklar. Derlendiğinde, uzaklıklar hem verilere hem de koda erişmek için kullanılır (sanal yöntem tablosu aracılığıyla).

Semptomlar

Bu daha büyük bir soruna yol açar programları inşa edildikleri zaman kütüphaneler. Kitaplığın yazarı, nesne içindeki ortak alanların boyutunu veya düzenini değiştirirse, uzaklıklar artık geçersizdir ve program artık çalışmayacaktır. FBI sorunu bu.

Uygulamadaki değişikliklerin sorun yaratması beklense de, FBI hakkındaki sinsi şey, hiçbir şeyin olmamasıdır. Gerçekten mi değiştirildi, yalnızca derlenmiş bir kitaplıkta gizli olan nesnenin düzeni. Biri değişirse, bir şey yap -e başka bir şey yap bir soruna neden olabilir, ancak bu durumda kişi değişmeden sorunlara neden olabilir bir şey yap, açıklık sağlamak için kaynak kod satırlarının taşınması kadar kolay bir şekilde oluşturulabilir. Daha kötüsü, programcının derleyici tarafından oluşturulan ortaya çıkan düzen üzerinde çok az kontrolü vardır veya hiç kontrolü yoktur, bu da sorunu neredeyse tamamen görünmez hale getirir.

Karmaşık nesne yönelimli programları veya kütüphaneler en üst düzey sınıflar onlarca sınıftan miras alıyor olabilir. Bu temel sınıfların her biri, yüzlerce başka sınıf tarafından da miras alınabilir. Bu temel sınıflar kırılgandır çünkü bunlardan birinde yapılacak küçük bir değişiklik, doğrudan ya da bunu yapan başka bir sınıftan miras alan herhangi bir sınıf için sorunlara neden olabilir. Bu, kitaplığın bir kart evi bir temel sınıfa yapılan bir değişiklikle birçok sınıf zarar görür. Miras ağacı karmaşıksa, değişiklikler yazılırken sorun fark edilmeyebilir. Aslında, temel sınıfı değiştiren geliştirici, genellikle başkaları tarafından geliştirilen sınıfların onu kullandığından habersizdir.

Çözümler

Diller

Kırılgan ikili arabirim sorununa bir çözüm, sorunun var olduğunu bilen ve ilk etapta olmasına izin vermeyen bir dil yazmaktır. Daha önceki dillerden geliştirilenlerin aksine, özel olarak yazılmış OO dillerinin çoğu, yükleme sırasında tüm ofset tablolarını oluşturur. Kütüphane düzeninde yapılan değişiklikler bu noktada "fark edilecektir". Gibi diğer OO dilleri Kendisi, kitaplıklarda bulunan nesneleri kopyalayıp değiştirerek çalışma zamanında her şeyi inşa edin ve bu nedenle kırılgan olabilecek bir temel sınıfa sahip olmayın. Gibi bazı diller Java, FBI sorunlarına yol açmadan hangi değişiklikleri yapmanın güvenli olduğuna dair kapsamlı belgelere sahip olun.

Diğer bir çözüm, derleme aşamasındaki ofsetleri ve diğer bilgileri listeleyen, meta-veri olarak bilinen bir ara dosya yazmaktır. Bağlayıcı daha sonra bu bilgiyi kitaplık bir uygulamaya yüklendiğinde kendini düzeltmek için kullanır. Gibi platformlar .AĞ Bunu yap.

Bununla birlikte, piyasada aşağıdaki gibi programlama dilleri seçilmiştir C ++ bunlar gerçekten "konuma bağlı" ve bu nedenle FBI sergiliyor. Bu durumlarda, soruna hala birkaç çözüm vardır. Gelecekte ek işlevler eklemeye ihtiyaç duymaları durumunda bir dizi "yer tutucu" nesne eklemelerini sağlayarak kütüphane yazarına yük biner (bu, kullanılan yapılarda görülebilir. DirectX kütüphane). Bu çözüm, bu mankenler tükenene kadar iyi çalışır - ve hafızayı kapladığı için çok fazla şey eklemek istemezsiniz.

Amaç-C 2.0 sağlar kırılgan olmayan örnek değişkenleri örneğin değişken erişimi için ekstra bir yönlendirme seviyesine sahip olarak.

Diğer bir kısmi çözüm, Köprü deseni, bazen "Pezevenk "(" Uygulama için işaretçi "). Qt çerçevesi böyle bir uygulamaya bir örnektir. Her sınıf, uygulama verilerini tutan yapıya bir gösterici olan yalnızca bir veri üyesini tanımlar. İşaretçinin kendisinin boyutunun değişmesi olası değildir (belirli bir platform için), bu nedenle uygulama verilerinin değiştirilmesi genel yapının boyutunu etkilemez. Ancak bu, sanal yöntemleri sıfıra sahip olmayan bir sınıfa tanıtmak veya kalıtım grafiğini değiştirmek gibi diğer önemli değişiklikleri engellemez.

Bağlayıcılar

Başka bir çözüm, daha akıllı bir bağlayıcı gerektirir. Orijinal versiyonunda Amaç-C, kitaplık biçimi bir kitaplığın birden çok sürümüne izin veriyordu ve çağrıldığında uygun kitaplığı seçmek için bazı işlevler içeriyordu. Ancak bu her zaman gerekli değildi çünkü ofsetler yalnızca alanlar için gerekliydi, çünkü yöntem ofsetleri çalışma zamanında toplandı ve FBI'a neden olamazdı. Metotlar alanlardan daha sık değişme eğiliminde olduğundan, ObjC ilk etapta birkaç FBI problemine sahipti ve yaptıkları versiyonlama sistemi ile düzeltilebilirdi. Objective-C 2.0, FBI problemini alanlar için de çözen "modern bir çalışma zamanı" ekledi. Ek olarak, TOM dil her şey için çalışma zamanında toplanan ofsetleri kullanır ve FBI'ı imkansız hale getirir.

Mümkün olduğunda dinamik kitaplıklar yerine statik kullanmak başka bir çözümdür, çünkü kitaplık daha sonra uygulamayı yeniden derlemeden ve kullandığı ofsetleri güncellemeden değiştirilemez. Bununla birlikte, statik kitaplıkların daha büyük bir ikili dosya ve kullanıma sunulduğunda kitaplığın daha yeni sürümlerini "otomatik olarak" kullanamama gibi ciddi sorunları vardır.

Mimari

Bu dillerde, sorun zorla azaltıldı tek miras (bu, miras ağacının karmaşıklığını azalttığı için) ve arayüzler ile temel sınıflar yerine sanal işlevler arabirimlerin kendileri kod içermediğinden, yalnızca arabirimin bildirdiği her yöntem imzasının arabirimi uygulayan her nesne tarafından destekleneceğine dair bir garanti.

Dağıtım yöntemi

Kütüphanelerin kaynak kodu mevcutsa tüm problem çöker. O zaman basit bir yeniden derleme işinizi görecektir.

Ayrıca bakınız

Dış bağlantılar