23:59
Comentarii Adauga Comentariu

Programarea orientată pe obiecte este moartă. Să fie oare, adevărat?



Programarea orientată pe obiecte este moartă. Să fie oare, adevărat?? Evangheliști de programare funcțională, vă îndreptați armele spre inamicul greșit

Programarea în anii 1960 a avut o mare problemă: computerele nu erau încă atât de puternice și, într-un fel, trebuiau să împartă capacitățile între structuri de date și proceduri.

Acest lucru însemna că, dacă aveți un set mare de date, nu puteți face atât de mult cu ele fără a împinge computerul la limitele sale. Pe de altă parte, dacă ar fi nevoie să faceți o mulțime de lucruri algoritmic, nu ați putea folosi prea multe date căci calculele computerului ar dura pentru totdeauna.

Apoi , Alan Kay a venit în 1966 sau 1967 și a teoretizat că ar putea folosi încapsularea în mini-computerele care nu au accesul la datele lor, ci mai degrabă le-ar primi comunicate prin mesaje. În acest fel, resursele de calcul pot fi utilizate mult mai economic.

În ciuda ingeniozității ideii, a durat până în 1981 până când programarea orientată pe obiecte va ajunge în mainstream. De atunci, însă, nu a încetat să atragă dezvoltatori de software noi și experimentați deopotrivă. Piața pentru programatori orientati-pe-obiect este la fel de ocupată, ca niciodată.

Dar, în ultimii ani, paradigma veche de decenii a primit din ce în ce mai multe critici . S-ar putea ca, la patru decenii după ce programarea orientată pe obiecte a lovit masele, tehnologia depășește această paradigmă?

Este atât de proastă ideea cuplării funcțiilor cu datele?

Ideea principală din spatele programării orientate pe obiecte este cât se poate de simplă: încercați să spargeți un program în părți la fel de puternice ca întregul. Rezultă că cuplați bucăți de date și acele funcții care se obișnuiesc doar cu datele în cauză.

Rețineți că aceasta acoperă doar noțiunea de încapsulare, adică datele și funcțiile care stau în interiorul unui obiect sunt invizibile pentru exterior. Se poate interacționa cu conținutul unui obiect numai prin mesaje, numite de obicei funcții getter și setter.

Ceea ce nu este conținut în ideea inițială, dar este considerat esențial pentru programarea orientată obiect în prezent, sunt moștenirea și polimorfismul. Moștenirea înseamnă practic că dezvoltatorii pot defini subclasele care au toate proprietățile pe care le are clasa lor părinte. Acest lucru nu a fost introdus în programarea orientată pe obiecte decât în ​​1976, la un deceniu de la concepție.

Polimorfismul a ajuns la programarea orientată pe obiecte încă un deceniu mai târziu . În termeni de bază, înseamnă că o metodă sau un obiect poate servi drept șablon pentru alții. Într-un sens, este o generalizare a moștenirii, deoarece nu toate proprietățile metodei sau obiectului original trebuie transmise noii entități; în schimb, puteți alege să înlocuiți proprietățile.

Ceea ce este special la polimorfism este că, chiar dacă două entități depind unele de altele în codul sursă, o entitate numită funcționează mai mult ca un plugin. Acest lucru face viața mai ușoară pentru dezvoltatori, deoarece nu trebuie să se îngrijoreze de dependențe în timpul rulării.

Merită menționat faptul că moștenirea și polimorfismul nu sunt exclusive programării orientate pe obiecte. Adevăratul diferențiator constă în încapsularea bucăților de date și a metodelor care le aparțin. Într-o perioadă în care resursele de calcul erau mult mai rare decât astăzi, aceasta era o idee genială.

Cele cinci mari probleme din programarea orientată pe obiecte

Odată ce programarea orientată pe obiecte a lovit masele, a transformat modul în care dezvoltatorii văd codul. Ceea ce a prevalat înainte de anii 1980, programarea procedurală, a fost foarte orientat spre mașină. Dezvoltatorii au avut nevoie să știe destul de multe despre modul în care funcționează computerele pentru a scrie coduri bune.

Prin încapsularea datelor și metodelor, programarea orientată pe obiecte a făcut dezvoltarea software-ului mai centrată pe om. Se potrivește cu intuiția umană că metoda aparține grupului de date , dar nu grupului . drive() car teddybear

Când moștenirea a apărut, și asta a fost intuitiv. Are perfect sens că este un subgrup de și are aceleași proprietăți, dar nu. Hyundai car PooTheBear

