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:

Medic acuză: În fazele inițiale, te faci bine în 24 de ore cu o singură perfuzie. România refuză să cumpere tratamentul. În faze mai grave există tratament cu un înalt grad de eficiență:Tocilizumab. România nu-l cumpără. Opinia Fluierul.ro

Interdicțiile aplicate în România în starea de alertă începând de luni, 25 octombrie. Masca, obligatorie peste tot

BOMBĂ ActiveNews: "Președintele Klaus Iohannis este membru al Organizației Progresiste 'European Council of Foreign Relations' un Think-Tank fondat de GEORGE SOROS". Fluierul.ro a descoperit că ECFR e condusă de Carl Bildt MEMBRU AL GRUPULUI BILDERBERG

Ziua Armatei Române, sărbătorită luni, 25 octombrie, în format restrâns

HOROSCOP 25 octombrie 2021. Obiectiv îndeplinit. Socoteala de acasă se potrivește cu cea din târg pentru aceste zodii

Coronavirus în România 25 octombrie 2021. Bilanț complet COVID-19

Moartea lui Kobe Bryant: soția Vanessa a aflat adevărul la câteva ore după accident

Formula 1: Verstappen a câștigat Marele Premiu al SUA, Hamilton a terminat pe locul 2

PREZENTUL FĂRĂ PERDEA Marius Oprea / Cîțu îl sabotează pe Ciucă - vrea înapoi la Palatul Victoria

COMENTARIU Valeriu ȘUHAN: Operation "Sentinel"

Antivacciniștii mărșăluiesc prin centrul Bucureștiului. Manifestanții flutură steaguri tricolore

Clotilde Armand își acuză subordonații. Obligația de serviciu pe care jumătate din funcționarii primăriei o nesocotesc

Segmentul care a tras în jos construcțiile în luna august. România "duduie", totuși, la un capitol

Accesul în sediile instanțelor și parchetelor nu se face în baza certificatului verde

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

Radu Lupescu, medicul român decorat pentru managementul pandemiei în Franța: "În Franța a ajutat foarte mult că autoritățile au fost foarte ferme"

COMENTARIU Lelia Munteanu. Criminalitatea în așezările israeliene locuite de arabi - o problemă de siguranță națională

Maratonul vaccinării la București. Zeci de mii de persoane au fost vaccinate în trei zile

Real Madrid a câștigat "El Clasico", cel mai mare meci al fotbalului. Pentru prima oară din 2007, fără Ronaldo și fără Messi

UPDATE-6 - ALO ANTENA 3 ? UNDE SUNT BANII DONATI? SOMAM INCA ODATA ANTENA 3: IMPARTITI IMEDIAT TOTI BANI DIN CONT, IN MOD EGAL, VICTIMELOR: morti si raniti.

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

DNA-ul condus de Kovesi afirmă FĂRĂ PROBE că ceea ce am auzit şi am văzut nu e adevărat. Mai mult, după DNA dacă cineva face o plângere penală CU PROBE AUDIO ŞI VIDEO arătând cum DNA-ul Fabrică Probe ca să bage lumea la închisoare atunci "face şantaj"

Sfatul unui medic: "Vaccinați-vă, dar stați deoparte! Numărul real de infectări este 100.000 pe zi"

Medicamentele pentru tratamentul pacienților COVID, oferite de Franța, au ajuns în România. Arafat: "Pentru noi este un ajutor extraordinar"

România, descrisă de presa internațională ca un cimitir al Europei: un mort la fiecare 5 minute, în ultima lună

Premierul desemnat și președintele USR se vor întâlni luni la Parlament

VIDEO Fotbal total în Anglia: Manchester United - Liverpool 0-5. Meci perfect pentru egipteanul Mo Salah

Emma Răducanu, descusută la Transylvania Open: cum i s-a schimbat viața după US Open

Vâlcov acuză că Iohannis că ar fi avut înțelegeri cu CEO al OMV pe legea offshore în urma unor întâlniri repetate şi a retrimiterii legii offshore în parlament. Cine investighează posibila trădare de țară? NIMENI.

România locul 2 în Europa la producția de porumb după Franța

Fete injectate în cluburi de noapte cu somnifere sau cu "droguri de viol"

TOT MAI MULȚI INFECTAȚI ÎN FRANȚA: Cât de proști sunt medicii francezi și cum l-au trimis acasă pe chinezul cu Coronavirus. Putem fi mândri de proștii noștri...

PORTATIV ROMÂNESC Conexiuni

Alo, MERKEL-WERNER-și-KURZ sunt și românii OAMENI sau nu sunt? Cine ia măsuri? GERMANIA. Bătaia de joc la care sunt supuși românii pe plantațiile nemțălăilor din Germania a ajuns în reportajele televiziunii germane ARD.

