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:

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

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"

Crime Tâlhării. Nesimțirea lui Arafat nu are limite. Arafat ține cont de specialiști doar la Congrese și Festivaluri. Arafat și trupa de politruci își bagă picioare în Institutul Național de Sănătate Publică și în Societatea Națională de Epidemiologie

Nasc și la Slovenia oameni. Premierul Sloven, Janez Janša, a publicat un Tweet si o fotografie cu 13 dintre cele 226 marionete ale lui SOROS din Parlamentul European, spre disperarea Soroșiștilor de la Bruxelles.

INSP: Jumătate din persoanele vaccinate s-au infectat cu Covid. Vaccinații umblă liber și răspândesc Molima la orice oră din zi și din noapte. Dacă aceasta nu e zădărnicirea criminală a răspândirii bolilor, făcută chiar de către guvernanți, atunci ce e?

Preşedintele Societăţii Române de Epidemiologie le bate obrazul sasului Iohannis, masonului Câmpeanu și inconștientului Câțu prin lipsa de măsuri și măsurile de-a dreptul criminale pe care le-au luat: „Carantina, obligatorie în București și Ilfov”

Monica Tatoiu, mărturie ŞOCANTĂ: "Umblam GOALĂ prin casă, iar la 14 ani fiul meu...".Ce spune despre pedofilie

Cum e sa te cheme Hari si să-i înjuri la greu pe români? Ar trebui să fie PENAL, nu? Hari: "Rata scăzută de vaccinare în România, expresia mai multor caracteristici ale neamului, analfabetism la nivelul colectiv al nației. Românii nu sunt educați"

Avertismentul unui medic: Nu vă mai tratați după rețete "faimoase" care circulă pe net

Uscarea naturală a părului este mai nocivă decât cea cu uscătorul de păr. Iată explicația

COMENTARIU Lelia Munteanu: Peștele cu fete la stradă

Coronavirus în România 16 octombrie 2021. Record la ATI. Bilanț complet COVID-19

Ion Cristoiu: Cîțu este un om foarte slab. Rămâne o mare enigmă de ce țara asta a fost dată peste cap pentru el, să fie președintele PNL și premier

PSD, replică după ce Cîțu a vorbit despre ratingul României: Ei se laudă și economia se scufundă

Reacție virulentă a lui Ciolacu: Premierul demis a dat astăzi un ultim spectacol al delirului politic

COMENTARIU Sorin Avram: Agentul constatator Tătaru. Nelu Tătaru

Uciderea deputatului conservator David Amess, calificată drept act terorist

HOROSCOP 16 octombrie. Dorințele acestor zodii se împlinesc. Totul merge strună pentru patru dintre ele

COMENTARIU Marius Oprea / Aceiași oameni care ne conduc: "toxici și indiferenți"

Șapte localități din Ilfov depășesc rata de infectare COVID-19 de 20 la mie

Florin Cîțu: Ratele la credite se pot amâna în cazul unui nou lockdown

Sibiu. Protest de amploare împotriva torționarului lui Horea, Cloșca și Crișan și a susținătorilor lui de tip Iohannis. Protest de amploare la Sibiu. Se cere retragerea statuii baronului Brukenthal din Piața Mare dezvelită cu mare fast chiar de Iohannis

Un câine simpatic oferă o lecție de viață oamenilor, într-un video viral pe Twitter

Reactorul 2 de la Cernavodă a fost reconectată la Sistemul Energetic Național / Decuplarea a dus la o explozie a importurilor de energie electrică

Zeci de mii de persoane au protestat la Roma împotriva anti-vacciniștilor și fasciștilor. Ei cer guvernului dizolvarea grupurilor impicate în violențele de weekendul trecut

Valoarea tichetelor de masă se majorează de luna aceasta

Mor profesorii pe capete, politrucii progresisto-soroșisti nu închid școlile ca să moară și mai mulți