Sună ca o mașinărie puternică. Totuși, problema este că programatorii care cunosc doar codul orientat pe obiecte vor forța acest mod de gândire pe tot ceea ce fac. Este ca atunci când oamenii văd cuie peste tot pentru că tot ce au este un ciocan. După cum vom vedea mai jos, când cutia dvs. de instrumente conține doar un ciocan, aceasta poate duce la probleme fatale.

1. Problema junglei bananelor gorilelor Imaginați-vă că creați un nou program și vă gândiți să proiectați o nouă clasă. Apoi, te gândești la o clasă mică, pe care ai creat-o pentru un alt proiect și îți dai seama că ar fi perfectă pentru ceea ce încerci să faci în prezent.

Nici o problemă! Puteți refolosi clasa din vechiul proiect pentru cel nou.

Cu excepția faptului că această clasă poate fi de fapt o subclasă a altei clase, așa că acum trebuie să includeți și clasa părinte. Atunci îți dai seama că clasa părinte depinde și de alte clase și ajungi să incluzi grămezi de cod.

Creatorul lui Erlang, Joe Armstrong, a proclamat faimos :

Problema cu limbajele orientate obiect este că au tot acest mediu implicit pe care îl transportă cu ele. Ai vrut o banană, dar ceea ce ai primit a fost o gorilă care să țină banana și întreaga junglă.

Asta spune aproape totul. Este bine să refolosiți cursurile; de fapt, poate fi o virtute majoră a programării orientate pe obiecte.

Dar nu o duce la extrem. Uneori este mai bine să scrieți o nouă clasă în loc să includeți mase de dependențe de dragul DRY (nu vă repetați).

2. Problema fragilă a clasei de bază Imaginați-vă că ați reutilizat cu succes o clasă dintr-un alt proiect pentru noul cod. Ce se întâmplă dacă clasa de bază se schimbă?

Vă poate corupe întregul cod. S-ar putea să nu fi atins-o. Dar într-o zi proiectul tău funcționează ca un farmec, a doua zi nu, deoarece cineva a schimbat un detaliu minor în clasa de bază care ajunge să fie crucial pentru proiectul tău.

Cu cât folosești mai mult moștenirea, cu atât trebuie să faci mai multă întreținere. Deci, chiar dacă reutilizarea codului pare foarte eficientă pe termen scurt, pe termen lung poate deveni costisitoare.

3. Problema diamantului

Moștenirea este acest mic lucru drăguț în care putem prelua proprietățile unei clase și le putem transfera altora. Dar dacă doriți să amestecați proprietățile a două clase diferite?

Ei bine, nu o poți face. Cel puțin nu într-un mod elegant. Luați în considerare, de exemplu, clasa Copier. (Am împrumutat acest exemplu, precum și câteva informații despre problemele prezentate aici, din povestea virală a lui Charles Scalfani Goodbye, Object Oriented Programming .) Un copiator scanează conținutul unui document și îl tipărește pe o foaie goală. Deci ar trebui să fie subclasa sau ?

Pur și simplu nu există un răspuns bun. Și, deși această problemă nu vă va rupe codul, apare suficient de des pentru a fi frustrant.

4. Problema ierarhiei

În problema diamantului, întrebarea era de ce clasă Copier este o subclasă. Dar te-am mințit - există o soluție îngrijită. Să fie clasa părinte și și să fie subclasele care moștenesc doar un subset de proprietăți. Problemă remediată! Copier Scanner Printer

Este curat. Dar ce se întâmplă dacă dvs. este doar alb-negru și vă puteți ocupa și de culoare? Nu este în acest sens o generalizare a ? Ce se întâmplă dacă este conectat la WiFi, dar nu este? Copier Printer Printer Copier Printer Copier

Cu cât aveți mai multe proprietăți pe o clasă, cu atât devine mai dificil să stabiliți ierarhii adecvate. Într-adevăr, aveți de-a face cu grupuri de proprietăți, unde împărtășește unele, dar nu toate proprietățile , și invers. Și dacă încercați să lipiți acest lucru în ierarhii și aveți un proiect complex, acest lucru vă poate duce la un dezastru dezordonat. Copier Printer

5. Problema de referință

Ați putea spune, bine, atunci vom face doar programare orientată pe obiecte, fără ierarhii. În schimb, am putea folosi clustere de proprietăți și să moștenim, extindem sau înlocuim proprietățile după cum este necesar. Sigur, ar fi cam dezordonat, dar ar fi o reprezentare exactă a problemei la îndemână.

Există doar o problemă. Întregul punct al încapsulării este de a păstra bucăți de date în siguranță unul de celălalt și, astfel, de a face calculul mai eficient. Acest lucru nu funcționează fără ierarhii stricte.

