interfacet

mitä käyttöä?

onko joku oikeasti tarvinnut koodatessa interfaceja? itse en ole keksinyt niille mitään käyttöä. jos oot keksinyt jotain käyttöä niin heitä esimerkki.

3

266

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Mika0800

      Interfacet - niitä moni ainakin yrittää tarjota ratkaisuksi - ja joihinkin asioihin ne sopivatkin, omasta tapauksestani en ole ihan vakuuttunut.

      Eli siis...

      Tarkoituksenani on koodata luokkakirjasto http -yhteyksien käsittelyyn, ja säikeessä tehtynä, jotta ohjelman käyttöliittymä ei jumiudu jos lataus netistä hidastelee.

      Mutta: haluan http -lataajaluokkani toimivan sekä j2se että j2me -ympäristössä.

      Valitettavasti http:n toteutus j2me:ssä ja j2se:ssä on erilainen. Oman luokkani tulisi siis toimia silti oikein molemmissa.

      Helpoin ratkaisu olisi ifdef - mutta sehän Javasta kielenä puuttuu kokonaan, ja NetBeansissä se on vain rajoitetusti, eli omassa tarpeessani käyttökelvoton. Netbeansissähän siis VOI tehdä näin:

      //#ifdef Nokia

      //#endif

      //#ifdef SonyEricsson

      //#endif

      //#ifdef Samsung

      //#endif

      mutta valitettavasti EI voi tehdä näin:

      //#ifdef j2me

      //#endif


      //#ifdef j2se

      //#endif


      Tuohon on ehdotettu ratkaisuksi interfaceja.

      Eli niin, että teen 2 minimaalista luokkaa, jotka toinen hoitaa matalan tason funktiokutsut http -yhteyden käsittelemiseksij2me -ympäristössä, toinen taas j2se -ympäristössä, ja molemmat toteuttaisivat saman interfacen, jotta voin sitten pääohjelmasta (joka aina on tehty vain joko j2me tai j2se -ympäristöön, eikä sen tarvitse olla siirrettävänäiden välillä) käsin luoda ilmentymän jommastakummasta näistä 2 luokasta, ja sitten välittääsen interfacena varsinaiselle http -työluokalle, joka tekee varsinaisen työn, nuo 2 apuluokkaa siis vain pyrkii yhtenäistämään http -toteutuksen j2me:n ja j2se:n välillä.

      itse en ole tuosta täysin vakuuttunut, ja tulipa mieleen kokeilla muita keinoja. Koska ajan NetBeansiä linuxissa, voin toki hyödyntää linuxin "tiedostolinkki" -käsitettä:

      ln -s todellinentiedosto luotavanLinkinNimi

      Yritin tuota jo hakemistotasolla mutta se johti vain ongelmiin.

      Sensijaan en ainakaan heti keksi, miksei sama idea toimisi, jos poistan tekemäni hakemistolinkit, koska ne eivät toimi halutulla tavalla (Vika on siis NetBeansin, ei linuxin), ja korvaan ne tiedostotason linkeillä.

      Linkkejä tulee näin enemmän, mutta ainakin pystyn silloin yksityiskohtaisesti hallitsemaan tilanteen.

      Ongelmana hakemistotason linkeissä on se, että NetBeans ottaa väkisin java -projektiin mukaan kaikki .java -tiedostot projektin src -hakemistosta JA sen kaikista alihakemistoista, vaikka joihinkin tiedostoihin ei olisi mitään import -määrettä !

      Kuten todettua, itse ei huvittaisi lähteä interfaceilla ihan muuten vaan, vaan käyttää niitä vain todelliseen tarpeeseen.

      Yksi asia, missä interfacet ovat hyviä:

      Oletetaanpa, että ollaan koodaamassa automaattista puhelinpalvelujärjestelmää (APJ), tunnetaan myös nimellä IVR (Interactive Voice Response).

      Entä, jos halutaan, että sama ohjelmarunko toimii useammalla erilaisella laitteella ?

      Windowsissa näitä asioita perinteisesti yritetään ratkoa laiteajureilla, jotta sovellusohjelmissa ei tarvitsisi miettiä eri laitteiden eroja.

      Yritys tähän suuntaan on Microsoftin TAPI (Telephony Application Programming Interface).

      Valitettavasti TAPI on yksi huonoimmin suunnitelluista ja sekavimmista API:sta mihin olen ikinä törmännyt.

      Yksi mahdollisuus onkin käyttää laitevalmistajien omia ajureita JA ohjelmointirajapintoja, ja jättää tuo TAPI kokonaan hyödyntämättä.

      Näppärä ratkaisu, jolla vältetään TAPIn sekavuus ja huono suunnittelu.

      Mutta: nyt sitten pitää itse ottaa huomioon eri laitteiden erot.

      Yksi hyvä vaihtoehto: määritellä itse juuri sellainen Interface kuin haluaa APJ:n laiterajapinnan toteutukseen, ja käyttää ohjelman logiikkapuolella tätä Interfacea.

      Sitten täytyy tietenkin kirjoittaa kutakin laitetyyppiä kohden luokka, joka toteuttaa kyseisen interfacen, ja keskusetelee suoraan kyseisen laitteen kanssa.

      Itse tosin kirjoittaisin moisen Delphillä, josta myös löytyy Interfacet, ja periytymisen säännötkin ovat samat kuin Javassa:

      Kukin luokka voi periytyä vain yhdestä kantaluokasta (=EI C -tyylistä moinperintää, josta on usein enemmän haittaa kuin hyötyä), mutta kukin luokka voi toteuttaa mielivaltaisen määrän interfaceja. Delphissä on myös mahdollisuus delegoida interfacen toteuttaminen toiselle luokalle, Javan osalta en tiedä, onko myös Javassa sama mahdollisuus.

      Ainakin Delphi on Javaa joustavampi ohjelmointiväline, Javan rajoitukset näköjään tulevat hyvinkin pian vastaan.

      Omana tarkoituksenani onkin käyttää Javaa nimenomaan j2me -ohjelmointiin, sillä kännyköihin ohjelmoitaessa Javalle ei ole vaihtoehtoja.

      Sensijaan esim. Windows -sovellusten tekoon Delphi on joustavampi ja tehokkaampi väline kuin java.

      Pidän kuitenkin j2se -sovellusta helpommin debugattavana kuin j2me. Ja juuri siksi haluankin rakentaa omat Java -luokkani niin, että ne toimivat molemmissa: silloin voin testata ja debugata ne huolellisesti j2se -sovelluksen osana, ja vasta kun olen havainnut sen virheettömästi toimivaksi, siirtää sen osaksi j2me -sovellusta.

      Uskoisin tällaisella strategialla päästävän parempaan ohjelmiston laatuun.

    • tarvin

      Ite tein joskus oman classloaderin ni siinä tein omille luokille interfacen.
      Aikasta harvoin noita tulee käytettyä mut on hyvää tietää et sellanen on olemas jos tarvetta tulee:)

    • Käyttöliittäjä

      Jos interfacet ei ole tulleet tutuksi Javassa eikä niitä ole joutunut käyttämään niin mielestäni silloin kannattaisi kyllä opetella olio-ohjelmointia, suunnittelumalleja ja muita yleisiä, hyviä ohjelmointikäytäntöjä.

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

    Luetuimmat keskustelut

    1. Jens Ihlen (ex Kukka) poika todistaa oikeudessa

      10:49 "Välit ovat olemattomat" Minkälainen isäsi ja sinun välinen suhde on tällä hetkellä? "Minulla ei ole minkäännäkö
      Maailman menoa
      280
      10326
    2. K-kaupassa on mukava käydä, kun ei tarvitse katsella köyhiä

      vasemmistolaisia, joista monet myös varastavat. Mielellään maksaa vähän enemmän tuotteista K-kaupassa, jotka ovat paljon
      Maailman menoa
      245
      6006
    3. Suomeen ei kuulu ihmiset jotka ei halua kätellä toisia ihmisiä, koska tämä on vääräuskoinen

      Nainen joka ei halunnut kätellä Stubbia on selvästi ääripään muslimi, eli sitä sakkia josta niitä ongelmia koituu. Ulos
      Maailman menoa
      173
      5434
    4. PS:n Purra teki -JÄTTI-VELAT

      * * PS:n Purra teki -JÄTTI-VELAT - ! ja jätti MaksuHuolet -Kansan Maksettavaksi -! *
      Maailman menoa
      98
      5066
    5. Vain vasemmistolaiset rakennemuutokset pelastavat Suomen

      Kansaa on ankeutettu viimeiset 30+ vuotta porvarillisella minäminä-talouspolitiikalla, jossa tavalliselta kansalta on ot
      Maailman menoa
      19
      3325
    6. Persut huutaa taas: "kato! muslimi!"

      Persut on lyhyessä ajassa ajaneet läpi kaksi työntekijöiden oikeuksien heikennystä, joita se on aiemmin vastustanut. Pe
      Maailman menoa
      9
      2714
    7. Ootko sä nainen suuttunut

      jostain? Harmi jos tullut väärinkäsityksiä.
      Ikävä
      214
      2622
    8. Nainen, sanotaan että totuus tekee kipeää

      Ehkä mutta se voi olla myös se kaikkein kamalin asia kohdata. Kuplassa on turvallista, kun tietää vähemmän on helpompi.
      Ikävä
      17
      2444
    9. Menen nyt koisimaan

      Ja en ehkä palaa tänne. Asia on nyt loppuunkäsitelty ja totuus tuli ilmi
      Ikävä
      28
      2304
    10. Valtio lopettaa pienituloisten perheiden kylpylälomien tukemisen

      Pienituloiset suomalaiset ovat voineet vuosikymmenten ajan hakea tuettuja lomia terveydellisin, sosiaalisin ja taloudell
      Maailman menoa
      382
      2227
    Aihe