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

891

    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. Ja taas ammuttu kokkolassa

      Kokkolaisilta pitäisi kerätä pois kaikki ampumaset, keittiöveitset ja kaikki mikä vähänkään paukku ja on terävä.
      Kokkola
      30
      3471
    2. Kukka ampu taas Kokkolassa?

      T. olisi hetkeä aiemmin lähtenyt johonkin. Naapuri kai tekijä J.K., ei paljasjalkainen Kokkolalainen, vaan n. 100km pääs
      Kokkola
      9
      1538
    3. Kuinka kauan

      Olet ollut kaivattuusi ihastunut/rakastunut? Tajusitko tunteesi heti, vai syventyivätkö ne hitaasti?
      Ikävä
      113
      1463
    4. Milli-helenalla ongelmia

      Suomen virkavallan kanssa. Eipä ole ihme kun on etsintäkuullutettu jenkkilässäkin. Vähiin käy oleskelupaikat virottarell
      Kotimaiset julkkisjuorut
      224
      1255
    5. Kun näen sinut

      tulen iloiseksi. Tuskin uskallan katsoa sinua, herätät minussa niin paljon tunteita. En tunne sinua hyvin, mutta jotain
      Ikävä
      34
      893
    6. Purra saksii taas. Hän on mielipuuhassaan.

      Nyt hän leikkaa hyvinvointialueiltamme kymmeniä miljoonia. Sotea romutetaan tylysti. Terveydenhoitoamme kurjistetaan. ht
      Maailman menoa
      242
      883
    7. Yhdelle miehelle

      Mä kaipaan sua niin paljon. Miksi sä oot tommonen pösilö?
      Ikävä
      60
      869
    8. Helena Koivu on äiti

      Mitä hyötyä on Mikko Koivulla kohdella LASTENSA äitiä huonosti . Vie lapset tutuista ympyröistä pois . Lasten kodista.
      Kotimaiset julkkisjuorut
      130
      848
    9. Ja taas kerran hallinto-oikeus että pieleen meni

      Hallinto-oikeus kumosi kunnanhallituksen päätöksen vuokratalojen pääomituksesta. https://sysmad10.oncloudos.com/cgi/DREQ
      Sysmä
      66
      844
    10. Löydänköhän koskaan

      Sunlaista herkkää tunteellista joka jumaloi mua. Tuskin. Siksi harmittaa että asiat meni näin 🥲
      Ikävä
      97
      808
    Aihe