Nesne bileşimi - Object composition

İçinde bilgisayar Bilimi, nesne bileşimi birleştirmenin bir yolu nesneler veya veri tipleri daha karmaşık olanlara. Yaygın kompozisyon türleri nesneler kullanılan nesne yönelimli programlama, etiketli sendikalar, setleri, diziler ve çeşitli grafik yapılar.[1] Nesne bileşimleri veri yapılarıyla ilgilidir, ancak aynı değildir.

Nesne bileşimi, uygulamanın veya fiziksel içeriğin değil, bilginin mantıksal veya kavramsal yapısını ifade eder. veri yapısı onu temsil etmek için kullanılır[kaynak belirtilmeli ]. Örneğin, bir sıra bir Ayarlamak çünkü (diğer şeylerin yanı sıra), oluşturulan öğelerin sırası birincisi için önemlidir, ancak ikincisi için önemli değildir. Gibi veri yapıları diziler, bağlantılı listeler, karma tablolar ve diğer birçokları ikisini de uygulamak için kullanılabilir. Belki kafa karıştırıcı bir şekilde, aynı terimlerden bazıları hem veri yapıları hem de bileşikler için kullanılmaktadır. Örneğin, "ikili ağaç "şunlardan birine atıfta bulunabilir: bir veri yapısı olarak, bu, öğelerin doğrusal bir sırasına erişmenin bir yoludur ve ağaçtaki öğelerin gerçek konumları önemsizdir (ağaç, anlamını değiştirmeden, kişi istediği gibi dahili olarak yeniden düzenlenebilir). Bununla birlikte, bir nesne bileşimi olarak, pozisyonlar önemlidir ve bunları değiştirmek, anlamı değiştirir (örneğin, kladogramlar )[kaynak belirtilmeli ].

Programlama tekniği

Nesne yönelimli programlama dayanır nesneler -e kapsüllemek veriler ve davranış. İşlevselliği daha karmaşık olanlara dönüştürmek ve oluşturmak için iki ana teknik kullanır: alt tipleme ve nesne oluşturma.[2] Nesne kompozisyonu, nesnelerin bileşik nesneler içinde birleştirilmesi ve aynı zamanda her nesnenin iyi tanımlanmış nesneler kullanılarak kapsüllenmesini sağlamakla ilgilidir. arayüz iç organlarının görünürlüğü olmadan. Bu bağlamda, nesne bileşimi, kapsüllemeyi zorlamayan veri yapılarından farklıdır.

Nesne bileşimi, aynı zamanda, bir dizi veya bir dizi nesne gibi birden çok ilişkili nesnenin bir grubu hakkında olabilir. Yetki çevreleyen bileşik nesneye yapılan talepleri veya çağrıları dahili bileşenlerinden birine ileterek kompozisyonu zenginleştirebilir.[3]

İçinde sınıf tabanlı ve daktilo programlama dilleri, türler bileşik ve bileşik olmayan türlere ayrılabilir ve kompozisyon, türler arasındaki bir ilişki olarak kabul edilebilir: birleşik türden bir nesne (ör. araba) "vardır "diğer türdeki nesneler (ör. tekerlek). Bileşik bir nesne aynı türden birkaç alt nesne içerdiğinde, bunlar belirli bir nesneye atanabilir. roller, genellikle isimler veya numaralarla ayırt edilir. Örneğin, bir Nokta nesne, her biri farklı bir eksen boyunca mesafeyi temsil eden 'x', 'y' ve 'z' gibi 3 sayı içerebilir. Genel olarak kısmi-bütün ilişkilerinin incelenmesi, mereoloji.

Kompozisyon şundan ayırt edilmelidir: alt tipleme, daha spesifik bir veri türü oluşturmak için genel bir veri türüne ayrıntı ekleme işlemidir. Örneğin, arabalar belirli bir araç türü olabilir: araba bir araç. Alt tipleme, farklı nesneler arasındaki bir ilişkiyi tanımlamaz, bunun yerine, bir türdeki nesnelerin aynı anda başka bir türden nesneler olduğunu söyler. Bu tür ilişkilerin incelenmesi ontoloji.

