merkkijonon lukemista

firstbase

Tilanne: merkkijono str1 ---abcd1234----

Miten saan luettua tuosta vain tuon abcd1234 osuuden?

Meneekö kaikissa järjestelmissä ihan vaan strncpy(destination,source 3,8) ?
(Dev-C:llä näkyy ainakin toimivan?)

Onko eri ympäristöissä merkitystä päättääkö merkkijonoja '\0' ?

Miten merkkijonoja luettaessa on paras tapa "ohittaa" merkkejä, jotta löytää oikean kohdan josta alkaa lukea?

Löytyykö hyviä sivuja missä on erilaisia "kikkoja" miten eri tavoilla noita merkkijonojen käsittely funktioita voi käyttää? Minulle tuo source 3 oli ainakin ihan uutta ja puolivahingossa sitä kokeilin.

3

269

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • kdslkadslkas
      • fistbase

        kirjoja aiheesta kyllä on, mutta ei ole koskaan aikaismmin kyseistä asiaa tullut vastaan enkä edes ajatellut tuota osoitinaritmetiikkaa.

        ajatellaanpas sitten tilanne että tuo luettava merkkijono on aina vaikkapa 10 merkkiä (--abcd1234), mutta jos käyttäjä on antanutkin vähemmän merkkejä esim abc tulee merkkijonosta -------abc automaattisesti eli nuo - merkit lisääntyvät tuohon eteen.

        jos nyt luetaan tuota merkkijonoa, miten luetaan - merkit pois?


      • ödölkalkösa
        fistbase kirjoitti:

        kirjoja aiheesta kyllä on, mutta ei ole koskaan aikaismmin kyseistä asiaa tullut vastaan enkä edes ajatellut tuota osoitinaritmetiikkaa.

        ajatellaanpas sitten tilanne että tuo luettava merkkijono on aina vaikkapa 10 merkkiä (--abcd1234), mutta jos käyttäjä on antanutkin vähemmän merkkejä esim abc tulee merkkijonosta -------abc automaattisesti eli nuo - merkit lisääntyvät tuohon eteen.

        jos nyt luetaan tuota merkkijonoa, miten luetaan - merkit pois?

        "kirjoja aiheesta kyllä on, mutta ei ole koskaan aikaismmin kyseistä asiaa tullut vastaan enkä edes ajatellut tuota osoitinaritmetiikkaa."

        Huonot kirjat?

        Eräs tapa, joka tosin tuhoaa alkuperäisen, mutta ota mallia jos ei suoraan sovellu:

        void strip_char(char *str, char ch)
        {
        char *start, *end;

        // etsitään alku
        start = str;
        while (*start == ch)
        start ;

        // str:n loppuun
        end = start;
        while (*end != '\0') end ;

        //etsitään loppu
        do { end--; } while (*end == ch);

        // kopioidaan törkeesti päälle
        while (start "abc--123"

        Poistaa siis alusta ja lopusta, mutta ei välistä. Vertaa:
        http://en.wikipedia.org/wiki/Trim_(programming)


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

    Luetuimmat keskustelut

    1. Mistä puhuitte viimeksi kun näitte

      Kerro yksi aiheista
      Ikävä
      107
      7793
    2. 113
      6064
    3. Se on hyvästi

      Toivottavasti ei tavata.
      Ikävä
      83
      5197
    4. Olenko saanut sinut koukkuun?

      Hyvä. Rakastan sua.
      Ikävä
      139
      4556
    5. Alavuden sairaala

      Säästääkö Alavuden sairaala sähkössä. Kävin Sunnuntaina vast. otolla. Odotushuone ja käytävä jolla lääkäri otti vastaan
      Ähtäri
      11
      3230
    6. Sisäsiittosuus

      Tämän kevään ylioppilaista 90% oli sama sukunimi?
      Suomussalmi
      62
      3024
    7. Miksi sä valitsit

      Juuri minut sieltä?
      Ikävä
      58
      2948
    8. Törkeää toimintaa

      Todella törkeitä kaheleita niitä on Ylivieskassakin. https://www.ess.fi/uutissuomalainen/8570818
      Ylivieska
      10
      2454
    9. Kerro nyt rehellisesti fiilikset?

      Rehellinem fiilis
      Suhteet
      61
      2437
    10. Hei........

      Pelkkä sun näkeminen saa mut hymyilemään pitkin iltaa. Oot niin 🤩😘 Edellinen poistettiin.
      Ikävä
      56
      2066
    Aihe