luokkien keksiminen

ei riitä mielikuvitus

Auttakaapa vähän, ei riitä mielikuvitus...

Eli pitäisi tehdä ohjelma cd-levyjen "arkistointiin". Eli yliluokkana se cd-levy ja sille tietenkin jotain attribuutteja, jotka yhteisiä tälle yliluokalle ja niille aliluokille. Sekä tietenkin niitä "palveluita".

Nyt en sitten keksi mitään muita aliluokkia kuin musiikki-cd. Ja tuosta saa vain nuo attribuuteiksi vain esim yhtye/artisti, levyn nimi, jne ne tavalliset.

Sanokaahan mitä tuohon oikein keksisi?

3

537

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • kuunnelma

      keksin yhden lisää kun kattelin penskojen cd:tä.
      kuunnelma.

    • jako ensin data ja audio

      vai pitäisikö lähteä eri kantilta? jako ensin data ja audio...

    • Koodari vaan

      Olio-ohjelmoinnin oppimateriaalissa tyypillisesti esitellään perintä tämän tyyppisellä kouluesimerkillä (pseudosyntaksilla ilmaistuna):

      luokka Elukka
      luokka Nisakas perii Elukka
      luokka Lintu perii Elukka
      luokka Koira perii Nisakas
      jne.

      Käsitteellisesti asia on hyvinkin kuta kuinkin näin. Samoin omassa esimerkissäsi, jossa mietit eri CD-levyjen aliluokkia.

      luokka CD
      luokka MusiikkiCD perii CD
      luokka DataCD perii CD
      jne.

      Tämän tyyppisissä ratkaisuissa tulee hyvin nopeasti ongelmaksi se, että ohjelmaa täytyy muuttaa aina, kun käyttöön tarvitaan uusia CD-tyyppejä - koska ne on ilmaistu luokkina ohjelmakoodissa.

      Kouluesimerkkien vastaisesti luokkia ei tule suunnitella datahierarkian mukaan. Luokat ja niiden mahdollinen periminen tulee suunnitella ohjelman teknisen toteutuksen helpottamiseksi, niin että sillä voi helposti esittää paljon erilaista dataa.

      Ongelman havainnollistamiseksi voi vaikka miettiä, mitä tapahtuu, jos Elukka-kantaluokasta pitää alkaa periä lepakoita, nokkaeläimiä ja muita kummajaisia, joiden olemus edellyttää niiden esittämistä lento-ominaisuuksien tai munimisen kautta. Helvetti odottaa.

      Samoin CD-hierarkiaa miettiessä tulee helposti mieleen, että pian erilaisia DataCD:n perillisiä alkaa ilmaantua mitä mielikuvituksellisimpiin tarkoituksiin. Tai jos MusiikkiCD:stä alkaa periä LastenMusiikkiCD:tä, RnBMusiikkiCD:tä, HeviCD:tä ja herratiesmitä, ollaan pian nesteessä. Ja sitten huomataankin, että kaikkea tätä voi tallentaa myös DVD-levyille. D'oh!

      Kuitenkaan kaikkia mahdollisia attribuutteja (artisti, genre, media, sisältö, otsikko, levytysvuosi, ohjelmatyyppi, jne) ei kannata esittää yhdellä luokalla.

      Mikä siis neuvoksi? Luokkien tuli helpottaa ohjelmointia, eikä vaikeuttaa sitä! Tavoitteenamme on tehdä niin geneeristä koodia kuin suinkin, tekemättä siitä silti monimutkaisempaa kuin on pakko.

      Otetaan teknisempi lähestymistapa, ja käytetään luokkia helpottamaan erilaisten attribuuttikokonaisuuksien määrittelyä.

      Määritellään luokka Attribuutti:
      - jäsen nimi (merkkijono)
      - jäsen arvo (merkkijono)

      Määritellään luokka Tallenne:
      - jäsen tunniste, kokonaisluku
      - jäsen taulukko, jossa nolla tai useampia Attribuutteja

      Näillä eväin data voidaan esittää geneerisesti, ja käyttöliittymä, jonka kautta dataa käsitellään, voidaan niinikään kirjoittaa geneeriseksi. Käyttäjän voi helposti antaa määritellä erilaisia attribuutteja ja antaa niille arvoja. Arvojen tallentaminen tiedostoon tai tietokantaan on triviaalia ja ennen kaikkea myös geneeristä. Koodiin voidaan tehdä valmiiksi erilaisia attribuuttikokonaisuuksia, kuten:

      Musiikkitallenne
      - media: CD, DVD tai käyttäjältä
      - tyyppi: musiikki
      - otsikko: (käyttäjältä)
      - genre: (käyttäjältä)

      Datatallenne
      - media: CD, DVD tai käyttäjältä
      - tyyppi: data
      - otsikko: (käyttäjältä)
      - ohjelmistotyyppi: toimisto, peli, ohjelmointi, apuohjelma tai käyttäjältä

      jne.

      Tämä onkin huomattavasti joustavampaa, ja mahdollistaa jopa sellaisen ohjelman tekemisen, jossa käyttäjä voi käyttöliittymässä määritellä uudentyyppisiä tallenteita!

      Hommaa voi halutessan laajentaa esimerkiksi seuraavasti:

      Määritellään enumeraatio AttribuuttiTyyppi:
      - merkkijono
      - kokonaisluku
      - desimaaliluku
      - totuusarvo (boolean)

      Ja lisätään tämä Attribuutin jäseneksi kuvaamaan, no, attribuutin tyyppiä. Attribuutti voi olla oikeasti tallennettuna merkkijonona, mutta se voi tarvittaessa olla muunnettavissa joksikin muuksi tyypiksi, esimerkiksi kokonaisluvuksi laskutoimituksia varten. AttribuuttiTyyppi ei ole millään muotoa kriittinen luokka tässä.

      Sen sijaan erityisesti hyödyksi voi olla määritellä luokka tai luokkia, jotka osaavat luoda templaatteja erilaisten tallennetyyppien pohjaksi. Nämä käsittelevät niinikään dataa yksinomaan Attribuutti-luokkina. Näitä voi olla valmiiksi ohjelmassa joku sopiva joukko, mutta käyttäjä voisi myös luoda niitä lisää. Voi olla, että templaatit kannattaa luoda ja lukea konfiguraatiotiedostosta. Tämäkin on triviaalia ja täysin geneeristä, kun data on ilmaistu yksinkertaisina Attribuutti-luokkina.

      Huomaa, että perintää ei tarvitse käyttää koko roskassa ehkä lainkaan. Se, että perintä on teknisesti käytettävissä, ei tarkoita sitä, että sitä pitäisi aina käyttää.

      Toivottavasti tästä on apua.

    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Mistä puhuitte viimeksi kun näitte

      Kerro yksi aiheista
      Ikävä
      107
      7793
    2. 113
      6064
    3. Se on hyvästi

      Toivottavasti ei tavata.
      Ikävä
      83
      5197
    4. Olenko saanut sinut koukkuun?

      Hyvä. Rakastan sua.
      Ikävä
      139
      4556
    5. Alavuden sairaala

      Säästääkö Alavuden sairaala sähkössä. Kävin Sunnuntaina vast. otolla. Odotushuone ja käytävä jolla lääkäri otti vastaan
      Ähtäri
      11
      3230
    6. Sisäsiittosuus

      Tämän kevään ylioppilaista 90% oli sama sukunimi?
      Suomussalmi
      62
      3024
    7. Miksi sä valitsit

      Juuri minut sieltä?
      Ikävä
      58
      2948
    8. Törkeää toimintaa

      Todella törkeitä kaheleita niitä on Ylivieskassakin. https://www.ess.fi/uutissuomalainen/8570818
      Ylivieska
      10
      2454
    9. Kerro nyt rehellisesti fiilikset?

      Rehellinem fiilis
      Suhteet
      61
      2437
    10. Hei........

      Pelkkä sun näkeminen saa mut hymyilemään pitkin iltaa. Oot niin 🤩😘 Edellinen poistettiin.
      Ikävä
      56
      2066
    Aihe