JavaScript ja while(..) {..} silmukka ei toimi

Anonyymi

Tämä alla oleva silmukka ei toimi. Jos sekunnit on alle 10, eli vertailussa toteutuu ehto s < 10. Jolloin jäädään odottamaan sitä että sekunteja kertyy vähintään 10.

var d = new Date();
d.getSeconds();
var s = 0;
do {
s = d.getSeconds();
} while (s < 10)

Silmukasta päästään ulos vain killall "selain" komennolla.

Onko näin että while silmukkaa pyöritetään niin intensiivisesti, ettei kelloa päivitetä silmukan sisällä.

17

105

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      Oikeastaan otsikoin tuon väärin, olisi pitänyt olla:

      JavaScript ja do {..} while(..) . . .

      Vaikka ongelman kannalta asia ei muutu onko while vai do while.

    • Anonyymi
      • Anonyymi

        Tiesin tuon, ajatus oli saada aikaan jotain modulo-operaation tuloksena, vaikka 5 sekunnin välein, mutta tyssäsi tuohon ettei nuo sekunnit päivity tuossa silmukassa.


    • Anonyymi

      En tiedä Javascriptistä mitään, mutta luulen, etteivät sekunnit juokse eteenpäin ts tuo date on kiinteä arvo. Kokeilepa siellä silmukassa ottaa new date ja siitä sekunnit.

      Ja tuolla tavalla kun pyörittää silmukkaa, niin ainakin yhden cpu-ytimen kuorma on satasessa. Kai Javascriptissä joku sleep-toiminto on, mitä voi käyttää?

      • Anonyymi

        "Kai Javascriptissä joku sleep-toiminto on, mitä voi käyttää?"

        Ei varsinaisesti ole.


    • Anonyymi

      ...ja getseconds varmaankin antaa arvoja 0:n ja 59:n väliltä eli kun sekunnit ovat 10-59, se menee heti tuosta läpi.

      • Anonyymi

        Lopetusehto on s < 10. Minuutissa ehdon täyttää sekunnit 0,1,2,3,4,5,6,7,8 ja 9.


      • Anonyymi
        Anonyymi kirjoitti:

        Lopetusehto on s < 10. Minuutissa ehdon täyttää sekunnit 0,1,2,3,4,5,6,7,8 ja 9.

        Aivan, ja juuri silloin tuota silmukkaa ei ohiteta, ja kun kerta ohitusta ei tehdä, ajautuu tuo ikuiseen jumiin, joka on laukastava komentokehotteesta käsin:

        Esimerkki
        killall opera


      • Anonyymi
        Anonyymi kirjoitti:

        Aivan, ja juuri silloin tuota silmukkaa ei ohiteta, ja kun kerta ohitusta ei tehdä, ajautuu tuo ikuiseen jumiin, joka on laukastava komentokehotteesta käsin:

        Esimerkki
        killall opera

        Joo mikäli sekunnit ei päivity, niin jää todennäköisesti ikiluuppiin.

        Tossa yksi esimerkki, joka näyttää kellonaikaa seuraavaan tasaminuuttiin saakka. Kokeiltu nodella, process.stdout ei välttämättä toimi selaimessa.

        const odota = () => {
        const ajastin = setInterval(() => {
        const aika = new Date();
        process.stdout.clearLine();
        process.stdout.write('\r' aika.toLocaleTimeString());
        if(aika.getSeconds() == 0) lopeta();
        }, 1000);
        const lopeta = () => { 
        clearInterval(ajastin);
        console.log();
        }
        }
        odota();


    • Anonyymi

      Niin, noin se ei ainakaan päivity, koska Datea ei päivitetä. Jännän huomion tein, kun kokeilin sellaista, jossa luupin sisällä Date() luodaan aina uudestaan.

      for (let i=0; i<10**9; i ) {
      if (i**7==0) console.log(new Date());
      }

      Tuossa päivämäärä muuttuu, mutta jos kokeillaan tuota sekunnin ottajaa ja sen ehdolla lopettajaa, niin menee jumiin tai en muista nyt kokeilinko ilman,... aa näyttähän se toimivan sekin, kun jättää consoloinnin pois sieltä luupin sisältä, se oli varmaan liian raskas ja sotki koko homman. Tämä toimii:

      console.log("Starting at " new Date());
      while (new Date().getSeconds()<10) {
      //console.log(new Date().getSeconds());
      }
      console.log("done");

      Eli kyllä se päivämäärä päivittyy kun luuppia ajetaan. Se on siis event-luupin ulkopuolinen juttu tuo päivämäärä. Mistä sitten sen temmanneen, vissiin konneen kellosta.

      • Anonyymi

        Eikä ne ihmeellisyydet tuohon lopu, testaappa tämä:

        var d = new Date();
        var n = d.getSeconds();
        console.log(n);

        var d = new Date();
        var s = d.getSeconds;
        console.log(s);

        Milläs selittelet tuon.


      • Anonyymi
        Anonyymi kirjoitti:

        Eikä ne ihmeellisyydet tuohon lopu, testaappa tämä:

        var d = new Date();
        var n = d.getSeconds();
        console.log(n);

        var d = new Date();
        var s = d.getSeconds;
        console.log(s);

        Milläs selittelet tuon.

        Toinen on funktio, koska sulut unohtuivat. Mutta en tiedä voisiko periaatteessa tuossakin erittäin hyvällä tuurilla sekunti vaihtua tuossa suorituksen välillä(?)


      • Anonyymi
        Anonyymi kirjoitti:

        Toinen on funktio, koska sulut unohtuivat. Mutta en tiedä voisiko periaatteessa tuossakin erittäin hyvällä tuurilla sekunti vaihtua tuossa suorituksen välillä(?)

        Mitä?
        Antoiko sinulla molemmat sekuntimäärän?

        Minulla vain tuo n -muutuja tulostaa sekunnit ja s -muutuja tälläistä:
        ƒ getSeconds() { [native code] }


      • Anonyymi
        Anonyymi kirjoitti:

        Mitä?
        Antoiko sinulla molemmat sekuntimäärän?

        Minulla vain tuo n -muutuja tulostaa sekunnit ja s -muutuja tälläistä:
        ƒ getSeconds() { [native code] }

        Joo
        ƒ getSeconds() { [native code] }
        tulee, koska siis kyseessä on itse funktio, eikä sen suoritus. Katso, sulta jäi sulut funktion perästä pois. Vai oliko se tarkoituskin?


      • Anonyymi
        Anonyymi kirjoitti:

        Joo
        ƒ getSeconds() { [native code] }
        tulee, koska siis kyseessä on itse funktio, eikä sen suoritus. Katso, sulta jäi sulut funktion perästä pois. Vai oliko se tarkoituskin?

        Niinpä näkyy, ei ollut tarkoitus, siinäpä se vika sitten olikin.


    • Anonyymi

      5 sekunnin odotus onnistuu näin:
      await new Promise(r => setTimeout(r, 5000));

      • Anonyymi

        Tämä on hyvä.


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

    Luetuimmat keskustelut

    1. Tänään pyörit ajatuksissa enemmän, kun erehdyin lukemaan palstaa

      En saisi, silti toivon että sinä vielä palaat ja otetaan oikeasti selvää, hioituuko särmät ja sulaudummeko yhteen. Vuod
      Ikävä
      22
      5234
    2. Huomenta ihana

      Kauniskasvoinen ihanuus 😘 saan sut vielä
      Ikävä
      25
      4398
    3. Hei rakas...

      Miten on työpäivä sujunut? Rakastan sinua 💗
      Ikävä
      28
      2541
    4. Edelleen sitä on vaikea uskoa

      Että olisit oikeasti rakastunut muhun
      Ikävä
      34
      2264
    5. Toiveikas vai toivoton

      torstai? Ajatuksia?
      Ikävä
      37
      2008
    6. Vitsi mihin menit. Heti takasin.

      Mä näin sut tuu takasin! Oli kiire, niin en ehtiny sin perään!
      Ikävä
      15
      1928
    7. En ole koskaan kokenut

      Ennen mitään tällaista rakastumista. Tiedän että kaipaan sinua varmaan loppu elämän. Toivottavasti ei tarvitsisi vain ka
      Ikävä
      19
      1617
    8. Mukavaa päivää

      Mun rakkauden kohteelle ❤️ toivottavasti olet onnellinen
      Ikävä
      12
      1541
    9. Voi ei! Jari Sillanpää heitti keikan Helsingissä - Hämmästyttävä hetki lavalla...

      Ex-tangokuningas on parhaillaan konserttikiertueella. Hän esiintyi Savoy teatterissa äitienpäivänä. Sillanpää jakoi kons
      Suomalaiset julkkikset
      21
      1277
    10. Kerranki asiat oikein

      Ilkka ja muut pienpuolueeet...teitte hyvän työn kun valitsitte pätevän henkilön virkaan eikä kepulle passelia!! Jatkakaa
      Haapavesi
      10
      1194
    Aihe