„Raktažodžių finalo“ naudojimas su paveldėjimu „Java“

Nors vienas iš „Java“ stipriosios pusės yra paveldėjimo sąvoka, kurioje viena klasė gali kilti iš kitos, kartais pageidautina užkirsti kelią kitos klasės palikimui. Norėdami išvengti paveldėjimo, kurdami klasę naudokite raktinį žodį „galutinis“.

Pvz., Jei klasę greičiausiai naudos kiti programuotojai, galbūt norėsite užkirsti kelią paveldėjimui, jei sukurti poklasiai galėtų sukelti problemų. Tipiškas pavyzdys yra Styginių klasė. Jei norėtume sukurti Styginių poklasį:

viešosios klasės „MyString“ pratęsia stygą {
}

Mes susidurtume su šia klaida:

 negali paveldėti iš galutinio java.lang. Stygos 

Styginių klasės dizaineriai suprato, kad tai nėra kandidatas į palikimą, ir užkirto kelią jo pratęsimui.

Kodėl reikia užkirsti kelią paveldėjimui?

Pagrindinė priežastis, užkertanti kelią paveldėjimas yra įsitikinti, kad klasės elgesys nėra sugadintas poklasio.

Tarkime, kad turime klasės sąskaitą ir ją pratęsiantį poklasį - „OverdraftAccount“. „Class Account“ turi metodą getBalance ():

 viešas dvigubas „getBalance“ ()

{

 grąžinti šią pusiausvyrą;

 } 

instagram viewer

Šioje diskusijos vietoje poklasis „OverdraftAccount“ nenuvertino šio metodo.

(Pastaba: Jei norite diskutuoti naudodamiesi šiomis „Account“ ir „OverdraftAccount“ klasėmis, pažiūrėkite, kaip: poklasis gali būti traktuojamas kaip superklasė).

Sukurkime egzempliorių kiekvienoje iš „Account“ ir „OverdraftAccount“ klasių:

 Paskyra bobsAccount = nauja sąskaita (10);

 „bobsAccount.depositMoney“ (50);

 OverdraftAccount jimsAccount = nauja OverdraftAccount (15.05.500.0.05);

 jimsAccount.depositMoney (50);

 // sukurkite Paskyros objektų masyvą

 // galime įtraukti „jimsAccount“, nes mes 

 // nori ją traktuoti tik kaip sąskaitos objektą

 Paskyra [] sąskaitos = {bobsAccount, jimsAccount};


 // kiekvienoje masyvo sąskaitoje nurodykite likutį

 kam (sąskaita a: sąskaitos)

 {

 System.out.printf („Likutis yra% .2f% n“, a.getBalance ());

 }

 Rezultatas:

 Likutis 60.00

 Likutis yra 65.05 

Čia viskas atrodo taip, kaip tikėtasi. O kas, jei OverdraftAccount pakeis metodą getBalance ()? Tai netrukdo daryti kažką panašaus:

 viešosios klasės OverdraftAccount pratęsia sąskaitą {


 privatus dvigubas overdraftLimit;

 dvigubas overdraftFee;


 // likusi klasės apibrėžtis neįtraukta


 viešas dvigubas „getBalance“ ()

 {

 grįžimas 25.00;

 }

 } 

Jei aukščiau pateiktas kodo pavyzdys bus vykdomas dar kartą, išvestis bus kitokia, nes „thedraBalance“ () elgesį „OverdraftAccount“ klasėje reikalauja „jimsAccount“:

 Rezultatas:

 Likutis 60.00

 Likutis - 25.00 val 

Deja, poklasis „OverdraftAccount“ bus niekada pateikite teisingą likutį, nes paveldėdami mes sugadinome sąskaitos klasės elgesį.

Jei suprojektuosite klasę, kurią naudos kiti programuotojai, visada atsižvelkite į galimų poklasių reikšmes. Dėl šios priežasties stygų klasės negalima pratęsti. Nepaprastai svarbu, kad programuotojai žinotų, jog kurdami „Styginių“ objektą, jie visada elgsis kaip stygos.

Kaip išvengti paveldėjimo

Norėdami sustabdyti klasės pratęsimą, klasės deklaracijoje turi būti aiškiai pasakyta, kad jos negalima paveldėti. Tai pasiekiama naudojant „galutinį“ raktinį žodį:

 viešos galutinės klasės sąskaita {


 } 

Tai reiškia, kad „Account“ klasė negali būti papildoma klasė, o „OverdraftAccount“ klasė nebegali būti jos poklasis.

Kartais norėsite apriboti tik tam tikrą superklasės elgesį, kad išvengtumėte poklasio korupcijos. Pvz., „OverdraftAccount“ vis dar gali būti paskyros poklasis, tačiau turėtų būti užkirstas kelias tam, kad būtų viršesnis „getBalance“ () metodas.

Tokiu atveju metodo deklaracijoje naudokite „galutinį“ raktinį žodį:

 viešosios klasės sąskaita {


 privatus dvigubas balansas;


 // likusi klasės apibrėžtis neįtraukta


 viešas galutinis dvigubas „getBalance“ ()

 {

 grąžinti šią pusiausvyrą;

 } 

 } 

Atkreipkite dėmesį, kaip klasės apibrėžime nenaudojamas galutinis raktinis žodis. Paskyros poklasius galima sukurti, tačiau jie nebegali pakeisti „getBalance ()“ metodo. Bet kuris kodas, paskambinantis šiuo metodu, gali būti tikras, kad jis veiks taip, kaip numatytas originalus programuotojas.