İçinde prototip gibi tabanlı programlama dilleri JavaScript nesneler, örnekleme anında bir prototip nesnesinden davranışları dinamik olarak devralabilir. Kompozisyon, prototip oluşturmadan ayırt edilmelidir: yeni örneklenen nesne, prototipinin kompozisyonunu miras alır, ancak kendisi kendi başına oluşturulabilir.

Kompozit nesneler, oluşturulan nesnelerin birlikte konumlandırılmasıyla, referansların birlikte konumlandırılmasıyla veya başka birçok yolla depoda temsil edilebilir. Bileşik bir nesne içindeki öğeler şu şekilde adlandırılabilir: Öznitellikler, alanlar, üyeler, özellikleriveya diğer isimler ve ortaya çıkan bileşim bileşik tip, depolama kaydı, yapı, demet veya a kullanıcı tanımlı tip (UDT). Ayrıntılar için bkz. toplama aşağıdaki bölüm.

UML modelleme tekniği

UML'de temsil edilen ve üç özelliğe sahip bir bycicle sınıfı: eyer, tekerlekler ve parçalar, son ikisinin birden fazla nesneyi gösteren çokluğu vardır.
Nesneleri oluşturmak için UML özelliklerini kullanan nesne kompozisyonu

İçinde UML modelleme, nesneler bir programlama dili ile uygulamadan bağımsız olarak kavramsal olarak oluşturulabilir. UML'de nesne oluşturmanın dört yolu vardır: özellik, ilişkilendirme, toplama ve kompozisyon:[4]

  • Bir özellik, sınıfın bir niteliğini temsil eder.
  • Bir ilişki bir anlamsal ilişki ilişkili sınıfların örnekleri arasında. Bir ilişkinin üye ucu, ilişkili sınıfın bir özelliğine karşılık gelir.
  • Bir toplama, bir toplam (bütün) ile bir grup ilişkili bileşen (parçalar) arasındaki bir parça / bütün ilişkisini modelleyen bir tür ilişkilendirmedir.
  • Bileşik birleştirme olarak da adlandırılan bir bileşim, bir bileşik (bütün) ile özel olarak sahip olunan bir grup arasındaki bir parça / bütün ilişkisini modelleyen bir tür kümelemedir.

Agrega ile bileşenleri arasındaki ilişki zayıf bir "has-a" ilişkisidir: Bileşenler birkaç kümenin parçası olabilir, diğer nesneler aracılığıyla kümeden geçmeden erişilebilir ve toplam nesneden daha uzun ömürlü olabilir.[4] Bileşen nesnenin durumu, hala toplu nesnenin bir parçasını oluşturur.[kaynak belirtilmeli ]

Bileşik ve parçaları arasındaki ilişki güçlü bir "a-değerine sahiptir" ilişkisidir: Bileşik nesnenin tekoluşan nesnelerin varlığı ve depolanması sorumluluğu", oluşturulan nesne en fazla bir kompozitin parçası olabilir ve"Bileşik bir nesne silinirse, nesneler olan tüm parça örnekleri onunla birlikte silinir.". Dolayısıyla, UML'de kompozisyon, olağan nesne kompozisyonundan daha dar bir anlama sahiptir.

Her birinin bir sahibi olan birkaç bisiklet arasındaki ilişki; Bisikleti oluşturan çerçeve parçalarına sahip bisiklet bileşimi; ve bisiklet olmadan var olan tekerlekleri ile bir bisikletin toplanması
İlişkilendirme, kompozisyon ve toplama için UML gösterimi

Grafik gösterim şunları temsil eder:

  • özelliği, çevreleyen sınıfın kutusuna yazılan bir öğe olarak,
  • ilişkili sınıflar arasında düz bir çizgi olarak ilişkilendirme,
  • toplama agreganın yanında dolgusuz bir elmas ve düz bir çizgi olarak,
  • Kompozit tarafında dolgulu bir elmas ve düz bir çizgi olarak kompozisyon.


Özel formlar

Muhafaza

Birleşik veri tipinin birkaç örneğini depolamak için kullanılan kompozisyon, muhafaza olarak adlandırılır. Bu tür kapların örnekleri şunlardır: diziler, ilişkilendirilebilir diziler, ikili ağaçlar, ve bağlantılı listeler.

İçinde UML, kapsama, çok sayıda 0 .. * veya 1 .. * ile gösterilir; bu, bileşik nesnenin, oluşturulan sınıfın bilinmeyen sayıda örneğinden oluştuğunu gösterir.

Özyinelemeli kompozisyon

Nesneler özyinelemeli olarak oluşturulabilir ve daha sonra türleri çağrılır özyinelemeli tip. Örnekler, çeşitli türlerde ağaçlar, DAG'ler, ve grafikler. Bir ağaçtaki her düğüm bir dal veya yaprak olabilir; başka bir deyişle, her düğüm başka bir ağaca ait olduğunda aynı zamanda bir ağaçtır.

UML'de, özyinelemeli kompozisyon, bir sınıfın kendisiyle bir ilişkisi, toplanması veya bileşimi ile tasvir edilir.

Bileşik desen

kompozit tasarım deseni karmaşık parça-bütün hiyerarşileri uygulamak için özyinelemeli kompozisyon ve muhafazayı birleştiren kompozit türlere dayalı nesne yönelimli bir tasarımdır.

C'deki kompozit türleri

Bu bir kompozisyon örneğidir. C.

yapı Kişi{  int yaş;  kömür isim[20];  Sıralama {iş arama, profesyonel, profesyonel olmayan, emekli, Öğrenci} ;};

Bu örnekte, ilkel (bileşik olmayan) türler int, enum {job_seeking, professional, non_professional, emekli, öğrenci} ve bileşik dizi türü karakter [] kompozit yapıyı oluşturmak için birleştirilir Kişi. Her biri Kişi yapı daha sonra bir yaş, isim ve istihdam türü "vardır".

Çeşitli dillerde kompozisyonun zaman çizelgesi

C bir kaydı çağırır yapı veya yapı; nesne odaklı gibi diller Java, Smalltalk, ve C ++ genellikle kayıtlarını içeride gizli tutar nesneler (sınıf örnekler); diller ML aile onlara sadece kayıt diyor. COBOL ilk yaygındı Programlama dili kayıtları doğrudan desteklemek;[5] ALGOL 68 COBOL'dan aldım ve Pascal ALGOL 68'den aşağı yukarı dolaylı olarak aldım. Ortak Lisp yapıları ve sınıfları sağlar (ikincisi Ortak Lisp Nesne Sistemi ).[kaynak belirtilmeli ]

1959 - COBOL
01  müşteri kaydı.  03  müşteri numarası     resim 9 (8) comp.  03  müşteri adı.    05  Lakaplar       resim x (15).    05  ilk-2         resim x.    05  soyadı           resim x (15).  03  müşteri adresi.    05  sokak.      07  sokak adı     resim x (15).        09  ev numarası  resim 999 comp.    05  Kent              resim x (10).    05  ülke kodu      resim x (3).    05  posta kodu          resim x (8).  03  borçlu        resim 9 (8) comp.
1960 - ALGOL 60

Diziler, içindeki tek bileşik veri türü idi. Algol 60.

1964 - PL / I
dcl 1 newtypet tabanlı (P); 2 (a, b, c) sabit bölme (31), 2 (i, j, k) float, 2 r ptr; yenitipi tahsis et;
1968 - ALGOL 68
int max = 99; mod newtypet = [0..9] [0..max] struct (long real a, b, c, short int i, j, k, ref real r); newtypet newarrayt = (1, 2 , 3, 4, 5, 6, gerçek yığın: = 7)

Örneğin, bağlantılı bir liste şu şekilde ilan edilebilir:

mod düğümü = birleşim (gerçek, int, compl, string), list = struct (düğüm val, sonraki ref listesi);

ALGOL 68 için sadece tip adı eşitliğin solunda görünür ve en önemlisi yapı, önceliklere bakılmaksızın soldan sağa yapılır ve okunabilir.