Datoria externă a României se apropie de 100 de miliarde de euro. Reamintim că Ceauşescu a lăsat România cu datorie ZERO şi cu 3 miliarde în conturi şi că a fost împușcat şi pentru subminarea economiei naționale

DEMISIA. Iohannis: "Mi s-a propus să fiu membru" în organizația condusă de un Bilderberg și finanțată de Soros. "Sunt bucuros să spun că-mi doresc acest lucru"

Proprietara companiei de dulciuri Fisherman’s friend a lăsat moștenire 41 de milioane de lire sterline săracilor, dar nimic fiului său

Proiect: Elevii vor studia obligatoriu educație financiară și educație juridică de anul viitor

Criză santitară: Niciun pat nu este liber în secțiile ATI COVID din România

Dănuț Lupu, despre lupta teribilă cu COVID-19: "Am slăbit vreo 26 de kilograme". Fratele său n-a rezistat

Autoritățile din București confirmă că școlile private vor fi deschise luni dimineața. Articolul din decizia CNSU nu a fost preluat în Hotărârea de Guvern

Bulgaria, mai rău ca România. Vecinii de la sud de Dunăre reclamă că li s-au prăbușit spitalele

Discuții PNL-UDMR la Palatul Victoria pentru noul program de guvernare. Luni, întâlnire cu USR

Coronavirus în România 24 octombrie 2021. COVID-19 a răpus un român la 4 minute în ultimele 24 de ore. Peste 11.000 de cazuri. Bilanț complet

Vaccinarea anti-COVID în România. Peste 110.000 de români s-au vaccinat în ultimele 24 de ore

Ana Maria Mocanu, GOALĂ la duş. Imagini de infarct FOTO XXX

Ca-n filmele americane. Gangsterii din Chicago către Donald Trump: "Te respectăm şi vom înceta să ucidem"

Povestea lui ConstantinCăpităneanu, astronomul care a desenat prima harta a României modernă

În timp ce "nu sunt bani" pentru pensionari, bugetari, studenți și elevi - Serviciile Secrete primesc bani gârlă și măriri uriașe prin credite de angajament

Iată imagini XXX cu Ana Mocanu şi noul iubit din vacanţa în Malta GALERIE FOTO

George Soros, Rețeaua Progresistă şi Amestecul Etnic Forțat. George Soros - Voi investi 500 de milioane ca să fac migrația de neoprit. Preocuparea mea cea mai mare este să îi ajut pe migranţi şi refugiaţi să vină în Europa

Mircea Eliade: "Invitație la Bărbăție" - "E adevărat, suntem proşti şi netrebnici, suntem mărunţi şi păcătoşi, suntem incapabili, lichele, fleacuri, mediocri, tot ce vreţi. În faţa acestor adevăruri, aş vrea ca o duzină de tineri să poată striga: Ei şi?!"

The Guardian : Doi ani de investigatii leaga firma austriaca Holzindustrie Schweighofer de distrugerea ultimelor paduri virgine din Europa - padurile virgine in Romania (engleza)

SUA. Tucker Carlson despre cenzura progresistă: „Niciodată în istoria americană nu a existat o cenzură de presă pe această scară”

Regizorul Michael Moore: "Trump e GRENADA UMANĂ pe care oamenii o pot arunca LEGAL în SISTEMUL care le-a furat viețile!”

Vaccinul Anti-Hepatic B asociat cu Sindromul Hemolitic Uremic.Cerem Guvernului Cioloș să facă o investigație și să prezinte un raport medical CORECT și COMPLET care să arate dacă Vaccinările au avut sau nu un rol în declanșarea Sindromului HemoliticUremic

UPDATE: Apa, portocalele, laptele praf și Spitalul din Argeș NU sunt sursa infecției. Conform unui grup de medici din Argeş: Vaccinul anti-hepatită, ar fi cauza îmbolnăvirilor pe bandă rulantă în rândul bebeluşilor!

Penibil. Exact în ziua, când a aflat că i se taie din bugetul uriaș de nesimțit, SRI-ul popperianului Hellvig s-a prefăcut că prinde un terorist.

1989. Șeful Securității:"Guvernul FSN era dominat de două categorii: cei cu legături cu KGB și evrei. Evreii au fost implicați în evenimente. Nu doar cei implicați direct, Brucan, Brateș, Stark, care au jucat un rol activ, ci și cei care au rămas în umbră"

A lătrat Klemă şi alți ambasadori străini şi Dragnea s-a executat. Bacşişul mic ce-l primim pe resursele NOASTRE e prea mare urlă străinii. Deşi de-abia a dat legea, Dragnea anunță că guvernul PSD+ALDE VA DA o ordonanță de urgență pentru legea off-shore.


Pag.1 Pag.2 Pag.3

Nr. de articole la aceasta sectiune: 165, afisate in 3 pagini.