Luați în considerare ce se întâmplă dacă un obiect suprascrie ierarhia interacționând cu un alt obiect . Nu contează ce relație are , cu excepția faptului că nu este clasa directă a părinților. Apoi trebuie să conțină o referință privată la , pentru că altfel nu ar putea interacționa. A B A B B A B

Dar dacă conține informațiile pe care le au și copiii , atunci aceste informații pot fi modificate în mai multe locuri. Prin urmare, informațiile despre acestea nu mai sunt sigure, iar încapsularea este ruptă. A B B

Deși mulți programatori orientați pe obiecte construiesc programe cu acest tip de arhitectură, aceasta nu este o programare orientată pe obiecte. Este doar o mizerie.

Pericolul paradigmei unice

Aceste cinci probleme au în comun faptul că pun în aplicare moștenirea acolo unde nu este cea mai bună soluție. Deoarece moștenirea nu a fost nici măcar inclusă în forma originală de programare orientată obiect, nu aș numi aceste probleme inerente orientării obiectelor. Sunt doar exemple de dogme duse prea departe.

Totuși, nu numai programarea orientată pe obiecte poate fi exagerată. În programarea funcțională pură , este extrem de dificil să procesați intrarea utilizatorului sau să imprimați mesaje pe un ecran. Programarea orientată pe obiecte sau procedurală este mult mai bună în aceste scopuri.

Cu toate acestea, există dezvoltatori care încearcă să pună în aplicare aceste lucruri ca funcții pure și să-și arunce codul până la zeci de linii pe care nimeni nu le poate înțelege. Folosind o altă paradigmă, și-ar fi putut reduce cu ușurință codul la câteva rânduri lizibile.

Paradigmele seamănă puțin cu religiile. Sunt buni cu măsură - fără îndoială, Isus, Mohamed și Buddha au spus câteva lucruri destul de interesante. Dar dacă îi urmezi până la ultimul mic detaliu, s-ar putea să ajungi să faci viața ta și a oamenilor din jurul tău destul de nenorocită.

Același lucru este valabil și pentru paradigmele de programare. Nu există nicio îndoială că programarea funcțională câștigă aderență , în timp ce programarea orientată pe obiecte a atras unele critici dure în ultimii ani.

Este logic să vă informați despre noile paradigme de programare și să le utilizați atunci când este cazul. Dacă programarea orientată obiect este ciocanul care îi face pe dezvoltatori să vadă cuie oriunde merg, este acesta un motiv pentru a arunca ciocanul pe fereastră? Nu. Adăugați o șurubelniță la cutia dvs. de instrumente și poate un cuțit sau o foarfecă și alegeți instrumentul pe baza problemei la îndemână.

Programatorii funcționali și orientați obiect, deopotrivă, nu mai tratați paradigmele ca pe o religie. Sunt instrumente și toți își folosesc undeva. Ceea ce folosești ar trebui să depindă doar de problemele pe care le rezolvi.

Marea întrebare: suntem în pragul unei noi revoluții?

La sfârșitul zilei, dezbaterea - desigur destul de aprinsă - despre programarea funcțională versus cea orientată pe obiecte se reduce la acest lucru: am putea ajunge la sfârșitul erei programării orientate pe obiecte?

Din ce în ce mai multe probleme apar atunci când programarea funcțională este adesea opțiunea mai eficientă. Gândiți-vă la analiza datelor, învățarea automată și programarea paralelă. Cu cât ajungi mai mult în aceste domenii, cu atât îți va plăcea mai mult programarea funcțională.

Dar dacă te uiți la status quo, există o duzină de oferte pentru programatorii orientați pe obiecte la o ofertă pentru programatori funcționali. Asta nu înseamnă că nu veți obține un loc de muncă dacă îl preferați pe acesta din urmă; dezvoltatorii funcționali sunt încă destul de puțini în zilele noastre.

Cel mai probabil scenariu este că programarea orientată pe obiecte va rămâne în jur de încă un deceniu. Sigur, avangarda este funcțională, dar asta nu înseamnă că ar trebui să renunțați încă la orientarea obiectelor. Este încă incredibil de bun să îl ai în repertoriul tău.

Deci, nu aruncați programarea orientată pe obiecte din cutia de instrumente în următorii câțiva ani. Dar asigurați-vă că nu este singurul instrument pe care îl aveți.

Acest articol a fost scris de Rhea Moutafis și a fost publicat inițial pe Towards Data Science . O puteți citi aici . Publicat pe 24 iulie 2021 - ora 8:00 UTC