1970 - Pascal
tip a = dizi [1..10] nın-nin tamsayı; b = kayıt  a, b, c: gerçek;  ben, j, k: tamsayı; son;
1972 – K&R C
#define max 99yapı newtypet {  çift a, b, c;  yüzer r;  kısa ben, j, k;} Newarrayt[10] [max + 1];
1977 - FORTRAN 77

Fortran 77 dizilere sahiptir, ancak herhangi bir resmi kayıt / yapı tanımından yoksundur. Tipik olarak bileşik yapılar kullanılarak oluşturulmuştur EŞDEĞERLİK veya YAYGIN ifadeler:

       KARAKTER İSİM*32, ADDR*32, TELEFON*16       GERÇEK SAHİP       YAYGIN /ÖZEL/İSİM, ADDR, TELEFON, SAHİP
1983 - Ada
tip Cust dır-dir kayıt  İsim  : Name_Type;  Adr  : Addr_Type;  Telefon : Telefon türü;  Borç : Tamsayı Aralık 1..999999; son kayıt;

Ada 95, etiketli türler (bir C ++ sınıfına eşdeğer) aracılığıyla OOP kavramlarını getirdi, Ada 2012 için destek ekledi. ikame sınıf çapında sözleşmeler yoluyla doğrulama.

1983 - C ++
sabit int max = 99;sınıf {  halka açık:  çift a, b, c;  yüzer &r;  kısa ben, j, k;}newtypet[10] [max + 1];
1991 - Python
max = 99sınıf NewTypeT:    def __içinde__(kendini):        kendini.a = kendini.b = kendini.c = 0        kendini.ben = kendini.j = kendini.k = 0.0# Bu sınıfın örnek bir dizisini başlatın.Newarrayt = [[NewTypeT() için ben içinde Aralık(max + 1)] için j içinde Aralık(10)]
1992 - FORTRAN 90

Diziler ve dizeler FORTRAN 77'den miras alındı ​​ve yeni bir ayrılmış sözcük tanıtıldı: tip

tip newtypet çift ​​hassasiyet a, b, c tamsayı*2 ben, j, k* Hayır işaretçi türü REF GERÇEK R bitiş türütip (newtypet) t(10, 100)

FORTRAN 90 güncellendi ve dahil edildi FORTRAN IV NAMELIST adlı kavramı.

TAM :: ocak = 1, Şubat = 2, mar = 3, nisan = 4İSİM LİSTESİ / hafta / ocak, Şubat, mar, nisan
1994 - ANSI Ortak Lisp

Common Lisp yapılar ve ANSI Common Lisp standardı eklenmiş CLOS sınıfları sağlar.

(defclass bazı sınıf ()  ((f : tür yüzer)   (ben : tür tamsayı)   (a : tür (dizi tamsayı (10)))))

C / C ++ 'da kompozisyon hakkında daha fazla ayrıntı için bkz. Bileşik tip.

Toplama

Toplama, sahiplik anlamına gelmemesi açısından normal bileşimden farklıdır. Kompozisyonda, sahip olan nesne yok edildiğinde, içerilen nesneler de yok olur. Toplulaştırmada bu mutlaka doğru değildir. Örneğin, bir Üniversite çeşitli departmanlara sahiptir (ör. kimya ) ve her bölümün bir dizi profesörü vardır. Üniversite kapanırsa, bölümler artık mevcut olmayacak, ancak bu bölümlerdeki profesörler var olmaya devam edecek. Bu nedenle, bir Üniversite, bölümlerin bir bileşimi olarak görülebilir, oysa bölümler bir profesör topluluğuna sahiptir. Ayrıca bir Profesör birden fazla bölümde çalışabilir ancak bir bölüm birden fazla üniversitenin parçası olamaz.

Kompozisyon genellikle bir nesne başka bir nesne içerecek şekilde uygulanır. Örneğin, C ++:

sınıf Profesör;  // Başka yerde tanımlandısınıf Bölüm { halka açık:  Bölüm(sabit std::dizi& Başlık): Başlık_(Başlık) {} özel:  // Toplama: | Profesörler | | Departmanı | geçebilir.  std::vektör<std::zayıf_tr<Profesör>> üyeler_;  sabit std::dizi Başlık_;};sınıf Üniversite { halka açık:  Üniversite() = varsayılan; özel:  // Kompozisyon: | Bölüm | ler sadece fakülte var olduğu sürece vardır.  std::vektör<Bölüm> Fakülte_ = {      Bölüm("kimya"),      Bölüm("fizik"),      Bölüm("sanat"),  };};

Toplamada nesne, nesneye yalnızca bir referans veya işaretçi içerebilir (ve ömür bunun için sorumluluk).

Bazen, sıradan bileşim ile kümelenme arasındaki ayrımın önemsiz olduğu durumlarda kümelenmeye bileşim denir.

Yukarıdaki kod, aşağıdaki UML Sınıf diyagramına dönüşecektir:

Aggregation-Composition3.png

COM'da toplama

COM'da toplama

Microsoft'un Bileşen Nesne Modeli, toplama, bir nesnenin sanki sahipleriymiş gibi bir veya birkaç arayüzler sahip olduğu başka bir nesnenin. Resmi olarak, bu daha çok benzer kompozisyon veya kapsülleme toplamadan daha fazla. Bununla birlikte, sahip olunan nesnenin arabirimlerini çağırarak dışa aktarılan arabirimleri uygulamak yerine, sahip olunan nesnenin arabirimleri dışa aktarılır. Sahip olunan nesne, bu arayüzlerin yöntemlerinin şu kaynaklardan miras alındığından emin olmaktan sorumludur. IBilinmeyen aslında sahibin karşılık gelen yöntemlerini çağırır. Bu, sahip olunan nesnenin diğer (özel) arayüzlerine erişilemezken, sahibin referans sayısının doğru olduğunu ve sahibin tüm arayüzlerine dışa aktarılan arayüz aracılığıyla erişilebileceğini garanti etmek içindir.[6]

Ayrıca bakınız

Referanslar

  1. ^ Michelle Yaiser. "Nesneye yönelik programlama kavramları: Kompozisyon ve toplama". Adobe. Alındı 11 Mart, 2015. Kompozisyon, nesneler arasındaki ilişkileri ifade etmekle ilgilidir. Sandalye örneğini düşünün. Bir sandalyede bir Koltuk vardır. Sandalyenin sırtı vardır. Ve bir sandalyenin bir dizi ayağı vardır. "A sahiptir" ifadesi, sandalyenin sahip olduğu veya en azından başka bir nesneyi kullandığı bir ilişkiyi ifade eder. Kompozisyonun temeli olan bu "var" ilişkisidir.
  2. ^ Tasarım desenleri: yeniden kullanılabilir nesne yönelimli yazılımın öğeleri. Gamma, Erich., Helm, Richard (Bilgisayar bilimcisi), Johnson, Ralph E., 1955-, Vlissides, John. Okuma, Kütle .: Addison-Wesley. 1995. ISBN  0-201-63361-2. OCLC  31171684.CS1 Maint: diğerleri (bağlantı)
  3. ^ Ostermann, Klaus; Mezini, Mira (1 Ekim 2001). "Karışık olmayan nesne yönelimli kompozisyon". ACM SIGPLAN Bildirimleri. 36 (11): 283–299. doi:10.1145/504311.504303. ISSN  0362-1340.
  4. ^ a b OMG (2017). "Birleşik Modelleme Dili Spesifikasyonu Sürümü 2.5.1". www.omg.org. s. 109-110,197-201. Alındı 4 Ekim 2020.
  5. ^ Sebesta, Robert W. Programlama Dilleri Kavramları (Üçüncü baskı). Addison-Wesley Publishing Company, Inc. s.218. ISBN  0-8053-7133-8.
  6. ^ "Toplama". Windows XP SP2 için Platform SDK. Microsoft. Alındı 4 Kasım 2007.

Dış bağlantılar