define ja const int

C-alkaja

Miksi C:ssä käytetään vakioiden nimeämiseen enemmän muotoa
#define MAX 40
kuin
const int MAX=40;?
Tiedän toki, että tällä ei ole mitään väliä, jos koodaamisessa ei tule virheitä. Kuitenkin, jos koodiin tulisikin juuri tuosta muuttujasta riippuva virhe, niin luulisin, että kääntäjä osaisi antaa enemmän virheilmoitusta jälkimmäisessä tapauksessa, sillä se tietäisi, että MAX on kokonaisluku?

5

965

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • sdgsggd

      Siis...suositellaan käytettäväksi juurikin const int MAX=40...

    • dx

      Siksi koska

      const int MAX = 40;

      ei ole C-kieltä vaan C -kieltä. Osittain syy on historiallinen ja toisaalta define on hieman yleiskäyttöisempi, koska tilalle voi laittaa myös makron tai aliaksen mikä ei oikein const -määreellä onnistu.

    • CCCCCCCC

      1) Syy: Define ei ole muuttuja kun taas const yleensä on (vakio sellainen)

      Tehdäänpä testi, käyttäen kumpaakin tapaa:

      --- ALKAA: use_const.c ---

      const int XX = 40;
      const int YY = 50;

      int main(int argc, char *argv[]) {
      int x = YY*XX;
      }

      --- LOPPUU ---

      vs.

      --- ALKAA: use_define.c ---

      #define XX 40
      #define YY 50

      int main(int argc, char *argv[]) {
      int x = YY*XX;
      }

      --- LOPPUU ---


      Kun nuo ohjelmat käännetään, ja katostaan objdump avulla miltä laskutoimitusrivin (int x = YY*XX) käännös objekti tiedostosta, niin näyttää se seuraavaa omalla kääntäjälläni:

      --- ALKAA: use_const.o ---

      2a: mov 0x4,%eax
      2f: imul 0x0,%eax
      36: mov %eax,0xfffffffc(%ebp)

      0: 28 00
      4: 32 00

      --- LOPPUU ---

      vs.

      --- ALKAA: use_define.o ---

      2a: movl $0x7d0,0xfffffffc(%ebp)

      --- LOPPUU ---


      Elikkä defineä käyttämällä, kääntäjä näki esikääntäjän jälkeen rivin int x = 50*40, ja laski sen valmiiksi, jolloin käännetystä koodista tuli erittäin kompakti. Käyttämällä vakioiksi määriteltyjä muuttujia eli consteja, niin käännös tulos ei ollutkaan yhtä kompakti, vaan käännös meni niin kuin oli kirjoitettu (eli int x = YY*XX), eli muuttujat päätyivät objekti tiedostoon ja lopputuloksena ajonaikaisesti tapahtuva kertolaskun suoritus kahden muuttujan välillä, (ellei sitten lopullinen linkkausvaihe optiomoi tuota kertolaskua pois).


      2) Syy: Define on helppo lisätä header tiedostoon

      Header tiedostoon voi lisätä suoraan esim. "#define XX 30", eikä se tarvitse muuta. Mutta miten menetellä constin kanssa? Jos headeriin lisätään "const int XX = 40;" niin sillon kyseistä headeria ei voi käyttää kuin yhdessä projektin C filessä tai muutoin tulee "multiple defination XX" virhettä. Yksi vaihto ehto ohittaa kyseinen ongelma olisi käyttää headerissa riviä "static const int XX = 40;", mutta toisaalta onko kannattavaa luoda yhdestä vakiosta jokaiselle C tiedostolle omaa paikallista kopiota. Oikea tapa olisi määritellä headeriin vakion prototyyppi, eli "extern const int XX;" rivi, ja sitten yhteen C tiedostoon sen toteutus rivi, eli "const int XX = 40" rivi, mutta toisaalta tämä aiheuttaa sen, että jos halutaan käyttää vain tuota vakiota ohjelmassa, niin kyiseisen vakion toteuksen sisältävä objekti tiedoston on myös linkattava mukaan, (ja toisaalta itse vakion arvoa ei näe ellei sitten omista sitä C tiedostoa jossa on sen toteutus), eli ei riittäkkään pelkkä headeri vakion käyttöön.


      3) Syy: Definella voi myös tulla esiin joitakin virheitä jotka muuton jäisi ajon aikaiseksi

      Kun muuttaa 1:n esimerkkin laskutoimituksen muotoon "YY/XX", ja määritää XX:n nollaksi, niin define toteutuksella kääntäjä herjaa "warning division by zero" koska jako virhe tapahtuu käännöksen aikana, mutta const toteutus menee iloisesti läpi ilman varoituksia. Kummatkin toteutukset tosin kaatuu ajonaikaisesti.

    • 24

      #define MAX 40 on symbolinen vakio

      mites käy jos tuota MAX vakiota laittaa sellaiseen paikkaan johon tuo "40" ei "sovi".
      (vrt. makro, makron parametrien tyyppitarkastus.)

    • Vanha kodari

      Koskapa C:ssä ei toimi
      const int MAX=40;
      int taulukko[MAX];
      C :ssa toimii. Lisäksi C:ssä noita const:eja ei voi käyttää headereissä (tai voi jos sanoo että ne on static).
      Eli summa summarun C:ssä toi const juttuei ole tuettu samallalailla kun C :ssa.

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

    Luetuimmat keskustelut

    1. Trump muka öljyn takia Venezuelaan? Pelkää mustamaalausta

      Kertokaapa mistä tuollainen uutisankka on saanut alkunsta? Näyttäkääpä ne alkuperäiset lähteet, minä en löytänyt mitään
      Maailman menoa
      134
      12055
    2. Kun Arman Alizad puolusti hiihtäjä Vilma Nissilää sanomalla

      "älä välitä sekopäistä Vilma", ja kun siitä kerrottiin täällä, niin sekopäinen mukasuvaitsevainen teki siitä valituksen
      Maailman menoa
      79
      3580
    3. Venezuela on hyvä esimerkki vasemmistolaisten pahuudesta

      Jokainen tietää, että Venezuelassa on pitkään ollut Chavezin ja Maduron vasemmistohallinto. Maan talous on romuttunut,
      Maailman menoa
      91
      2855
    4. Miksei Trump ole kiinnostunut Suomen valloittamisesta?

      Täällähän on enemmän turvetta kuin Norjalla öljyä. Eikö Ttump ole turvenuija?
      Maailman menoa
      34
      1339
    5. Martinalta vahva viesti

      "Suuret unelmat venyttävät sinua, pelottavat vähän ja vievät mukavuusalueen ulkopuolelle. Juuri siellä kasvu tapahtuu. J
      Kotimaiset julkkisjuorut
      264
      1309
    6. Akateemikko Martti Koskenniemi vertaa Trumpia Putiniin

      "-Suomalaisena on syytä olla huolissaan siitä, että Yhdysvallat näin vahvistaa 1800-luvun alkupuolella julistamansa etup
      Maailman menoa
      143
      1265
    7. Jos mies olet oikeasti...?

      Kiinnostunut... Pyydä mut kunnolla treffeille ja laita itsesi likoon. En voi antaa sydäntä jos sinä olet epävarma ja eh
      Ikävä
      112
      1216
    8. Esko Eerikäinen paljastaa järkyttävän muiston lapsuudesta - Isä löytyi alastomana slummista

      Esko Eerikäisen tausta on monikulttuurinen, hän muutti vain 10-vuotiaana yksin kotoaan Kolumbiasta isovanhempiensa luo S
      Suomalaiset julkkikset
      11
      1127
    9. Pitäisikö meidän

      Sitten nähdä ilman että siitä tehdään ongelmaa?
      Ikävä
      80
      1021
    10. Nautitko riidan haastamisesta?

      Itse olen hyvin kärsivällinen ja sopuisa noin yleensä, mutta osaan tarvittaessa olla hankala. Niin metsä vastaa kuin sin
      Sinkut
      184
      913
    Aihe