Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Problem] Berechnungen mit Variablen, warum klappt das nicht?

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Problem] Berechnungen mit Variablen, warum klappt das nicht?

    This topic has been deleted. Only users with topic management privileges can see it.
    • rantanplan
      rantanplan last edited by

      Hallo JavaScriptler

      Ich bin auf ein Problem gestoßen, für das ich keine Lösung finde.

      Der folgende Code wurde von Blockly generiert.

      setState("javascript.0.varA"/*varA*/, 10);
      for (var count = 0; count < 10; count++) {
        setState("javascript.0.varB"/*varB*/, (getState("javascript.0.varA").val + 10));
        setState("javascript.0.varC"/*varC*/, (getState("javascript.0.varB").val + 10));
        setState("javascript.0.varD"/*varD*/, (getState("javascript.0.varC").val + 10));
      }
      
      

      Diese doch recht einfachen Rechenoperationen führen nicht zum richtigen Ergebnis.

      Kann mir jemand erklären woran das liegt.

      Grüße

      1 Reply Last reply Reply Quote 0
      • T
        tempestas last edited by

        Was gibt er denn aus?

        Nehme an, die 10 ist nur ein Beispiel?

        Variable A wird ja nur ienmal gesetzt. Damit läuft die For Schleife imho immer wieder aufs Gleiche raus. Wenn das so sein soll, warum 10x machen?

        Im Ergebnis setzt du doch

        A = 10

        Schleife:

        B = 20 (A + 10)

        C = 30 (B + 10)

        D = 40 (C+10)

        Dann wieder Schleife:

        B = 20 ( A + 10, wobei A eben einmalig mit 10 fixiert wurde)

        C = 30

        D = 40

        usw

        1 Reply Last reply Reply Quote 0
        • rantanplan
          rantanplan last edited by

          Hallo tempestas

          Alle Variablen auf 0

          Nach dem 1. Programmstart

          A=10

          B=10

          C=10

          D=10

          Nach dem 2. Programmstart

          A=10 (ok)

          B=20

          C=20

          D=20

          Und die Schleife läuft jedesmal 10x durch.

          1 Reply Last reply Reply Quote 0
          • G
            gst666 last edited by

            > Was gibt er denn aus?
            Vermutlich Unfug.

            Wahrscheinlich werden die Befehle nicht in der Reihenfolge wie erwartet abgearbeitet. Folgendes Programm mag das verdeutlichen:

            setState("javascript.0.varA", 10);
            ... hier eine Pause in der Programmausführung ...
            setState("javascript.0.varA", 20);
            console.log(getState("javascript.0.varA").val);
            

            Das Programm kann entweder als Ergebnis 10 oder 20 ausgeben. Das hängt davon ab, ob das zweite setState schon abgeschlossen ist, bevor die Ausgabe kommt. Die Programmausführung wird bei setState fortgesetzt, bevor der eigentliche Schreibvorgang abgeschlossen ist. In dem Beispiel von rantanplan ist das Problem dasselbe, nur durch die Schleife noch verschärft.

            1 Reply Last reply Reply Quote 0
            • rantanplan
              rantanplan last edited by

              @gst666:

              Das hängt davon ab, ob das zweite setState schon abgeschlossen ist, bevor die Ausgabe kommt. Die Programmausführung wird bei setState fortgesetzt, bevor der eigentliche Schreibvorgang abgeschlossen ist. `
              Wie kann man das denn verhindern?

              Dieses Beispiel macht die Katastrophe noch deutliche.

              for (var count = 0; count < 10; count++) {
                setState("javascript.0.varA"/*varA*/, (getState("javascript.0.varA").val + 10));
                setState("javascript.0.varB"/*varB*/, (getState("javascript.0.varB").val + getState("javascript.0.varA").val + 10));
                setState("javascript.0.varC"/*varC*/, (getState("javascript.0.varC").val + getState("javascript.0.varB").val + 10));
                setState("javascript.0.varD"/*varD*/, (getState("javascript.0.varD").val + getState("javascript.0.varC").val + 10));
              }
              
              

              Grüße

              1 Reply Last reply Reply Quote 0
              • T
                tempestas last edited by

                setStateDelayed mit ansteigendne Intervallen, so dass auf jedenfall der State A geschrieben ist, bevor State B drauf zugreift und ihn für seinen eigenen Wert nutzt

                1 Reply Last reply Reply Quote 0
                • rantanplan
                  rantanplan last edited by

                  @tempestas:

                  setStateDelayed mit ansteigendne Intervallen, so dass auf jedenfall der State A geschrieben ist, bevor State B drauf zugreift und ihn für seinen eigenen Wert nutzt `
                  Da hat man mit Blockly aber schlechte Karten 😢

                  1 Reply Last reply Reply Quote 0
                  • T
                    tempestas last edited by

                    und wenn du die Schleife nur mit Variablen abarbeiten lässt und erst am Ende die finalen Variablen in die States schreibst?

                    1 Reply Last reply Reply Quote 0
                    • AlCalzone
                      AlCalzone Developer last edited by

                      setState hat einen Callback, der aufgerufen wird, sobald der State tatsächlich geschrieben wurde.

                      https://github.com/ioBroker/ioBroker.ja … d#setstate

                      Erst dann kannst du per getState den neuen Wert auslesen.

                      Ob das aber mit Blockly geht... puuuh. Du kannst höchstens in Skript-internen Variablen rechnen und die Ergebnisse per setState rausschreiben. Dann fällt das getState zum Weiterrechnen weg.

                      1 Reply Last reply Reply Quote 0
                      • rantanplan
                        rantanplan last edited by

                        @tempestas:

                        und wenn du die Schleife nur mit Variablen abarbeiten lässt und erst am Ende die finalen Variablen in die States schreibst? `
                        Habe ich auch schon dran gedacht. Elegant ist aber was anderes.

                        Und trotzdem ist so etwas eine böse Falle.

                        Wer kann sagen, wie lange so eine asynchrone Abarbeitung dauert.

                        Wie soll man so etwas Blockly Anfängern veranschaulichen.

                        Alles sehr unbefriedigend 😢

                        Grüße

                        1 Reply Last reply Reply Quote 0
                        • T
                          tempestas last edited by

                          @rantanplan:

                          @tempestas:

                          und wenn du die Schleife nur mit Variablen abarbeiten lässt und erst am Ende die finalen Variablen in die States schreibst? `
                          Habe ich auch schon dran gedacht. Elegant ist aber was anderes.

                          Und trotzdem ist so etwas eine böse Falle.

                          Wer kann sagen, wie lange so eine asynchrone Abarbeitung dauert.

                          Wie soll man so etwas Blockly Anfängern veranschaulichen.

                          Alles sehr unbefriedigend 😢

                          Grüße `

                          Ehrlich gesagt verstehe ich dich da nicht ganz.

                          Warum soll es "eleganter sein", wenn States im Milisekundentakt beschrieben und ausgelesen werden anstatt direkt nur mit Variablen zu Arbeiten? Es gibt doch eh nur ein (bzw vier in deinem Beispiel) Endergebnis(se).

                          Eleganz liegt ja eh im Auge des Betrachters. Was z.B. paul53 skripted ist für mich elegant.

                          1 Reply Last reply Reply Quote 0
                          • inline
                            inline last edited by

                            Ist aber schon klar, dass das Ändern von States potentiell den Update von x angeschlossenen vis GUI's, das Ausführen von Skripten und das Senden via mqtt usw triggert?

                            In so fern sollte man da wirklich etwas vorsichtig mit sein.

                            LG,

                            Ralf

                            1 Reply Last reply Reply Quote 0
                            • uweklatt
                              uweklatt last edited by

                              Hallo,

                              sinnvoll bzw. hilfreich wäre ein zusätzlicher Parameter für setState() mit der Funktion synchrone/asynchrone Ausführung.

                              Dann könnte man sich das Rumgehampel mit Callbacks sparen und der Code macht das, was man erwartet.

                              Tschau

                              Uwe

                              1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 last edited by

                                @uweklatt:

                                und der Code macht das, was man erwartet. `
                                …was Du erwartest.

                                1 Reply Last reply Reply Quote 0
                                • uweklatt
                                  uweklatt last edited by

                                  Hallo Paul,@paul53:

                                  …was Du erwartest. ` Ja, und was die Mehrheit der "Laienprogrammierer" auch erwartet 😉

                                  Tschau

                                  Uwe

                                  1 Reply Last reply Reply Quote 0
                                  • apollon77
                                    apollon77 last edited by

                                    Es ist korrekt das der JavaScript-Adapter an sich alles versucht synchron zu machen.

                                    Welche JS-Version ist im Einsatz?

                                    Wenn aktuell (mind 3.4.x) dann bitte GitHub Issue aufmachen dafür, sonst bitte updaten und neu versuchen

                                    1 Reply Last reply Reply Quote 0
                                    • G
                                      gst666 last edited by

                                      States sind keine Variablen. Falls man wie rataplan rechnen will, so sollte man die States in eine Variable einlesen und dann wenn die Berechnungen abgeschlossen sind, kann man den Wert in einen State wieder zurückschreiben.

                                      Auch wenn es sich platt anhört. States sind keine Variablen.

                                      Wer sich mal gewundert hat, warum man beim auslesen der States am Ende .val angibt, mag folgendes ausprobieren:

                                      console.log(JSON.stringify(getState("obj")));
                                      

                                      obj durch einen gültigen State ersetzen.

                                      Wie man sieht, werden eine Reihe von Daten gespeichert und nicht nur der Wert des eigentlichen States. Bei zu häufiger Verwendung wird das System stark belastet.

                                      1 Reply Last reply Reply Quote 0
                                      • rantanplan
                                        rantanplan last edited by

                                        @tempestas:

                                        Ehrlich gesagt verstehe ich dich da nicht ganz.

                                        ….. Es gibt doch eh nur ein (bzw vier in deinem Beispiel) Endergebnis(se). `
                                        Das Beispiel ist auch nur zur Verdeutlichung und sonst ziemlich sinnlos.

                                        Das Problem tauchte bei einem "Hilfsprojekt" hier im Forum auf.

                                        Zudem lief es bei mir und bei dem User nicht.

                                        Da scheinen auch die Leistungsstärke des verwendeten System eine Rolle zu spielen.

                                        Erst ein "Stresstest" brachte mich auf die Fährte.
                                        @tempestas:

                                        …Warum soll es "eleganter sein", wenn States im Milisekundentakt beschrieben und ausgelesen werden anstatt direkt nur mit Variablen zu Arbeiten?... `
                                        Versetzt Dich mal bitte in einen Blockly-Anfänger.

                                        Grüße

                                        1 Reply Last reply Reply Quote 0
                                        • rantanplan
                                          rantanplan last edited by

                                          @apollon77:

                                          Welche JS-Version ist im Einsatz?

                                          Wenn aktuell (mind 3.4.x) dann bitte GitHub Issue aufmachen dafür, sonst bitte updaten und neu versuchen `
                                          3.4.5 ist bei mir im Einsatz.

                                          GitHub ist für mich leider immer noch eine Blackbox :oops:

                                          Werde es mal bei Trello versuchen.

                                          Grüße

                                          1 Reply Last reply Reply Quote 0
                                          • apollon77
                                            apollon77 last edited by

                                            Github issues anlegen ist simpel.

                                            Github.com , Account anlegen mit E-Mail. Dann im entsprechenden github Projekt (Adapter rechts beim Fragezeichen),dort auf issues und create issue. Text eingeben. Done

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            814
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            9
                                            24
                                            2564
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo