Objektuetara bideratutako programazioa

Ezaugarri eta izaera propioak dituzten eta beren artean komunika daitezkeen hainbat azpiprogramaz (objektuz) osatutako programa informatikoa egiteko ekintza
Objektuei bideratutako programazioa» orritik birbideratua)

Objektuei Bideratutako Programazioa (OBP) (ingelesez, Object-Oriented Programming edo OOP) programazio paradigma bat da, oinarri moduan objektuen kontzeptua erabiltzen duena. Objektuak klaseen instantzia moduan sortzen diren datu-mota abstraktu bat dira. Objektuetan informazioa (datuak) eta haiek atzitzeko funtzioak (kodea) kapsulatuta daude: informazioa eremuetan (atributuetan, propietateetan) eta kodea metodoetan (prozeduretan).

UML notazioan definitutako klase bat. Klase hau butoi bat irudikatzen du. Butoi klase honek eremuetan informazioa gordetzen du eta metodoetan funtzionalitatea. Herentziaren bitartez butoi mota desberdinak sortu daitezke. Objektuak klasearen instantziak dira.

OBP-ren funtsezko ezaugarri batzuk hauek dira: herentzia, kohesioa, abstrakzioa, polimorfismoa, akoplamendua eta kapsulazioa.

Gaur egun OBP onartzen duten hainbat programazio-lengoaia daude, batzuk aipatzearren: C++, Objective-C, Smalltalk, Delphi, Java, Javascript, C#, Perl, Python, Ruby eta PHP.

Sarrera aldatu

Programazio egituratu tradizionalean datuak eta prozedurak bereizita daude eta ez dute harremanik. Sarrera-datuak prozesatuz irteerako datuak lortzea da helburua. Objektuei Bideratutako Programazioan, aldiz, objektuak erabiltzen dira.

Objektuak identitate, egoera eta portaera jakin bat duten entitateak dira. Identitatea identifikatzaile moduko bat da, objektuak haien artean bereizten dituena. Objektuaren eremuetan dagoen informazioaren bidez egoera definitzen da eta metodoen bidez portaera. Mundu errealeko elementuei erreferentzia egin diezaiekete objektuek.[1]

Objektuak diseinatzean eta sortzean klase-hierarkia erabiltzen da. Klaseak eta azpiklaseak, logika matematikoko multzoen eta azpimultzoen parekoak dira. Klaseek metodoak behar dituzte eremuak atzitzeko.

Datuak eta metodoak egitura berean antolatzeko mekanismo gisa kapsulazioa erabiltzen da. Haren bidez informazioa ezkutatzea lortzen dela esaten da. Horrela, klase bat erabili behar duen programatzaileak objektua nola antolatuta dagoen (datuak, metodoen inplementazioa) jakin beharrik ez du. Datuen integritatea bermatzeko, beharrezkoa da erabiltzaileari objektuaren eremuetan dagoen informazioa zuzenean aldatzen ez uztea. Hori lortzeko, kapsulazioan hiru atzipen-maila zehazten dira: publikoa, babestua eta pribatua.

Historia aldatu

Objektuei Bideratutako Programazioaren (OBP) kontzeptuak 50eko hamarkadaren amaieran eta 60koaren hasiera agertu ziren lehen aldiz. MITko Adimen Artifizialeko sailean "objektu"aren kontzeptua erabiltzen hasi zirenean propietateak (atributuak) dituzten elementuei (LISP atomoei) egiten zieten erreferentzia.[2] Kontzeptu horien erabilera erakusten duen garai hartako beste adibide bat MITko Sketchpad konputagailu-programa da. Ivan Sutherland-ek sortu zuen 1960an doktore-tesia egiten ari zenean.[3] Sketchpad-i buruzko txosten teknikoaren glosarioan, Sutherlandek "objektua" eta "instantzia" kontzeptuak definitu zituen eta klasearen kontzeptua "master" eta "definition" terminoen bidez erabili zuen.[4] Interfaze grafikoen garapenean garrantzia handia izan zuen Sketchpad konputagailu-programak. Egindako lanagatik Turing saria jaso zuen Sutherlandek 1988an.[5] OBPko kontzeptuen lehen erabileren beste adibide bat MITko ALGOL bertsio bat da (AED-0 bertsioa). Datu-egituren ("plexes" terminoaz izendatuak bertsio hartan) eta prozeduren artean lotura zuzena ezarri zen. Gerora "metodo" kontzeptua izango zenaren aurrekari moduan har daiteke.[6]

OBParen kontzeptua 60ko hamarkadan formalizatu zen, Simula programazio-lengoaiak (Simula 67) klasea, objektua, herentzia, instantzia eta lotura dinamikoa moduko kontzeptuak inplementatu zituenean. [7][8] Simula I (1961–1965) eta Simula 67 (1965–1968) bertsioak garatu ziren. Ole-Johan Dahl-ek eta Kristen Nygaard-ek sortu zuten Simula, Oslo-n kokatuta dagoen Norvegiako Konputazio-Zentruan. Simulazioak egiteko helburuarekin sortu zen, portuetan itsasontzien eta haiek garraiatutako kargen mugimendua aztertzeko eta hobetzeko ereduak sortu ahal izateko. Dagoeneko LISP programazio-lengoaia funtzionalean inplementatuta zegoen "zabor-bilketa automatikoa" (ingelesez, automatic garbage collection) ere erabiltzen zuen. Simula 67 programazio-lengoaian inplementatutako kontzeptu horiek eragina izan zuten gerora garatutako beste programazio-lengoaia batzuetan, hala nola, Smalltalk, Object Pascal, C++, Ada eta BASIC.

70eko hamarkadan, Alan Kay-k, Dan Ingalls-ek eta Adele Goldberg-ek Smalltalk programazio-lengoaiaren lehen bertsioa garatu zuten Xerox PARC enpresan. Lengoaiak objektuetara bideratutako kontzeptuak erabiltzen zituelako eta garapenerako ingurune grafikoa erabiltzen zuelako nabarmendu zen. Hainbat bertsio sortu ziren, eta komunitatearen interesa piztu zen. Smalltalk-ek Simula 67 lengoaiaren eragina jaso zuen arren, sistema guztiz dinamikoa izateko diseinatu zen. Horrela, klaseak modu dinamikoan sortu eta aldatu zitezkeen.[9][10]

70eko hamarkadan, Smalltalk-ek eragina izan zuen Lisp-eko komunitatean, eta garatzaileek objektuei bideratutako teknikak txertatu zituzten Lisp makinetan exekutatzeko. Egindako esperimentuetatik LOOPS (Lisp Object-Oriented Programming System) eta Flavors moduko Lisp-en hedapenak sortu ziren. Azkenean, CLOS (Common Lisp Object System) garatzea lortu zen, objektu-sistema dinamiko ahaltsua, programazio funtzionala eta objektuetara bideratutakoa bateratzen dituena.

80ko hamarkadan zehar, OBP garrantzia hartzen joan zen. 1981ean, Goldbergek Smalltalk-i eta OBPari buruzko artikulu bat argitaratu zuen "Byte Magazine" aldizkarian, eta publiko zabalagoarengana iristea lortu zuen. 1986an, ACM (Association for Computing Machinery) elkarteak "Conference on Object-Oriented Programming, Systems, Languages, and Applications" (OOPSLA) biltzarra antolatu zuen lehen aldiz, eta espero baino parte-hartzaile gehiago izan zen bertan. 80ko hamarkadaren erdialdean, Brad Cox-ek "Objective-C" garatu zuen, C programazio-lengoaiari Smalltalk-en estiloko mezu-trukea erantsi zion OBP lengoaia. Azkenean, Bjarne Stroustrup-ek objektuei bideratutako C++ programazio-lengoaia sortu zuen. 1985ean, Bertrand Meyerrek Eiffel programazio-lengoaiaren lehen diseinua egin zuen. Softwarearen kalitatearen ikuspuntutik, Eiffel objektuei bideratutako programazio-lengoaia purua da.

90eko hamarkadan, OBParen erabilera asko zabaldu zen, batez ere OBP tekniketan oinarritutako programazio-lengoaien erabilera (C++, Visual FoxPro[11], Delphi) orokortu zenean. Interfaze grafikoen erabileraren gorakadak ere eragina izan zuen arrakastan. Lehendik existitzen ziren lengoaia askotan OBP ezaugarriak gehitu ziren, Ada, BASIC, Fortran, Pascal eta COBOL lengoaietan, besteak beste. Hasieran OBP paradigmarako diseinatu ez ziren lengoaiei OBP ezaugarriak gehitzeak, askotan, bateragarritasun- eta mantentze-arazoak ekarri zituen.

Gerora, neurri handi batean OBP paradigmari jarraitzen dioten baina programazio funtzionalarekin ere bateragarriak diren lengoaiak sortu dira. Horietako bi Python eta Ruby dira. Segur aski, ikuspegi komertzialetik garrantzitsuenak Java (Sun Microsystems-ek garatua), C# eta Visual Basic (Microsoften .NET plataformarako diseinatutakoak) dira.

Oinarrizko kontzeptuak aldatu

Objektuei bideratutako programazioa (OBP) onartzen duten programazio-lengoaia guztiek ez dituzte onartzen hari lotutako teknika eta egitura guztiak. Izan ere, lengoaia batzuk klasearen eta objektuaren kontzeptuetan oinarrituz diseinatu ziren baina beste batzuk, malguagoak dira eta hainbat programazio-paradigma onartzen dituzte. OBP paradigmaren kontzeptu nagusiak dira honakoak dira:

Klasea

Klasea objektuak sortzeko funtsezko mekanismoa da. Bertan definitzen dira objektu mota baterako eremuak (atributuak, propietateak) eta metodoak (prozedurak). Klase baterako sortzen diren objektu guztiek eremu eta metodo berberak partekatzen dituzte. Adibidez, "Katu" izeneko klase batean, eremuen atalean katuen ezaugarriak defini daitezke (kolorea, pisua, etab) eta metodoen atalean katuen jokaera (salto egitea, jatea, etab.).

Programazio egituratu tradizionalarekin alderatuta, objektuaren eremua "aldagaiak" dira, objektuaren egoerari buruzko informazioa ematen duen barne-edukiontzi bat, eta objektuaren metodoak "funtzioak" dira, objektuaren barne-prozedurak.

Objektua

Klase bateko objektu berri bat sortzeari instantziazioa deritzo. Horrela, objektua klase baten instantzia moduan sortutako datu-mota abstraktua da. Objektuetan informazioa (datuak) eta haiek atzitzeko funtzioak (kodea) kapsulatuta daude: informazioa eremuetan (atributuetan, propietateetan) eta kodea metodoetan (prozeduretan).

Objektuak "constructor" izeneko metodo berezi bati deituz sortzen dira. Objektu batek mundu errealeko elementu bat adieraz dezake. Online erosketa-sistema batean, adibidez, objektu bat "erosketa-orga", "bezeroa" edo "produktua" izan daiteke. "Katu" klaserako objektu bat, adibidez, "Mixina" katua izan daiteke. Entitate abstraktuagoak ere adieraz daitezke objektuen bidez; neurketak metrika batetik bestera aldatzeko zerbitzua ematen duen objektu bat, adibidez, miliak kilometrotara bihurtzeko.

Objektuak barne-egitura konplexuko aldagai gisa atzitzen dira. Programazio-lengoaia askotan erakusle (ingelesez, pointer) moduan erabiltzen dira. Abstrakzio-maila bat ematen diote programatzaileari, barne-kodea eta kanpo-kodea bereizteko aukera ematen dutelako. Kanpoko kodeak objektu bat erabil dezake, instantzia-metodo jakin bati deituz, objektuaren instantzia-aldagai batetik irakurriz edo bertan idatziz.

Eremua

Objektuaren ezaugarriak gordetzen dira bertan. "Katu" klaseko "Mixina" objektuaren "kolorea" eremuan, adibidez, "beltza" balioa egon daiteke, eta "pisua" eremuan "3 kg" balioa. "Katu" klasean definitutako metodoak exekutatuz aldatzen dira objektuaren eremuetan gordetako balioak.

Metodoa

Klase bateko objektuaren portaera definitzen duen algoritmoa da eta objektuak egin dezakeena definitzen du. Hainbat metodo defini daitezke klase batean. "Katu" klaserako, adibidez, "salto egin" metodoa, "jan" metodoa, etab. Metodoak exekutatzeko, "message passing" izeneko teknika erabiltzen da: mezu batek metodoaren exekuzioa eragiten du objektu jakin baterako (haren eremuetako balioetarako). Ondorioz, objektuaren propietateetako balioak alda daitezke, edo gertaera bat sor daiteke metodoa beste objektu baterako exekutatzeko.

Gertaera

Gertaerak sistemaren ekintzak dira eta programaren exekuzio-fluxua gidatzen dute. Erabiltzaileak eragindakoa izan daiteke (saguaren botoia edo teklatuaren tekla bat sakatzea) edo beste objektu batek bidalitako mezu batek eragindakoa. Gertaera baten ondorioz, sistemak mezu bat bidaliko dio dagokion objektuari. Gertaeretara bideratutako programazioaren paradigman asko erabiltzen dira.

Mezua

Mezu bat gertaera batek objektu bati bidalitako komunikazioa da. Mezu bat bidaltzean, objektuaren metodo jakin bat exekutatzeko agindua ematen da, eta exekuzioan gertaera horri lotutako parametroak erabiltzen dira. Mezu-trukeari dagokionez, halaxe zioen Alan Kay-k: "I thought of objects being like biological cells and/or individual computers on a network, only able to communicate with messages (so messaging came at the very beginning – it took a while to see how to do messaging in a programming language efficiently enough to be useful"[12].

Ezaugarriak aldatu

Hona hemen Objektuei Bideratutako Programazioaren (OBP) ezaugarri nagusiak:

Herentzia

Klasearen kontzeptuan oinarritzen diren programazio-lengoaia gehienek herentziaren mekanismoa eskaintzen dute. Klaseak ez dira isolatuta egoten, elkarren artean modu hierarkikoan erlazionatuta baizik. Horrela, klase berriak sor daitezke existitzen diren klaseen azpiklase moduan "is-a-type-of" erlazioen bidez. Adibidez, "Ugaztun" klasearen azpiklase moduan "Katu" eta "Txakur" klaseak definituz gero, "Ugaztun" klaserako definituta dauden eremuak eta metodoak herentzia bidez jasoko dituzte. Horrela, hierarkian behera gero eta espezializatuagoak diren azpiklaseetarako espezifikoak diren eremuak eta metodoak besterik ez ditu definitu beharko programatzaileak. Objektuak klase bat baino gehiagokoak direnean, klase guztien propietateak eta metodoak heredatzen dituzte.

Herentziari esker, polimorfismoa eta kapsulatzea errazten dira, objektuak lehendik existitzen diren objektu-mota espezializatu moduan sor daitezkeelako.

Kapsulatzea

Kapsulatzearen kontzeptuak honako bi esanahiak izan ditzake: 1) datuak eta datu horiekin lan egiten duten metodoak elkartzea, 2) objektuaren hainbat osagaietarako atzipena murriztea. Kapsulatzeari esker, kanpoko kodeak ez du objektuaren barne-funtzionamenduaz arduratu behar. Horrela, errazagoa gertatzen da objektuko eremuetan eta kodean aldaketak egitea.

Abstrakzioa

Abstrakzioaren helburua konplexutasuna maneiatzea da, erabiltzaileari beharrezkoak ez diren xehetasunak ezkutatuz. Programatzeko garaian, aktore abstraktuak adierazten dituzten objektuak defini daitezke, zeregin bat beteko dutenak, objektuari buruz informatuko dutenak edo bere egoera aldatuko dutenak, baina inplementazioari buruzko xehetasunetan sartu gabe. Horri esker, programatzaileak logika konplexuagoa erabil dezake, abstrakzio-maila altuagoan lan eginez.

Polimorfismoa

Zerbait modu desberdinetan gerta daitekeela esan nahi du. OBP paradigman, sintaktikoki berdinak diren mezuak mota desberdineko objektuei bidali ahal izatea, adibidez, datu-motekin arazorik izan gabe[13]. Objektuak modu polimorfikoan erabili ahal izateko, bidaltzen zaien mezuari erantzuteko prestatuak egon behar dute. Interfazeekin lan egitean, mota desberdineko objektuak interfaze komun baten bidez atzitu ahal izango dira. Adibidez, Java-n klase guztiak Object klasetik heredatzen dute. Hortaz, Object motako aldagai bat sortu daiteke eta edozein klaseko instantzia esleitu[14].

Modularitatea

Aplikazio bat "modulu" izeneko atal txikiagoetan zatitzeko aukera ematen duen propietatea da. Zati bakoitzak aplikazioaren eta gainerako zatien artean ahalik eta independenteena izan behar du. Modulu horiek bakoitza bere aldetik konpilatu daitezke, baina loturak dituzte haien artean.

Informazioa ezkutatzea

Objektuen arteko elkarrekintza interfazeen bidez egiten da. Bertan adierazten zaie beste mota bateko objektuei, klase horretako objektuekin nola elkarreragin dezaketen. Isolamendua horri esker, objektuaren eremuak babesten dira, haiek aldatzeko baimenik ez dutenen aurrean. Horrela, objektuen barne-egoera ez da ezustean aldatuko.

Zabor-bilketa

Zabor-bilketa egitea (ingelesez, garbage collection) erreferentziatuak ez diren objektuak modu automatikoan suntsitzea da. Erreferentziarik gabeko objektuak dagoeneko erabiltzen ez direnak dira; suntsitzeko markatzen dira eta haiei lotutako memoria askatu egiten da. Teknika horri esker, programatzaileak ez du memoriaren kudeaketaz arduratu behar; objektu berriei inguruneak esleituko die memoria eta dagoeneko erabiltzen ez diren objektuen memoria hark askatuko du.

OBP programazio-lengoaiak aldatu

OBP-an oinarritutako lehen programazio-lengoaia Simula izan zela esaten da (1967). Simulazio-programak egiteko sortu zen, eta informazio garrantzitsuena objektu izenekoetan gordetzen zen. Smalltalk ere lehenengotariko OBP lengoaia bat izan zen (1972-1980) eta harekin garatu zen OBP paradigmaren oinarrizko teoria. Objektuetara duten bideratze-mailari dagokionez, sailkapen hau egin daiteke:

  • Lengoaia puruak. Lengoaia hauetan dena interpreta daiteke objektuen ikuspuntutik: primitibak (karaktereak, puntuazio-markak, etab.), klaseak, prototipoak, blokeak, moduluak eta abar. OBP metodoen erabilera errazteko diseinatuta daude: Ruby[15], Scala, Smalltalk, Eiffel, Emerald, JADE, Self, Raku.
  • OBPrako diseinatutako lengoaiak, elementu prozeduralak dituztenak: Java, Python, C++, C Sharp, Delphi, Object Pascal, Visual Basic.NET.
  • Lengoaia prozeduralak, hainbat OBP ezaugarri onartzeko hedatuak izan direnak: PHP, Perl, Visual Basic, MATLAB, COBOL 2002, Fortran 2003, ABAP, Ada 95, Pascal.
  • OBP ezaugarri gehienak dituzten lengoaiak (klaseak, metodoak, herentzia), but modu desberdinean inplementatuak: Oberon.
  • OBP programazioaren antza duten lengoaiak, datu-mota abstraktuak onartzen dituztenak baina OBP paradigmako ezaugarriak falta dituztenak. Objektuetan edo prototipoetan "oinarritutako" programazio-lengoaiak direla esaten da: JavaScript, Lua, Modula-2, CLU.
  • Kameleoi-lengoaiak, programazio-paradigma asko onartzen dituztenak, baita OBP ere: Tcl[16] lengoaiak, adibidez TclOO bertsioan, prototipoetan oinarritutako programazioa eta klaseetan oinarritutako OBP onartzen dituen objektu-sistema hibridoa dauka.

Erreferentziak aldatu

  1. Booch, Grady. (1994). Software engineering with Ada. (3rd ed. argitaraldia) Benjamin/Cummings, 220 or. ISBN 0-8053-0608-0. PMC 28293653. (Noiz kontsultatua: 2022-11-07).
  2. Levin, Michael I.. (1965). LISP 1.5 programmer's manual : the Computation Center and Research Laboratory of Electronics, Massachusetts Institute of Technology. (2d ed. argitaraldia) M.I.T. Press ISBN 0-262-13011-4. PMC 1841373. (Noiz kontsultatua: 2022-11-07).
  3. (Ingelesez) Sutherland, Ivan Edward. (1963). Sketchpad, a man-machine graphical communication system. Massachusetts Institute of Technology (Noiz kontsultatua: 2022-11-18).
  4. Sutherland, Ivan Edward. (1963). «Sketchpad, a man-machine graphical communication system» web.archive.org (Noiz kontsultatua: 2022-11-18).
  5. (Ingelesez) «A.M. Turing Award» amturing.acm.org (Noiz kontsultatua: 2022-11-18).
  6. (Ingelesez) Introduction to Software Engineering with the AED-0 Language,. (Noiz kontsultatua: 2022-11-18).
  7. Holmevik, J.R.. (1994). «Compiling SIMULA: a historical study of technological genesis» web.archive.org (Internet Archive) (Noiz kontsultatua: 2022-11-18).
  8. Holmevik, J.R.. (1994). «Compiling SIMULA: a historical study of technological genesis» IEEE Annals of the History of Computing 16 (4): 25–37.  doi:10.1109/85.329756. ISSN 1934-1547. (Noiz kontsultatua: 2022-11-18).
  9. «The Early History of Smalltalk» gagne.homedns.org (Noiz kontsultatua: 2022-11-18).
  10. «The Early History of Smalltalk» web.archive.org 2008-07-10 (Noiz kontsultatua: 2022-11-18).
  11. «Visual FoxPro 3.0 Reviewers Guide» www.dfpug.de (Noiz kontsultatua: 2022-11-18).
  12. (Ingelesez) Stefan L. Ram, Berlin. (2003-07-23). Dr. Alan Kay on the Meaning of "Object-Oriented Programming". Stefan L. Ram, Berlin, Germany. (Noiz kontsultatua: 2022-12-05).
  13. (Ingelesez) Janssen, Thorben. (2021-12-17). «OOP Concepts for Beginners: What is Polymorphism» Stackify (Noiz kontsultatua: 2022-12-06).
  14. «Polymorphism (The Java™ Tutorials > Learning the Java Language > Interfaces and Inheritance)» docs.oracle.com (Noiz kontsultatua: 2022-12-06).
  15. «Lenguaje de Programación Ruby» www.ruby-lang.org (Noiz kontsultatua: 2022-12-07).
  16. «Tcl Developer Site» www.tcl-lang.org (Noiz kontsultatua: 2022-12-07).

Kanpo estekak aldatu