Switch-lause

Innokas Koodaaja

Eräässä sulautetussa järjestelmässäni olisi sellainen tilanne, että ohjelman alkaessa pitäisi tulostaa LCD-näytölle tiettyjä muuttujan arvoja, jotka saatiin edellisellä ajokerralla, virtakatkoksen jälkeen. Nämä muuttujan arvot saadaan taulukosta, joka sijaitsee mikro-ohjaimen sisäisessä EEPROM-muistissa. Yritän suorittaa tulostusta käyttäen for-silmukassa pyörivää switch-lausetta seuraavaan tapaan:

for(lcd_eeprom_alustus = 1; lcd_eeprom_alustus

5

912

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • C-noviisi

      Kokeile switch-lauseen default-haaraa ja katso tuleeko suoritus aina sinne. Muuttujien nimet ovat
      aika pitkiä, olisi ehkä helpompi seurata koodia jos käytät lyhempia nimiä.

      default:
      lcd_putsf("9");
      break;

      Niin ja huono tapa on myös sijoittaa useita komentoja samalle riville (nuo break;).

      • Olen edellisen C-noviisin kanssa molemmista tapauksista muuten eri mieltä. Noin yksinkertaiset switschit kannattaa laittaa yhdelle riville luettavuuden parantamiseksi, ja pidemmät muuttujannimet ovat usein parempia kuin lyhyemmät (kuvaavampia). Toki jos niitä joutuu paljon kirjoittelemaan, jne.

        Okei, for-loopissa taulukkoa läpikäytäessä indeksille annetaan perinteisesti yksikirjaiminen muuttuja (alkaen i:stä i, j, k, ... Harvoin enempää tarvitseekaan).

        Mitä itse ongelmaan tulee, jotenkin epäilyttää tuo unsigned charin vertaaminen inttiin, kai sen pitäisi mennä, mutta silti... Eikös jotenkin voisi merkata, että tuo case 0: tarkoittaa juurikini unsigned char 0:aa? En tiedä onko tällä väliä.

        Joka tapauksessa hieman ihmetyttää tuo tarve tulostaa numero stringinä noin. Eikös olisi helpompi vain muuttaa se stringiksi ja tyrkätä menemään ilman mitään valintoja?


    • iziot

      Näyttää epäilyttävästi switchin väärinkäytöltä, etenkin kun käytetään totaali paskaa CodeVision kääntäjää.

      Parempi tapa:

      for(lcd_eeprom_alustus = 1; lcd_eeprom_alustus

      • :)

        Tota switch/case käyttää kokonaislukua ei char:ia, sen takia menee mönkään.
        unsigned char lcd_taulu[14];
        ^^^^^^^^^^^^^^^^^^^^^^^^^^^
        char merkki-> numero = kokonaisluku
        0 = 48
        1 = 49
        2 = 50
        jne...


    • cmies

      Pieni tyyliseikka, tekee tiukempaa koodia kun ei pistä funktiokutsua joka on sama joka caselle sinne switchin sisään:

      const char* s;
      switch (a)
      {
      case 0: s = "0"; break;
      case 1: s = "1"; break;
      //
      }
      blabla_puts(s);

      Sitten, kandee huomata että toi switch on symmetrinen, ton saman asian voi tehdä jotenkin näin:

      char s[2];
      s[0] = '0' a;
      s[1] = 0; // terminate string
      bla_puts(s);

      Noi on vaan ehdotuksia, muokkaa siten että napsahtaa paremmin siihen koodiis kiinni. Mutta tosiaan tollanen switch missä noi menee ihan lineaarisesti noi vaihtoehdot ei o välttämättä paras ratkaisu.

      Ja tosiaan ne puts() kutsut siellä switchin sisällä generoi aika ison kasan kakkaa koodia sinne, mm. koodi joka pistää parametrit esimerkiksi pinoon tulee joka caselle erikseen. Voi olla että kääntäjäs on ajantasalla ja optimoi ton hyvin, mutta miks riskeerata? Teet jotain embedded hommia niin luulisi että muistia ja tehoa ei ole ihan tolkuttomasti. Tää ei ole edes premature optimization vaan yritän opastaa vaan oikeaan suuntaan koodin kirjottamisessa heti ekalla yrityksellä.

      Toivottavasti en vaikuta ihen sekopäältä. Ciao.

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

    Luetuimmat keskustelut

    1. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      202
      4208
    2. SDP haluaa 40 000 nettomaahanmuuttajaa

      SDP:n Suunnanmuutos-vaihtoehtobudjetissa, käy ilmi, että demarit itse asiassa vaativat räjähdysmäistä ”työperäisen” maah
      Maailman menoa
      146
      3768
    3. Orpo: Velkajarrua vastustavaa puoluetta vaikea ajatella hallitukseen

      No Minja Koskelan kommunistipuolue jäi ulos tuosta. Kaikki eduskuntapuolueet vasemmistoliittoa lukuun ottamatta sopivat
      Maailman menoa
      82
      3126
    4. Hienoa! Eduskunta luopui käteisen käytöstä

      Nyt tuo sama muutos pitää saada myös muuhun yhteiskuntaan. Käteistähän ei tarvitse tänä päivänä enää kuin rikolliset.
      Maailman menoa
      43
      1579
    5. Ikävä sinua mies

      Vuosia kuluu, mutta tunteet ei ole hävinnyt. Tasoittuneet toki, kun ei olla nähty. Järki palannut päähän kuitenkin. Se i
      Ikävä
      19
      1418
    6. Sulla on avaimet ja keinot

      Jos haluat jatkaa tutustumista. Itse olen niin jäässä etten pysty tekemään enää mitään. Pidempi keppi johon on helpompi
      Ikävä
      24
      1360
    7. Mikä tämä henkilö mahtaa touhuta Parkanossa

      Kamalaa https://www.ylasatakunta.fi/teksti/pirkanmaan-karajaoikeus-vangitsi-koiran-tappamisesta-epaillyn-6.68.127794.b58
      Parkano
      32
      1357
    8. Orpo loukkaantui fasismiin viittaavasta sanavalinnasta

      Mutta miksi loukkaantui? Orpohan on tehnyt yhteistyötä fasistien kanssa jo vuonna 2019, siis jo neljä vuotta ennen loukk
      Maailman menoa
      27
      1341
    9. Kiinnostaa - ei kiinnosta - kiinnostaapas

      Selittäkää hämmentyneelle miksi miehiä ei ikinä kiinnosta silloin, kun sitä olisi itsekin kiinnostunut? Sitten kun siirt
      Sinkut
      115
      1128
    10. Martina haluaa Marbellaan

      Martinan tekisi mieli ottaa lennot Marbellaan, jossa näkisisi kauniita ja hyväntuulisia ihmisiä. No sitten pitää matkust
      Kotimaiset julkkisjuorut
      215
      1053
    Aihe