(Fluierul)


Linkul direct catre Petitie

CEREM NATIONALIZAREA TUTUROR RESURSELOR NATURALE ALE ROMANIEI ! - Initiativa Legislativa care are nevoie de 500.000 de semnaturi - Semneaza si tu !

Comentarii:


Adauga Comentariu



Citiți și cele mai căutate articole de pe Fluierul:

PNL-ul lui Cîțu-Iohannis și PSD Ciulacu-Dâncu-Grindeanu au transformat România în țara ABUZURILOR ANTICONSTITUȚIONALE A patra zi consecutiv când gașca de Securistoizi de la PNL PSD și UDMR împiedică ABUZIV și NEconstituțional Demararea Moțiunii de CENZURĂ

Simona Popescu - De ce ni se spune că suntem Hoți şi Proşti? Ca să conducă şi să ne exploateze multinaționalele străine proprietatea noastră publică în locul nostru şi ca să ne poată fura şi jefui.

Numai DGIA (Direcţia de Informaţii a Armatei – n.n.) n-a fost probabil împotriva mea. Lucrează toţi, îţi dai seama, au lucrat la turaţie maximă, e greu să te baţi cu toate structurile statului, în frunte cu preşedintele”, a mărturisit Ludovic Orban

Efectele COVID pe plan intim. Cum a transformat anul pandemic viața sexuală a tinerilor din România

Președinta Comisiei Europene, Ursula von der Leyen, vine la București. Întrevederi cu Klaus Iohannis și Florin Cîțu

Dumitru Prunariu, singurul român care a zburat în spațiu, împlinește 69 de ani

Cutremur puternic, cu magnitudinea 5,8, înregistrat luni în Grecia. Clădiri avariate pe insula Creta

AUR ar putea susține Guvernul Cîțu. "Îl așteptăm la negocieri în Piața Universității". Ce condiții pun

CEO Pfizer: "Într-un an cred că putem reveni la viața normală. Scenariul cel mai probabil este vaccinarea anuală"

COMENTARIU Marius Oprea. Mai am un singur dor: să nu-l mai văd pe Cîțu la televizor

Ion Cristoiu: Congresul PNL a fost momentul Căderii lui Klaus Iohannis de pe soclu

Primul efect al crizei energiei. Nuclearelectrica și-a dublat valoarea la bursă

HOROSCOP 27 septembrie 2021. Mercur retrograd de azi. Indecizie și oportunități ratate

Coronavirus în România LIVE UPDATE 27 septembrie 2021. Noul bilanț COVID-19

Strategia de extragere a gazelor din Marea Neagră. Romgaz ia un credit de 350 mil. euro pentru a cumpăra participația americanilor de la Exxon

Numărul localităților din Ilfov cu rată de infectare peste 6 la mie continuă să crească

Rezultate parțiale. Partidul Social-Democrat (SPD) are un ușor avans în urma scrutinului din Germania

Avionul Egyptair prăbuşit: Analiza uneia din cutiile negre arată că s-a pronunţat cuvântul "foc"

Un accident a avut loc la Raliul Clujului

Actorul William Shatner, din serialul Star Trek, va zbura în spațiu cu racheta lui Bezos

Rareș Bogdan, ironii la adresa lui Orban: "Îi voi așeza personal tabloul pe perete"

„Și nu fu pre voe câinilor de tătari”

Cîțu, despre demisia lui Orban de la Camera Deputaților: marți discutăm alternativele în PNL

Michael Myers, celebrul criminal din filmul de groază Halloween și-a întâlnit "nașul", într-un video viral adorabil și terifiant

Marius Tucă Show, diseară, la 19, la Aleph News și pe mediafax.ro. Invitații de azi: publicistul Ion Cristoiu și liderul Holograf, Dan Bittman

Creșterea facturilor în Italia. Premierul promite subvenții la energie de 3 miliarde de euro

Românii s-au alăturat protestelor din Italia împotriva certificatului verde. "Batantele nevaccinate sunt disperate, trebuie să plătească 200 de euro pe lună"

Pandemia COVID-19 a redus speranța de viață cu cea mai mare valoare de la Al Doilea Război Mondial

Basistul trupei Status Quo, Alan Lancaster, a murit la vârsta de 72 de ani

A explodat vestiarul la PSG. Mbappé contra Neymar: "Vagabondul ăsta nu-mi dă pase"

O carte pe zi: "Cabinetul albastru" de Simona Preda

Criza energiei din Europa se acutizează și ar putea deveni cronică

Afganistan: Talibanii interzic frizerilor din provincia Helmand să scurteze bărbile

Piticul Stalinist, Emil Boc, a infectat Cluj-Napoca în ultimul hal cu mizeria de sute de mii de oameni adunați la Untold În doar câteva zile, Cluj-Napoca ajunge la halucinantă cifră de infectare de 4,87 și infectările cresc în ritm galopant

Healthcare Trends VIDEO. Prevenția pentru cancerul de col uterin. Te poți vaccina daca ai deja virusul HPV în corp?

Au trebuit să moară bebeluși ca să vedem nesimțirea lui Iohannis. Deşi de 14 zile avem zeci de bebeluși grav bolnavi dintre care trei au murit, Iohannis nu a binevoit nici măcar 5 minute să treacă să-i vadă. În schimb s-a întâlnit cu ONG-iştii lui Soros

Dan Barna, despre algerile din PNL: "România este o republică bananieră în care Constituția pare opțională. Cîțu nu mai are susținerea USR PLUS"

Ludovic Orban și-a trimis demisia de la Camera Deputaților prin intermediul unui "reprezentant"

Alegeri Germania. Verzii: Annalena Baerbock este mulțumită de rezultatul obținut

LOVITURILE DE STAT SOFT. Mai nou, loviturile de stat, oprirea legislației și eliminarea adversarilor politici se fac prin utilizarea în mod ostentativ a mijloacelor «judiciare» întărite cu un linșaj mediatic de proporții şi cu mitinguri uriaşe de stradă

Simptomul din corp care anunță apariția demenței. Ce au descoperit cercetătorii

STRĂINILOR NU LE PLAC PRODUSELE ROMÂNEȘTI. Asociaţia Marilor Reţele Comerciale din România şi Confederaţia Patronală CONCORDIA au cerut Parlamentului să respingă Legea nr. 321/2009 care obligă hipermarketurile să achiziţioneze 51% produse românești la raft

Un urs curios găsește o cameră GoPro pierdută în zapadă. Ce a urmat, într-un video viral

Valul 4 în România. Municipiul Craiova are peste 5 persoane infectate la mia de locuitori

1.300 de clase din București au activitatea fizică suspendată și își desfășoară cursurile online

Ultima încercare a Chinei de a corecta declinul demografic. Partidul Comunist limitează avorturile din motive "non-medicale"

Alianța lui Dragnea are mii de adepți în Sălaj. Vlad Gălățeanu: ”E despre patriotism și identitate națională. Acolo-s”

Marea Britanie vrea să blocheze, în pofida Brexit, inițiativa creării unei armate a UE. Marea Britanie vrea să blocheze inițiativa despre care Iohannis ne-a spus CĂ NU EXISTĂ. Vă dați seama ce mincinos avem în funcția de președinte?

Liderul din partidul Angelei Merkel recunoaște că scorul este sub așteptări, dar vrea să conducă viitorul guvern

Alegeri Germania. Reacția lui Olaf Scholz, după rezultatul din alegeri: "Germanii au votat în număr mare pentru ca eu să fiu cancelar"

Veștea, învins de Rareș Bogdan: Am fost martorul unei minuni. 1.200 de votanți au furnizat 1.842 de voturi

Simona Halep împlinește astăzi 30 de ani fără antrenor, dar nu bani

Prognoza METEO pentru următoarele două săptămâni. Răcoare în primele zile din octombrie

Coronavirus în România LIVE UPDATE 27 septembrie 2021. 5.655 cazuri noi și peste 100 de decese. Bilanțul complet

Florentin Bercu: "Dacă vrem să avem în agricultură rezultate ca în multinaționale, trebuie să avem oameni plătiți ca în multinaționale"

Talibanii ordonă frizerilor să nu tundă bărbile afganilor. "Nu mai preluați moda americană"

Sex oral într-o parcare din Bucureşti. Ea e dezbrăcată, el cu pantalonii în vine IMAGINI XXX

Dezvăluire Şoc. Ponta "am fost obligați de UE sa integrăm zona de Vest a Țării cu Ungaria Cehia și Slovacia". Când vă spuneam, că se lucrează din greu la regionalizarea, federalizarea și la dispariția statului național numit România nu ne credeați.

Cel mai vechi recrutor român, sondaj pe LinkedIn: "Femeile care vor să facă sex să poarte la job un cerculeț verde pe rever"

Olimpiu Moruțan a marcat golul victoriei pentru Galatasaray, în partida cu Goztepe


Pag.1 Pag.2 Pag.3 Pag.4 Pag.5

Nr. de articole la aceasta sectiune: 261, afisate in 5 pagini.