Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Blockly
  5. Verständnisfrage zu Timeout

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    371

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    327

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    946

Verständnisfrage zu Timeout

Geplant Angeheftet Gesperrt Verschoben Blockly
20 Beiträge 4 Kommentatoren 382 Aufrufe 3 Beobachtet
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • G guitardoc

    @codierknecht said in Verständnisfrage zu Timeout:

    Er wartet also quasi darauf, dass die Zeit abläuft oder der timeout abgebrochen wird.

    Hmm, entweder ich habe einen Fehler in meiner Programmierung drin oder Verzögerung.timeout wartet nicht mit der Ausführung des 'mache' Codes bis der Timeout abgelaufen ist.
    Was ich beobachte, ist, dass der Trigger auf das Script ausgelöst wird. Dann wird das Script abgearbeitet und der Timeout ausgelöst. Unmittelbar darauf wird festgestellt, dass der Timeout noch läuft und in der Verzweigung wird false zurückgegeben. Damit wird der Code im 'mache'-Teil nicht ausgeführt und die Abarbeitung geht mit dem Code dahinter weiter.

    Es müsste aber anders sein:
    Vorgehen 1: Wenn der Timeout nicht ausgelöst wird, dann führe den Code (sofort) aus.
    Vorgehen 2: Wenn der Timeout ausgelöst wurde, dann warte bis der Timeout abgelaufen ist und dann arbeite den Code ab.

    Ich habe es mir jetzt so gedacht:

    af079e2a-adee-4156-81de-ec6e1e8d611f-image.png

    Damit sollte es so funktionieren wie ich gedacht hab? Ich kann es im Moment nicht testen, weil ich nicht zu Hause bin, werde es aber heute Abend sicher ausprobieren können. Es sei denn, das ist so völlig verkehrt...

    T Nicht stören
    T Nicht stören
    ticaki
    schrieb am zuletzt editiert von ticaki
    #8

    @guitardoc

    Das ist das Verhalten was erwartet wird.

    Mit Javascript wäre die Antwort wegen Faulheit klar, bei Blockly liegt sie nicht so auf der Hand muß man ja mehr Blockly bewegen :) :

    Bildschirmfoto 2023-09-09 um 13.39.38.png

    Dann muß der Code auch nicht alle 500ms was überprüfen.

    Verzögerung timeout überprüft die variable timeout und stop timeout setzt diese Variable auf null (also false)

    Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

    Spenden

    G 2 Antworten Letzte Antwort
    1
    • T ticaki

      @guitardoc

      Das ist das Verhalten was erwartet wird.

      Mit Javascript wäre die Antwort wegen Faulheit klar, bei Blockly liegt sie nicht so auf der Hand muß man ja mehr Blockly bewegen :) :

      Bildschirmfoto 2023-09-09 um 13.39.38.png

      Dann muß der Code auch nicht alle 500ms was überprüfen.

      Verzögerung timeout überprüft die variable timeout und stop timeout setzt diese Variable auf null (also false)

      G Offline
      G Offline
      guitardoc
      schrieb am zuletzt editiert von
      #9

      @ticaki OK, das macht natürlich Sinn.

      Jetzt eine ganz ganz dumme Frage... Wo kommt bei dir das 'um etwas tun' her? Diesen Funktionsaufruf gibts bei mir nicht. Bei mir sieht das so aus:

      36833da8-6672-4f2e-8ff4-88c2420acecb-image.png

      paul53P 1 Antwort Letzte Antwort
      0
      • G guitardoc

        @ticaki OK, das macht natürlich Sinn.

        Jetzt eine ganz ganz dumme Frage... Wo kommt bei dir das 'um etwas tun' her? Diesen Funktionsaufruf gibts bei mir nicht. Bei mir sieht das so aus:

        36833da8-6672-4f2e-8ff4-88c2420acecb-image.png

        paul53P Offline
        paul53P Offline
        paul53
        schrieb am zuletzt editiert von
        #10

        @guitardoc sagte: Wo kommt bei dir das 'um etwas tun' her?

        @ticaki verwendet eine neuere Version des Javascript-Adapters.

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

        G 1 Antwort Letzte Antwort
        1
        • paul53P paul53

          @guitardoc sagte: Wo kommt bei dir das 'um etwas tun' her?

          @ticaki verwendet eine neuere Version des Javascript-Adapters.

          G Offline
          G Offline
          guitardoc
          schrieb am zuletzt editiert von
          #11

          @paul53 Ahhh... Na da kann ich ja lange suchen... 😁

          Machen denn 'nach' und 'um' wenigstens das gleiche?

          paul53P 1 Antwort Letzte Antwort
          0
          • G guitardoc

            @paul53 Ahhh... Na da kann ich ja lange suchen... 😁

            Machen denn 'nach' und 'um' wenigstens das gleiche?

            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #12

            @guitardoc sagte: Machen denn 'nach' und 'um' wenigstens das gleiche?

            Ja.

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

            1 Antwort Letzte Antwort
            1
            • T ticaki

              @guitardoc

              Das ist das Verhalten was erwartet wird.

              Mit Javascript wäre die Antwort wegen Faulheit klar, bei Blockly liegt sie nicht so auf der Hand muß man ja mehr Blockly bewegen :) :

              Bildschirmfoto 2023-09-09 um 13.39.38.png

              Dann muß der Code auch nicht alle 500ms was überprüfen.

              Verzögerung timeout überprüft die variable timeout und stop timeout setzt diese Variable auf null (also false)

              G Offline
              G Offline
              guitardoc
              schrieb am zuletzt editiert von
              #13

              @ticaki said in Verständnisfrage zu Timeout:

              Bildschirmfoto 2023-09-09 um 13.39.38.png

              Verzögerung timeout überprüft die variable timeout und stop timeout setzt diese Variable auf null (also false)

              Irgendwie funktioniert das so nicht. Der erste Aufruf 'etwas tun' innerhalb des Timeouts funktioniert, da der Timeout unmittelbar davor gestoppt wurde. Der zweite Aufruf im 'sonst'-Zweig funktioniert nicht. Also 'etwas tun' wird da natürlich auch aufgerufen, aber Verzögerung ist nicht Null (false) sondern hat einen numerischen Wert (wie der zustande kommt und was der besagt weiß ich nicht - der Wert ist auch jedesmal anders - vielleicht ist es die aktuelle Uhrzeit, hab ich jetzt nicht getestet). Daher wird dort der 'mache'-Teil nicht ausgeführt.
              Den Timeout ganz am Anfang zu stoppen geht auch nicht, denn da gibt es ihn noch gar nicht und Verzögerung gibt 'undefined' zurück.

              Hmm, jetzt hab ich keine elegante Idee wie ich das mache. Ich könnte höchstens eine Variable setzen und mich selber darum kümmern wann die welchen Wert hat um damit den Aufruf der Funktion zu steuern.

              T 1 Antwort Letzte Antwort
              0
              • G guitardoc

                @ticaki said in Verständnisfrage zu Timeout:

                Bildschirmfoto 2023-09-09 um 13.39.38.png

                Verzögerung timeout überprüft die variable timeout und stop timeout setzt diese Variable auf null (also false)

                Irgendwie funktioniert das so nicht. Der erste Aufruf 'etwas tun' innerhalb des Timeouts funktioniert, da der Timeout unmittelbar davor gestoppt wurde. Der zweite Aufruf im 'sonst'-Zweig funktioniert nicht. Also 'etwas tun' wird da natürlich auch aufgerufen, aber Verzögerung ist nicht Null (false) sondern hat einen numerischen Wert (wie der zustande kommt und was der besagt weiß ich nicht - der Wert ist auch jedesmal anders - vielleicht ist es die aktuelle Uhrzeit, hab ich jetzt nicht getestet). Daher wird dort der 'mache'-Teil nicht ausgeführt.
                Den Timeout ganz am Anfang zu stoppen geht auch nicht, denn da gibt es ihn noch gar nicht und Verzögerung gibt 'undefined' zurück.

                Hmm, jetzt hab ich keine elegante Idee wie ich das mache. Ich könnte höchstens eine Variable setzen und mich selber darum kümmern wann die welchen Wert hat um damit den Aufruf der Funktion zu steuern.

                T Nicht stören
                T Nicht stören
                ticaki
                schrieb am zuletzt editiert von ticaki
                #14

                @guitardoc
                Tja ich sollte nicht ganz so sparsam mit Blocklys sein, im timeout falls mußt du den doppelten Aufruf von timeout verhindern.

                https://forum.iobroker.net/post/1041243

                Ansonsten zeige mir bitte das Blockly oder den erzeugten Javascriptcode.

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                G 1 Antwort Letzte Antwort
                1
                • T ticaki

                  @guitardoc
                  Tja ich sollte nicht ganz so sparsam mit Blocklys sein, im timeout falls mußt du den doppelten Aufruf von timeout verhindern.

                  https://forum.iobroker.net/post/1041243

                  Ansonsten zeige mir bitte das Blockly oder den erzeugten Javascriptcode.

                  G Offline
                  G Offline
                  guitardoc
                  schrieb am zuletzt editiert von
                  #15

                  @ticaki Ja, das muss man dann dort auch noch machen.
                  Aber das Problem war, dass der Aufruf ja NICHT die Blocklys abgearbeitet hat weil Timeout nicht false (null) ist.
                  Oder hab ich was falsch verstanden?

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • G guitardoc

                    @ticaki Ja, das muss man dann dort auch noch machen.
                    Aber das Problem war, dass der Aufruf ja NICHT die Blocklys abgearbeitet hat weil Timeout nicht false (null) ist.
                    Oder hab ich was falsch verstanden?

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #16

                    @guitardoc sagte: NICHT die Blocklys abgearbeitet hat weil Timeout nicht false (null) ist.

                    Dann ist Timeout noch nicht abgelaufen. Blockly zeigen!

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    G 1 Antwort Letzte Antwort
                    1
                    • paul53P paul53

                      @guitardoc sagte: NICHT die Blocklys abgearbeitet hat weil Timeout nicht false (null) ist.

                      Dann ist Timeout noch nicht abgelaufen. Blockly zeigen!

                      G Offline
                      G Offline
                      guitardoc
                      schrieb am zuletzt editiert von guitardoc
                      #17

                      @paul53 Das Problem ist, dass Timeout im Sonst-Zweig ja noch gar nicht gestartet wurde und damit auch nicht ablaufen kann. Wenn von dort in die Funktion 'etwas tun' gesprungen wird, dann ist aber trotzdem Verzögerung.Timeout nicht Null (false) und damit werden die nachfolgenden Blocklys auch nicht abgearbeitet.
                      Es funktioniert nur, wenn aus dem mache.Timout Zweig in die Funktion gesprungen wird. Nur dann ist Verzögerung.Timeout Null.

                      paul53P 1 Antwort Letzte Antwort
                      0
                      • G guitardoc

                        @paul53 Das Problem ist, dass Timeout im Sonst-Zweig ja noch gar nicht gestartet wurde und damit auch nicht ablaufen kann. Wenn von dort in die Funktion 'etwas tun' gesprungen wird, dann ist aber trotzdem Verzögerung.Timeout nicht Null (false) und damit werden die nachfolgenden Blocklys auch nicht abgearbeitet.
                        Es funktioniert nur, wenn aus dem mache.Timout Zweig in die Funktion gesprungen wird. Nur dann ist Verzögerung.Timeout Null.

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #18

                        @guitardoc sagte: dass Timeout im Sonst-Zweig ja noch gar nicht gestartet wurde

                        Dann ist die Variable timeout undefined und die Bedingung "falls nicht Verzögerung timeout" ist ebenfalls erfüllt.

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        G 1 Antwort Letzte Antwort
                        1
                        • paul53P paul53

                          @guitardoc sagte: dass Timeout im Sonst-Zweig ja noch gar nicht gestartet wurde

                          Dann ist die Variable timeout undefined und die Bedingung "falls nicht Verzögerung timeout" ist ebenfalls erfüllt.

                          G Offline
                          G Offline
                          guitardoc
                          schrieb am zuletzt editiert von
                          #19

                          @paul53 Ich kann es jetzt nicht mehr genau nachvollziehen weil ich den Funktionsaufruf jetzt mit Variablen gemacht habe, aber es funktionierte bei mir nicht. Vielleicht lag es daran, dass beim erneuten Triggern dann in Verzögerung.Timeout schon ein Wert drin steht - bin mir jetzt nicht mehr sicher...

                          T 1 Antwort Letzte Antwort
                          0
                          • G guitardoc

                            @paul53 Ich kann es jetzt nicht mehr genau nachvollziehen weil ich den Funktionsaufruf jetzt mit Variablen gemacht habe, aber es funktionierte bei mir nicht. Vielleicht lag es daran, dass beim erneuten Triggern dann in Verzögerung.Timeout schon ein Wert drin steht - bin mir jetzt nicht mehr sicher...

                            T Nicht stören
                            T Nicht stören
                            ticaki
                            schrieb am zuletzt editiert von
                            #20

                            @guitardoc
                            Was wir vorgeschlagen haben funktioniert :) - nächstes Mal zeige bitte mit der Frage das/den Blockly/Javascriptcode.

                            Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                            Spenden

                            1 Antwort Letzte Antwort
                            1

                            Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                            Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                            Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                            Registrieren Anmelden
                            Antworten
                            • In einem neuen Thema antworten
                            Anmelden zum Antworten
                            • Älteste zuerst
                            • Neuste zuerst
                            • Meiste Stimmen


                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            379

                            Online

                            32.8k

                            Benutzer

                            82.8k

                            Themen

                            1.3m

                            Beiträge
                            Community
                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                            ioBroker Community 2014-2025
                            logo
                            • Anmelden

                            • Du hast noch kein Konto? Registrieren

                            • Anmelden oder registrieren, um zu suchen
                            • Erster Beitrag
                              Letzter Beitrag
                            0
                            • Home
                            • Aktuell
                            • Tags
                            • Ungelesen 0
                            • Kategorien
                            • Unreplied
                            • Beliebt
                            • GitHub
                            • Docu
                            • Hilfe