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:

GUVER$N TRĂDĂTOR ȘI VÂNZĂTOR DE ȚARĂ. Guvernul Trădător pregătește să vândă pe mai nimic ce a mai rămas nevândut. Guvernul PNL-UDMR-PLUS-USR a abrogat legea prin care se interzicea vânzarea acțiunilor deținute de stat la companii, timp de doi ani.

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Ă

Cum l-au furat progresiștii lui Biden pe Donald Trump la Alegerile Prezidențiale. Azi furtul din Arizona. Raportul Senatului din Arizona privind auditul alegerilor prezidențiale din districtul Maricopa evidențiază 49.000 de voturi dubioase

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

MOSTENIREA nestiuta a lui Ceausescu! America e SOCATA de ce a descoperit in Romania
ULTIMA ORA: Dusmanii tarii vor sa ascunda adevarul

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

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

Alegeri Germania. Germanii merg azi la urne pentru a decide urmașul Angelei Merkel. Cine sunt favoriții și cum arată posibilele coaliții. S-au deschis urnele LIVE UPDATE

"Au ascuns 4000 de infectați". După ce au ascuns în mod criminal Mii de Morții în noiembrie decembrie anul trecut ca să facă Alegeri, acum gașca progresistă Iohannis, Tătaru, Cîțu ascund Mii de Infectații în București ca să-și țină Congresul

Alegerile prezidențiale din SUA. Donald Trump vrea candideze din nou, în 2024: "Doar doctorul mă poate opri"

AZI, ora 20.00, OFF/ON THE RECORD, cu Sorina Matei, pe Aleph News & Mediafax.ro. Invitat: Csoma Botond, liderul grupului UDMR din Camera Deputaților

Alegeri Germania. Cum funcționează sistemul electoral german și de ce este considerat unul dintre cele mai bune din lume

Crește numărul localităților din Ilfov cu rată de infectare peste 6 la mie

Ion Cristoiu: O enigmă postdecembristă: Preferința lui Klaus Iohannis pentru Florin Cîțu

Nepoata lui Arsenie Boca s-a refugiat într-un azil de bătrâni din Bihor. A învins Covidul, la 90 de ani

Un câine a întrerupt un meci de fotbal. "Dognaldo" a furat mingea, într-un video viral pe Twitter

Teroare în Afganistan: talibanii au spânzurat de o macara un om, în piața din Herat

Deraierea unui tren în statul american Montana s-a lăsat cu victime

Liga 1 la fotbal. FCSB a trecut și de Clinceni. A treia victorie consecutivă în campionat

Lady Huawei a fost primită ca o eroină, la întoarcerea în China

NBA îl amenință pe un baschetbalist din NBA că nu va putea juca pe teren propriu, dacă nu se vaccinează

Tragedie la Baia Mare. O asistentă medicală nevaccinată, cu COVID-19, a murit la 3 zile după decesul fetiței nou-născute

Vaccinare anti-COVID. Experiența unei tinere din Satu Mare, care s-a infectat cu SARS-CoV-2 la mare, după imunizare

Premierul Florin Cîțu vrea să-și salveze Guvernul: Vom discuta cu toate partidele

Membrii echipei lui Orban și-au retras candidaturile pentru BEX. Virgil Guran: "Nu plec nicăieri"

HOROSCOP 26 septembrie 2021. O duminică perfectă pentru trei zodii. Astrele le împlinesc astăzi toate dorințele

Coronavirus în România LIVE UPDATE 26 septembrie 2021. Noul bilanț

Referendum în România. Buzoienii sunt chemați la urne pentru unirea orașului cu o comună

Supriză în boxul mondial. Oleksandr Usyk l-a bătut la puncte pe Anthony Joshua și a devenit noul rege al "greilor"

Alegeri Germania. Germanii merg azi la urne pentru a decide urmașul Angelei Merkel. Cine sunt favoriții și cum arată posibilele coaliții LIVE UPDATE

Doliu în motorsport. Pilotul spaniol Dean Berta Vinales a murit la 15 ani, în accident la Jerez

Dinastia Maldini la AC Milan. Daniel, fiul lui Paolo Maldini, a marcat primul gol pentru "diavoli"

Tenis, Laver Cup. La Boston, Europa conduce Restul Lumii cu 11-1, după a doua zi a competiției

Florin Cîțu și-a anunțat echipa propusă pentru Biroul Executiv al PNL. Cine e mâna dreaptă a președintelui liberal

Gheorghe Flutur, după Congresul PNL: "Trebuie să îi chemăm pe cei din USR PLUS, să facem o analiză, să vedem ce nu a funcționat"

De ce „imunitatea naturală” este o problemă politică pentru regimurile progresiste

Norul de gaze provocat de erupția vulcanului din La Palma a ajuns deasupra Europei

FOCUS: Ce sarcini îl așteaptă pe succesorul Angelei Merkel

Cluj: Mai multe gospodării din Beliș au fost distruse de un incendiu puternic

Marea Britanie, pusă în genunchi de criza transporturilor: rafturi goale în magazine și cozi la benzinării

Se rupe PNL după votul de la Congres? Răspunsul lui Cîțu

Cea mai sexy dansatoare amatoare. O tânără a înebunit internetul cu un DANS EROTIC VIDEO

Metoda "Phoenix", manual de fraudare a Statului. Falsuri, ficțiuni și alte ilegalități în securitatea public-privată a Statului

A doua zi de alegeri în PNL. Liberalii își stabilesc echipa care va conduce partidul alături de Florin Cîțu

Ultimul omagiu pentru pilotul-erou Ion Dobran. Avioanele vor survola pe deasupra Bucureștiului

O ursoaică își învață puiul să se dea pe tobogan, într-un video viral

Rata de infectare este în creștere în Capitală

Coronavirus: 8 orașe și 71 comune au incidență de peste 6 la mie

Klaus Iohannis, prins fără mască la Congresul PNL. Președintele României, în 2020: "În fața unei boli, ori ești precaut, ori ești prost. Una din două"

Coronavirus în România LIVE UPDATE 26 septembrie 2021. Peste 6.300 de cazuri noi, în 24 de ore. Bilanț complet COVID-19

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”

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

ANM: Norul de cenușă vulcanică produs de erupția vulcanului Cumbre Vieja traversează de azi România

Norul de gaze provocat de erupția vulcanului din La Palma este deasupra Europei. Cenușa vulcanică a ajuns și în România

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

Afganistanul, sub teroare. Talibanii execută oameni și le atârnă trupurile în piața publică

Noi doze de vaccin. Peste 700.000 de doze Pfizer BioNTech sosesc în țară

Rezultate referendum. Elvețienii au votat pentru căsătoria civilă și dreptul de a adopta copii al cupluri de același sex

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

Orban nuanțează declarația despre demisie: "Nu vreau să vină Ciolacu la conducerea Camerei"


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 Pag.19 Pag.20 Pag.21 Pag.22 Pag.23

Nr. de articole la aceasta sectiune: 1374, afisate in 23 pagini.