Header tiedostot

TribaKalle

Hei, olen pitkään tehnyt C ohjelmat siten että on main.cpp tiedosto ja sitten kaikki muut osa alueet jaettu xxxxx.cpp ja xxxxx.h tiedostoihin.

Mutta nyt törmäsin erään pelin lähdekoodiin jossa päätiedosto oli .cc päätteinen (ilmeisesti jotain C# tai vastaavaa tarkoittaa), tämän lisäksi muut osa-alueet olivan PELKÄSTÄÄN .h tiedostoissa, eli funktoiden määrittelyiden lisäksi myös itse funktiot samassa tiedostossa.

Tämä näyttää erittäin selkeältä ja nopealta tavalta mutta kun itse tekee tuolla tapaa ei kääntäjä osaa kääntää koodia, vaan valittaa että header tiedostoissa määritellyt funktiot eivät löydy mistään.

Onko tämä siis nykypäivinä edes mahdollista, minusta olisi vaan tavattoman selkeää lisätä koodit yhteen header tiedostoon sen sijasta että kirjoitat (melkein) samat asiat kahdesta .cpp ja .h tiedostoihin?

15

827

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Tarkoittaa sitä, että peli on koodattu päin helvettiä ja tuollainen on niin sanotusti ongelmien kerjäämistä. Onpas hauskaa jos (kun) tarvitsevat käyttää ristiin osia ja samoja tiedostoja liitetään includella niin käännösaika räjähtää helposti käsiin ja muuta hauskaa. Ei C:tä eikä C :aa ole niin tarkoitettu käytettäväksi. Sitä varten on muita kieliä kuten vaikka Java.

      • wizses125

        Paitsi että header tiedostoissa käytetään #ifndef #endif systeemiä niin niitä ei tarvitse kääntää moneen kertaan joten käännösaika ei muutu miksikään.


      • wizses125 kirjoitti:

        Paitsi että header tiedostoissa käytetään #ifndef #endif systeemiä niin niitä ei tarvitse kääntää moneen kertaan joten käännösaika ei muutu miksikään.

        Itseasiassa kyllä kasvaa ja paljon kun joutuu käymää kaikki läpi aina vähintään kerran.


      • Mee neuvoon sit

        Kirjastofunktio pitää ensinnäkin esitellä jossain ja toisaalta määritellä. Tästä on oiva esimerkki standardi-c:n kaikille vähänkin ohjelmoineille tuttu ja tuiki tarpeellinen ”math.h”. Nyt te ette ole kyllä yhtään jyvällä standardista(kaan) c: n syntaksista.


      • Mee neuvoon sit kirjoitti:

        Kirjastofunktio pitää ensinnäkin esitellä jossain ja toisaalta määritellä. Tästä on oiva esimerkki standardi-c:n kaikille vähänkin ohjelmoineille tuttu ja tuiki tarpeellinen ”math.h”. Nyt te ette ole kyllä yhtään jyvällä standardista(kaan) c: n syntaksista.

        Tietysti pitää. Sitä varten ne otsikkotiedostot ovat. Se koodi sitten pidetään siitä erillään.


      • On ja ei oo noin
        M-Kar kirjoitti:

        Tietysti pitää. Sitä varten ne otsikkotiedostot ovat. Se koodi sitten pidetään siitä erillään.

        Jossä teet siitä tuolla tavalla kirjaston, siitä ei tule mitään: vain atk-jumala voi tietää, missä määrittelysi ovat.


      • ICT-Piru
        On ja ei oo noin kirjoitti:

        Jossä teet siitä tuolla tavalla kirjaston, siitä ei tule mitään: vain atk-jumala voi tietää, missä määrittelysi ovat.

        Ei sitä sorsa-tiedostoa (eli 'määrittelyä') tarvitse olla edes koko koneella, riittää että on header ja linkitettävä binääri ko. kirjastosta. Ei taida sulla olla homma ihan hallussa.


      • ICT-Piru kirjoitti:

        Ei sitä sorsa-tiedostoa (eli 'määrittelyä') tarvitse olla edes koko koneella, riittää että on header ja linkitettävä binääri ko. kirjastosta. Ei taida sulla olla homma ihan hallussa.

        Aivan.


      • Näin se on
        M-Kar kirjoitti:

        Aivan.

        Senkin atk-pölkkypäät: avaja puhuu kirjastoista, joita hän on tuomassa koneelleen. Ei ole vielä mitään käännöksiä siitä eikä linkityksiäkään.


      • ICT-Piru
        Näin se on kirjoitti:

        Senkin atk-pölkkypäät: avaja puhuu kirjastoista, joita hän on tuomassa koneelleen. Ei ole vielä mitään käännöksiä siitä eikä linkityksiäkään.

        Sen verran sekavia ovat sepustukset, ettei oikein saa selvää mistä puhutaan.

        Mutta EI OLE sellaista sääntöä että kirjaston varsinainen toteutus eli lähdekoodi (.c, .cpp, .cc) PITÄÄ olla koneella. Header binääri riittää ja tämä on se ylivoimaisesti yleisin tapa tuoda kirjasto koneelle. Joskus toki kirjasto käännetään itse, kun valmis käännös puuttuu tai halutaan vaikkapa uudempi versio. Tällöin on tulisi olla mukana jonkin projektisysteemin tiedosto(t), jotta ne lähdekoodit löytyy käännöstä varten.

        Harvallapa esimerkiksi tuosta "math.h"-kirjastosta on koneella lähdekoodeja, eivätkä ole edes saatavilla kaikille kääntäjille.


      • Homma atk-hanskassa
        ICT-Piru kirjoitti:

        Sen verran sekavia ovat sepustukset, ettei oikein saa selvää mistä puhutaan.

        Mutta EI OLE sellaista sääntöä että kirjaston varsinainen toteutus eli lähdekoodi (.c, .cpp, .cc) PITÄÄ olla koneella. Header binääri riittää ja tämä on se ylivoimaisesti yleisin tapa tuoda kirjasto koneelle. Joskus toki kirjasto käännetään itse, kun valmis käännös puuttuu tai halutaan vaikkapa uudempi versio. Tällöin on tulisi olla mukana jonkin projektisysteemin tiedosto(t), jotta ne lähdekoodit löytyy käännöstä varten.

        Harvallapa esimerkiksi tuosta "math.h"-kirjastosta on koneella lähdekoodeja, eivätkä ole edes saatavilla kaikille kääntäjille.

        Avaaja tuo sorsia koneelle: pitää kertoa kääntäjälle, missä otsikkotiedostot (*.h, *.hpp) ja missä määrittelyt (*.c, *.cpp) ovat. Ensimmäisen käännöksen jälkeen kääntäjälle tarvitsee jokaisen käännöksen aikana kertoa, missä otsikkotiedostot (*.h, *.hpp), koska kääntäjä tietää, että ohjelmoijan määrittelyt (sorsat) ovat siinä ohjelmointieditorissa apposen auki eikä niitä tarvitse mistään etsiä, mutta tämä on vasta puoli atk-ruokaa. Kertokaas ohjelmoijat, miten homma siitä eteenpäin menee, jos aikoo jonkin tekkeleistään kääntymään ajokelpoiseksi sovelukseksi? Pidettäköön ajokelpoisena soveluksena sellaista, jonka voi resurssienhallinnasta tuplahiirenklikkauksella käynnistää, vaikka sen jälkeen tulisikin käsittämättömiä ajonaikaisia virheitä ja ylivuotoja ja tietokone käynnistyisi sen jäljestä itsestään vikasietotilassa.


    • jksadlkjdsaljasdlkas

      .cc-pääte tarkoittaa samaa kuin .cpp-pääte.

      Se #include "joku-tiedosto.h" lisää vain yksinkertaisesti kyseisen tiedoston sisällön siihen kohtaan koodia. Ei mitään tarkistuksia tai muuta monimutkaista. Ja siksipä siihen käy mikä vaan: #include "foo.cpp" #include "joku.txt".

      Siis on mahdollista työntää tiedostot kaikki includen avulla samaan läjään, jolloin käännöksestä tulee vain YKSI .o-tiedosto. Tämä on hölmöä, sillä pikku muutos yhteen tiedostoon ja kaikki joudutaan kääntämään (ison projektin kääntäminen kestää minuutteja). Ja static-määreellä ei enää merkitystä... Varmaan muitakin ongelmia.

      • Kyllähän tää 70-lukulainen kääntöjärjestelmä alkaa olla aikansa elänyt mutta valitettavasti sitä käyttävät kielet ei ole.

        Kuitenkin, ihan turhaa siitä on valittaa ja tehdä koodi päin persettä. Tuo koodin jakaminen erillisiin otsikko ja kooditiedostoihin on kuitenkin pieni vaiva siinä kaikessa mitä koodin tekemisessä tarvitsee tehdä. Ja jos se on olevinaan suuri vaiva niin sitten kannattaisi miettiä, että onkohan editori ihan varmasti hanskassa.


    • dx

      C :ssa on sellainen huono puoli, että jos käytät templateja (joka on C :n versio genericseistä), pitää kyseinen koodi pistää otsikkotiedostoon. Tämä johtuu siitä, että koodi pitää olla käännösyksikön tiedossa silloin kun sitä templatea lähdetään instantioimaan. Voisiko kirjastosta suurin osa olla jotain templateja?

      • FireOfFeenix

        Valitettavasti c on lähes kaikki mahdollista. Siksi kai syntyi java ja C#, jotka poistavat header tiedostojen käytön ja poistavat kaikki ne hyvät tai huonot ominaisuudet, joita C mihin tahansa melkein pystyvässä maailmassa on. Paitsi muuten, en saanut Visual Basicin syntaksia täydellisesti toimimaan c :lla, vaikka taiteilin macroilla vaikka mitä. Melkein kaikki muu onnistui paitsi if lauseet toimivat c :ssa Visual Basicin syntaksilla. Kokeilkaa joskus ja miettikää sen jälkeen, onko uusia lähdekoodeja ottaessa oikeasti muuta mahdollisuutta kuin tutustua koodiin, jos haluaa sen toimivan jatkossa omalla koneella. Kaikissa tuntemissani lähdekoodeissa on ollut aina jotain outoa ja kummallista - ja aina niissä on joutunut lyömään päätään seinään, ennen kuin on saanut ne toimimaan. Tuo yllä kuvattu esimerkki on arkipäivää.


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

    Luetuimmat keskustelut

    1. Metsäkoneen kuljettaja huuteli tutkijalle

      "voisit kyllä ottaa rintaliivit pois ennen kuin tulet minulle juttelemaan, hän sanoo." https://yle.fi/a/74-20106446 On
      Suomussalmi
      704
      10030
    2. Suomi on täysin sekaisin

      Jo ties monettako päivää hirveä itku ja poru jostain helvetin nilviäisistä. https://www.is.fi/taloussanomat/art-2000010
      Maailman menoa
      412
      4390
    3. Kaikki ei vieläkään usko luontokatoon.

      Suomussalmen Hukkajoella foliohattu metsäkoneen kuljettaja tuhosi tuhansia harvinaisia jokihelmisimpukoita eli raakkuja
      Kajaani
      90
      3016
    4. Sano vain suoraan, että nyt riittää

      ettei kiinnosta. Sano, että lopeta! En ihmettelisi, jos olet saanut tarpeeksesi ja toivot minun ymmärtävän lopettaa. Eh
      Ikävä
      43
      2855
    5. Mari Rantanen asettaa sairaan lapsen edun oman uransa edelle - (tekikö Marin samaa)

      Noin toimii kunnon vastuuntuntoinen äiti, mutta siitäkin nämä mt-ongelmaiset vasemmistolaiset häntä täällä haukkuvat. "
      Maailman menoa
      230
      2668
    6. Ohhoh! Ex-pääministeri Sanna Marinin Joni-rakas paljasti ilouutisen: "Tässä kuussa..."

      Sanna Marin on ollut naimisissa Markus Räikkösen kanssa. Nyt hänen seurassaan on usein julkkishiusmuotoilija Joni Willb
      Kotimaiset julkkisjuorut
      55
      2664
    7. Mitä ajattelet aina

      Kun hän tulee näköpiiriin?
      Ikävä
      153
      1855
    8. Luokatonta toimintaa

      Tyrmistyttävää toimintaa Stora Enson korjuu yrittäjältä Hukkajoella. Täyttä piittaamattomuutta laeista ja luontoarvoista
      Suomussalmi
      71
      1710
    9. Ensimmäisestä kohtaamisesta saakka

      minulla on ollut hämmentynyt olo. Miten voit tuntua siltä, että olisin tuntenut sinut aina? Sinun kanssasi on yhtä aikaa
      Ikävä
      14
      1620
    10. Maailmankuulu homopingviini on kuollut

      Minä niin toivoin että pariskunta olisi saatu kunniavieraiksi ensi kesän Prideen. 💔 "Maailmankuulu homopingviini on k
      Lapua
      6
      1423
    Aihe