Miten NULL voi olla epäselvä asia?

nolliajaykkösiä

http://keskustelu.suomi24.fi/t/9837242/mika-on-null-onko-se-0

Mitä nykään opetetaan, jos joku voi sanoa että "kaikkissa mahdollisissa lukualueissa, joissa nollan paikka voi olla missä tahansa".

Eikö 0 ja NULL ole aina samassa paikassa.
0 lukuna on -1:n ja 1:n välissä.
NULL arvona tarkoittaa ettei sillä ole tällä hetkellä tietotyypin mukaista arvoa. Se kyllä tarkoittaa "ettei ole määritetty arvoa", mutta jotta sen voisi tunnistaa, pitää NULL:lla olla tarkka arvoa eli 0.

24

250

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • c__c

      NULL on 0 C -kielessä. C:ssä se on yleensä ((void *)0). Sekavuus johtuu huonoista kääntäjistä.

    • tämä_sekavuus

      Ongelma koodina:
      int a;
      int *ptr_a = &a;
      jne...
      Nyt jos koodissa lukee jossain kohdassa:
      ptr_a = 0;
      herää epäilys, että tarkoitettiinkin:
      *ptr_a = 0;
      vai tarkoitettiinko sittenkin:
      ptr_a = NULL;

      Kääntäjä ei tuossa pysty auttamaan, jos se ei pysty erottamanaa kummasta tapauksesta on kysymys vaan bugi sujahtaa tuossa hyvin helposti ohjelmaan.

      • fdsfljdlskfj

        Lintteri varoittaa tuosta, asetuksista riippuen heittää herjan ja hylkää buildin.


    • Panteraitp

      Null on suurin virhe mitä on ikinä tapahtunut koodaus maailmassa. Se on luultavasti aiheuttanut miljardien euron vahingot. Null on eri asia riippuen mitä kieltä käytät. Null aiheuttaa niin suurta päänvaivaa että se olisi ollut parempi jättää kokonaan pois.

      • kerni

        Pitäisiköhän sanoa, että huonot/tietämättömät ohjelmoijat ovat aiheuttaneet nuo miljardivahingot, jos sellaisia on ollut olemassa.
        Sitten perusteet ja käsitteet kuntoon: Olet varmaan nähnyt erilaisissa tuotteissa viivakoodeja? Viivakoodien taustallahan on jokin numerosarja. Tuollaisten numerosarjojen suunnittelu on koodausta. Ohjelmointi on ohjelmointia.


    • gfassafs

      "NULL arvona tarkoittaa ettei sillä ole tällä hetkellä tietotyypin mukaista arvoa."

      Ehkä. Riippuu kielestä. Jossain tuo kunnia on suotu esim. undefined:lle. Yleensä null tarkoittaa ennemminkin sitä että muuttujaa ei ole olemassa, eikä sitä että sillä ei ole arvoa. Jossain nämä sitten ovat sotkettu toisiinsa.

      • vaatii_nollausta

        Olen tavannut järjestelmän, jossa undefined-arvo oli -1 pointterissa ja NIL koodissa tarkoitti, että em. muistipaikka on käytettävissä uudelle tiedolle.. ensin luotiin siis null-pointteri ja sitten se etsittiin, jotta siihen voitiin ripustaa jotain ja noi -1:t voitiin sitten jossain välissä siivota pois.. sanomattakin selvää, että tietorakenne ei ihan heti auennut, varsinkin, kun datatyyppi oli -2:een asti täysi..


    • Nimenomaan sen takia null voi olla epäselvä asia että se on monesti sama kuin 0. Varsinkin jos muuttujan tyyppi on joku numero, niin on hankalaa tietää onko sen arvo 0 vai onko sitä lainkaan.

      • kaikkeakuuleekin

        Mitä ihmettä? Null ja 0 (nolla) sama asia? Koitetaan jotakin yksinkertaisempaa esimerkkiä, jospa sitten asia avautuisi.
        Ajattele CD-soitinta (niitäkin vielä on, jos et tiedä mikä on, käy kirpparilla). Jos "pesässä" on tyhjä CD, niin on mielestäsi sama kuin siellä ei ole CD:tä ollenkaan?


    • Joo CD soittimen tapauksessa näin onkin, mutta puhuin tietotyypistä, jolla esitetään numeroita esim. interger

      • null_on_null_ei_0

        Sen kokonaisluvun (integer) tilanteessa null-arvo ei tarkoita sitä, että sen arvo olisi 0 vaan että sillä ei ole arvoa.
        Ajattele seuraavaa: Jostakin havainnosta, joita on vaikkapa 5 kappaletta pitää laskea esim. keskiarvo. Kun on kaksi havaintoa (kolme siis vielä puuttuu), voidaanko laskea viiden havainnon keskiarvo? No ei voida. Jos nyt sitten joku käsittää niin, että tulevat havainnot ovat arvoltaan 0, niin sittenhän jo voikin laskea. Onko tulos oikea ja luotettava jne? Ei ole. Asiasta, jolla ei ole kaikkia arvoja olemassa, ei voida laskea keskiarvoa.


      • Tyhjä_Bitti

        Mielestäni juuri näin kuin esität!
        NULL tarkoittaa TYHJÄÄ, siis ei mitään arvoa (ei numeerista arvoa).


      • devnull0
        Tyhjä_Bitti kirjoitti:

        Mielestäni juuri näin kuin esität!
        NULL tarkoittaa TYHJÄÄ, siis ei mitään arvoa (ei numeerista arvoa).

        "NULL tarkoittaa TYHJÄÄ"

        Ei.

        Se tarkoittaa, että kaikki bitit ovat nollia.


    • Joo Null tarkoittaa tyhjää, mutta monissa toteutuksissa sitä ei voida todella erottaa nollasta, koska ne esitetään samalla tavalla muistissa.

      • Ja tästä yleensä johtuu se että Null tuottaa bugeja


      • dsfdfadfsasa

        Esimerkkejä tuollaisesta toteutuksesta?


      • EiTaidaTulla
        dsfdfadfsasa kirjoitti:

        Esimerkkejä tuollaisesta toteutuksesta?

        Minäkin kyllä haluaisin sen esimerkin nähdä.


    • Esimerkiksi C:sä voi tehä näin:
      "
      if (pointer == 0)
      "
      tai
      "
      int mynull = 0;

      if (pointer == mynull)
      "
      Tämän sijaan
      "
      if(pointer == NULL)
      "

      • Ja nyt jos menet jossain päin koodia räpläämään ton mynullin kanssa, niin ollaan kusessa.


      • Jep. Kuten aiemmin jo kerrottiinkin, esimerkkisi on huonoa koodia ja vika on koodarissa, ei NULL:ssa.


    • Tietysti "nykyaikaisissa" kielissä Null on voitu toteuttaa ns. "Discriminated unions" avulla. (Mitä sitten onkaan suomeksi...)

    • nullikka

      NULL osoittaa muistiosoitteeseen 0000:0000, mutta 0 on muuttujaan asetettu lukuarvo.

    • code_red

      Kyllä joillakin on 0 ja NULL pahasti sekaisin.
      NULL on pelkkä sopimus, jonka todellinen "arvo" voi vaihdella eri alustoilla, ja näin se kannattaakin ottaa. Toisin sanoen NULL tarkoittaa "tyhjän osoittamista", jonka kääntäjät ymmärtää.

      Esim. lause:

      int null_val = NULL;

      on järjetön ja helvetin huonoa koodia. Tosin esim. (void*) kastaus kyllä vähintään herjaa tuosta sijoituksesta ja normitapauksessa ei mee ees läpi. Ja kyllä, "nykyaikaisten kielten" kuten java ja C# objektiviittaukset ovat sisäisesti myös osoittimia sillä erollla, että osoittimen semantiikka ym. "osoitinhelvetti" on hoidettu tausalla eikä koodarin tarvi enää miettiä sitä.

      Toki voi lähteä "syvällisemmin" leikkimään NULL - sijoituksilla ja katsoa kuinka paljon vahinkoa saa aikaan.

    • System.Nullable

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

    Luetuimmat keskustelut

    1. Simula, rakkaus, Aittakumpu

      Milloin tämä rakkaus on roihahtanut? Onko molemmat herätysliikkeen jäseniä - kristillisiä etnonationalisteja ?https://ww
      Perussuomalaiset
      132
      2929
    2. Yläkoulun seksiopas neuvoo harjoittelemaan

      anaaliyhdyntää lämpöisellä ja pitkällä porkkanalla https://www.is.fi/kotimaa/art-2000010859818.html
      Maailman menoa
      255
      2570
    3. Pormestari käräjille?

      Ei mene Puolangalla häpösesti, rinnekeskus&hotelli suljettuna ja käräjäasiana, naudat tapetaan nälkään, poliisi tutkii j
      Puolanka
      64
      1688
    4. Joukko oppilaita terrorisoi koulua Helsingissä niin

      että osa opettajista pelkää töihin tulemista https://www.hs.fi/helsinki/art-2000010857587.html
      Maailman menoa
      191
      1595
    5. Millaista naista ikävöit

      Ulkonäkö/persoona
      Ikävä
      59
      1542
    6. Norjan tilaama koruton raportti mitä NATO-jäsenyys aiheuttaa Suomelle

      Iltasanomat: "Miksi vaikenemme? Asiantuntijoiden mukaan Suomessa ei vieläkään ymmärretä, mitä Nato-jäsenyydestä seuraa
      Maailman menoa
      83
      1209
    7. Minkälainen naama

      kaivatullasi on? 🫠
      Ikävä
      43
      1185
    8. Susta ei saisi nättiä vaikka miten paljon

      meikkaisit. 😁 anna siis sen miehen olla rauhassa! Sivusta tutulta mieheltä
      Ikävä
      77
      1181
    9. Purra esiintyi epäasiallisesti

      Eduskunnassa keskustellaan vaihtoehtobudjeteista. Niistä voi olla monta mieltä ja myönnän niiden olevan osin heikkoja. M
      Pyhäjärvi
      296
      1012
    10. Voisimmeko seuraavan kerran kun

      Nähdään tehdä toisille selväksi että kiinnostaa enemmän kuin kaveri mielessä. Jos keksit vielä keinon niin napakymppi
      Ikävä
      39
      1012
    Aihe