Electrica achiziționează un grup care operează centrale electrice fotovoltaice

Novak Djokovic, aproape de a doborî recordul lui Pete Sampras. Cum poate intra în istorie sportivul sârb

Un director al Nike a dezvăluit că a ucis un om pe vremea când era adolescent. Cum a reușit să-și schimbe viața

Florin Cîțu, întrebat când se va simți în nivelul de trai al românilor creșterea economică: "Lucrurile arată bine"

Hipopotamii lui Pablo Escobar "terorizează" populația. Columbia va începe sterilizarea giganților aduși de lordul drogurilor

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

SUA aruncă milioane de doze de vaccin COVID, în timp ce alte țări le caută. Analiză The Guardian

O pacientă COVID din România a decedat în timpul transferului în Ungaria

Avertisment privind criptomonedele de la omul care "a prezis" criza din 2008

O țară din Europa acorde sume record pentru subvențiile destinate achizițiilor de mașini cu emisii reduse

Vârsta de eligibilitate pentru doza booster cu vaccinul anti-COVID-19 de la Pfizer ar putea fi scăzută la 40 de ani

METEO. Cinci județe intră sub alertă de ploi puternice până duminică dimineață

Atenție la gripă. Relaxarea măsurilor anti-Covid va face ca aceasta să fie mai răspândită

Alertă METEO. Plouă abundent pe mai multe tronsoane de drumuri naționale și autostrăzi

România, printre țările cu cel mai mic procent de adolescenți cu probleme de sănătate mintală

Statele Unite anunță noile cerințe de vaccinare anti-COVID pentru turiști. De când se aplică?

Sir Elton John din nou pe primul loc. Artistul a recăpătat poziția după 16 ani

Dezvăluire bombă a lui Liviu Dragnea: În România SRI-ul pune prim-miniștrii. Liviu Dragnea a declarat că șeful SRI, Hellvig împreună cu Coldea și Dâncu, i-au cerut să-l pună pe Dîncu premier chiar în ziua când PSD câștigase alegerile

Aproape 60.000 de români s-au vaccinat în ultimele 24 de ore. Situația pe doze și vaccinuri

Business Magazin: România are o producție record de grâu în 2021, dar pâinea se scumpește

O sticlă rară de șampanie, veche de 147 de ani, va fi scoasă la licitație

Michael Caine, în vârstă de 88 de ani, se retrage din actorie

Rata de infectare în București a depășit 16 la mia de locuitori

VIDEO Trucuri pentru a avea mai multe locuri în avion

Efectul certificatului verde obligatoriu în Italia.10.000 de vaccinuri la prima administrare în plus

Pandemia de COVID în Europa: Rusia este cap de afiș la decese. Autoritățile dau vina pe oamenii nevaccinați

AZI, ora 20.00, "InSecuritate", cu Bogdan Nicolae, pe Aleph News & Mediafax.ro. Invitat dr. Radu Țincu, medic primar Terapie Intensivă-Toxicologie

METEO Cum va fi vremea în București în acest weekend

Inedit: Autoritățile din Viena au deschis un cont pe platforma pentru adulți OnlyFans. Protest față de cenzura artei pe rețelele de socializare

Cazurile de COVID la nivel mondial depășesc pragul de 240 de milioane

O nouă zi fără niciun pat liber în țară la ATI

O bucată de istore. Suma cu care va fi scos la licitație microscopul dat de Charles Darwin fiului său

Substanță toxică descoperită în sosul de maioneză. Mai multe loturi au fost retrase din magazine. Cumpărătorii sunt sfătuiți să returneze produsele


Pag.1 Pag.2 Pag.3 Pag.4 Pag.5 Pag.6 Pag.7
Pag.8 Pag.9 Pag.10 Pag.11 Pag.12 Pag.13 Pag.14 Pag.15
Pag.16 Pag.17 Pag.18

Nr. de articole la aceasta sectiune: 1052, afisate in 18 pagini.