Ieteicams, 2020

Redaktora Izvēle

Atšķirība starp OOP un POP

Procedūras orientēta programmēšana (POP) un uz objektu orientēta programmēšana (OOP) abas ir programmēšanas pieejas, kurās programmēšanai tiek izmantota augsta līmeņa valoda. Programmu var rakstīt abās valodās, bet, ja uzdevums ir ļoti sarežģīts, OOP darbojas labi, salīdzinot ar POP. POP „datu drošība” ir apdraudēta, jo dati brīvi pārvietojas programmā, kā arī netiek panākta “kodu atkārtota izmantošana”, kas padara programmu ilgstošu un grūti saprotamu. Lielas programmas rada vairāk kļūdu, un tas palielina atkļūdošanas laiku. Visi šie trūkumi noved pie jaunas pieejas, proti, “uz objektu orientētas programmēšanas”. Objektu orientētas programmēšanas galvenais uzdevums ir “datu drošība”; tas cieši piesaista datus funkcijām, kas darbojas tajā. Tā arī atrisina “koda atkārtotas izmantošanas” problēmu, it kā radītu klasi, var izveidot tās vairākus gadījumus (objektus), kas atkārtoti izmanto klases un locekļu funkcijas, ko definē klase.

Ir dažas citas atšķirības, kuras var izskaidrot ar salīdzinājuma diagrammas palīdzību.


Salīdzinājuma diagramma
Pamats SalīdzinājumamPOPOOP
Pamata
Procedūra / struktūra orientēta.
Objektu orientēta.
PieejaNo augšas uz leju.Bottom-up.
PamatsGalvenā uzmanība tiek pievērsta tam, kā iegūt uzdevumu, ti, programmas procedūru vai struktūru.Galvenā uzmanība tiek pievērsta datu drošībai. Tādējādi tikai objektiem ir atļauts piekļūt klases vienībām.
NodaļaLiela programma ir sadalīta vienībās, ko sauc par funkcijām.Visa programma ir sadalīta objektos.
Vienības piekļuves režīmsNav novērota piekļuves specifikācija.
Piekļuves specifikācija ir "publiska", "privāta", "aizsargāta".
Pārslodze / polimorfismsNe pārslodzes funkcijas, ne operatori.Tā pārslogo funkcijas, konstruktorus un operatorus.
MantojumsViņi nav mantojuma nodrošinājums.Mantojums, kas sasniegts trīs sabiedriskā sektora un aizsargātajos režīmos.
Datu slēpšana un drošībaNav pareiza datu slēpšanas veida, tāpēc dati ir nedrošiDati ir paslēpti trīs veidos: publiski, privāti un aizsargāti. tādējādi palielinās datu drošība.
Datu koplietošanaGlobālie dati tiek dalīti starp programmas funkcijām.Dati tiek dalīti starp objektiem, izmantojot dalībnieku funkcijas.
Draugu funkcijas / klasesNav drauga funkcijas jēdziena.Klases vai funkcija var kļūt par citas klases draugu ar atslēgvārdu "draugs".
Piezīme: atslēgvārdu "draugs" izmanto tikai c + +
Virtuālās klases / funkcijaNav virtuālo klašu jēdziena.Virtuālās funkcijas koncepcija parādās mantojuma laikā.
PiemērsC, VB, FORTRAN, PascalC ++, JAVA, VB.NET, C # .NET.

Objektorientētas programmēšanas definīcija (OOP)

OOP galvenais uzdevums ir slēpt datus no klases locekļiem nesaistītām funkcijām, ko tā uzskata par “kritisku informāciju”. Dati ir cieši saistīti ar klases funkcijām, kas darbojas tajā. Tas neļauj nevienai funkcijai mainīt datus tajā. Objekti sazinās savā starpā, izmantojot dalībfunkcijas, lai piekļūtu saviem datiem.

OOP ir izstrādāts, balstoties uz “objekta”, “klases”, “datu iekapsulēšanas vai abstrakcijas”, “mantojuma” un “polimorfisma / pārslodzes” pamatjēdzienu. Programmā OOP programmas var iedalīt moduļos, sadalot datus un funkcijas, kuras turpmāk var izmantot kā veidnes jaunu moduļu kopiju izveidei, ja nepieciešams.

Procedūru orientētās programmēšanas definīcija (POP)

POP ir tradicionāls programmēšanas veids. Procedūras plānošana ir tāda, kurā galvenā uzmanība tiek pievērsta uzdevuma veikšanai secīgā secībā. Plūsmas shēma organizē programmas kontroles plūsmu. Ja programma ir liela, tā ir strukturēta dažās mazās vienībās, ko sauc par funkcijām, kurām ir kopīgi dati. Šeit rodas bažas par datu drošību, jo programmā pēc nejaušas izmaiņas tiek mainītas funkcijas.

Galvenās atšķirības starp OOP un POP

  1. POP ir uz programmu orientēta programmēšana, OOP ir objektorientēta programmēšana.
  2. POP galvenā uzmanība tiek pievērsta tam, kā iegūt paveikto uzdevumu, un tā seko diagrammai, lai veiktu uzdevumu. OOP galvenā uzmanība tiek pievērsta datu drošībai, jo tikai klases priekšmeti var piekļūt klases atribūtiem vai funkcijai.
  3. Funkcijas ir nelielas lielo programmu vienības, kas veic, lai iegūtu galveno uzdevumu. OOP klasē atribūti un funkcijas tiek sadalītas starp objektiem.
  4. POP nav īpaša piekļuves režīma, lai piekļūtu atribūtiem vai funkcijām programmā, bet OOP ir trīs piekļuves režīmi “publiski”, “privāti”, “aizsargāti”, kurus izmanto kā piekļuves daļu, lai piekļūtu atribūtiem vai funkcijām .
  5. POP neatbalsta pārslodzes / polimorfisma koncepciju. OOP atbalsta pārslodzi / polimorfismu, kas nozīmē to pašu funkciju nosaukuma izmantošanu dažādu funkciju veikšanai. OOP var pārslogot funkcijas, konstruktoru un operatorus.
  6. POP tajā nav mantojuma jēdziena, bet OOP atbalsta mantojumu, kas ļauj izmantot citas klases atribūtu un funkcijas, to pārmantojot.
  7. POP ir mazāk drošs, salīdzinot ar OOP, jo OOP piekļuves specifikators ierobežo piekļuvi atribūtiem vai funkcijām, kas palielina drošību.
  8. POP, ja daži dati ir jāsadala starp visām programmas funkcijām, tas tiek pasludināts globāli ārpus visām funkcijām. OOP datu klases dalībniekam var piekļūt, izmantojot klases locekļu funkcijas.
  9. POP nav drauga funkcijas jēdziena, bet OOP ir drauga funkcijas jēdziens, kas nav klases biedrs, bet tāpēc, ka tas ir drauga biedrs, var piekļūt klases locekļu un dalībnieku funkcijām.
  10. POP nav virtuālo klašu koncepcijas, bet OOP virtuālās funkcijas atbalsta polimorfismu.

Secinājums

POP trūkumi rada nepieciešamību pēc OOP. OOP koriģē POP trūkumus, ieviešot “objekta” un “klases” jēdzienu. Tas uzlabo datu drošību un automātisku objektu inicializāciju un tīrīšanu. OOP ļauj izveidot vairākus objekta gadījumus bez traucējumiem.

Top