Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • 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. JavaScript
  5. [Gelöst] Funktion wird scheinbar nicht ausgeführt

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.6k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.0k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.3k

[Gelöst] Funktion wird scheinbar nicht ausgeführt

Geplant Angeheftet Gesperrt Verschoben JavaScript
15 Beiträge 4 Kommentatoren 308 Aufrufe 4 Watching
  • Ä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.
  • W Offline
    W Offline
    WolfgangFB
    schrieb am zuletzt editiert von WolfgangFB
    #1

    Ich habe ein Heizungssteuerungsskript und heute morgen habe ich gesehen, dass nicht mehr geheizt wird und frage mich, warum. Ich habe darin eine Funktion "Log", die in eine eigene Logdatei in meine Homeverzeichnis schreibt (Datum,Uhrzeit und Logtext).
    Die entscheidende Funktion ist die folgende:

    function CheckVerdichterNochNichtZuLangeAn(){
        // bei true alles ok, false: wurde nach 120 Minuten abgeschaltet
        var Ergebnis = true;
        Log("CheckVerdichterNochNichtZuLangeAn");
        if (GetVerdichterZustand() == true){
            var VerdichterLaufzeit = GetVerdichterLaufzeit();
            Log("VerdichterLaufzeit = " + VerdichterLaufzeit);
            if (VerdichterLaufzeit >=120){
                Log("Verdichter ist mehr als 120 Minuten gelauf, Zeit fuer eine Pause");
                SchalteAlleRelaisAus("Verdichter mehr als 120 min");
                Ergebnis = false;
                }
        }
        return Ergebnis;
    }
    

    Diese Funktion solte beim Aufruf also zuerst (unabhängig davon was später passiert) in die Logdatei "CheckVerdichterNochNichtZuLangeAn" schreiben.
    Aufgerufen wird diese Funktion in einer anderen Funktion mit folgendem Code:

    ...
        var IstEinRelaiswunschAn = CheckRelaisWunsch();
        Log("IstEinRelaiswunschAn: " + IstEinRelaiswunschAn);
        var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
        Gesamtbedingung = Gesamtbedingung && CheckVerdichterNochNichtZuLangeAn();
        Einschaltbedingung = Einschaltbedingung && CheckVerdichterNochNichtZuLangeAn();
        Einschaltbedingung = Einschaltbedingung && IstEinRelaiswunschAn;
        Log("Einschaltbedingung: " + Einschaltbedingung);
        if (Einschaltbedingung === true){
    
    

    D.h. die Funktion CheckVerdichterNochNichtZuLangeAn wird zweimal direkt hintereinander aufgerufen.

    In der Logdatei sehe ich jetzt aber, dass diese Funktion mal zweimal, mal einmal und mal garnicht aufgerufen wird (könnte man optimieren, darum geht es aber hier nicht).
    Beispiel der Logeinträge:

    08.02 21:46:00 SindAlleRelaisAus: true
    08.02 21:46:00 IstEinRelaiswunschAn: true
    08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
    08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
    08.02 21:46:00 Einschaltbedingung: true
    
    

    (sieht für mich OK aus)

    Zwei Minuten später

    08.02 21:48:00 IstEinRelaiswunschAn: true
    08.02 21:48:00 CheckVerdichterNochNichtZuLangeAn
    08.02 21:48:00 Einschaltbedingung: false
    
    

    (Nur noch einmal ausgeührt)

    09.02 06:36:00 SindAlleRelaisAus: true
    09.02 06:36:00 IstEinRelaiswunschAn: true
    09.02 06:36:00 Einschaltbedingung: false
    09.02 06:36:00 Gesamtbedingung: false
    
    

    ab hier wird die Funktion überhaupt nicht mehr aufgerufen und das Ergebis ist immer false (und damit geht die Heizung nicht mehr an).

    Jetzt die Frage: Wie debugge ich sowas? Im "normalen" Log is nichts auffälliges zu finden. Selbst wenn die Unterfunktionen GetVerdichterZustand() oder GetVerdichterLaufzeit() oder SchalteAlleRelaisAus() irgend ein Problem haben sollte doch zumindest (nach meinem Verständnis) die Zeile

        Log("CheckVerdichterNochNichtZuLangeAn");
    
    

    ausgeführt werden. Die 3 Unterfunktionen sind meiner Meinung nach völlig unspektakulär und funktionieren an anderer Stelle einwandfrei.

    function GetVerdichterZustand(){
        var Ergebnis = (VerdichterPower > 500);
        if (LastVerdichterAusschaltzeit > LastVerdichterEinschaltzeit){// Zeit noch nicht gesetzt
            Ergebnis = false;
        }
        return Ergebnis;
    }
    function GetVerdichterLaufzeit(){
        var Laufzeit = -1;// laeuft nicht
        if (GetVerdichterZustand()){
            Laufzeit = TimeToMinutes(Now - LastVerdichterEinschaltzeit);
        }
        return Laufzeit;
    }
    
    function SchalteAlleRelaisAus(Grund){
        Log("Alle Relais aus wegen " + Grund);
        for (var i = 0; i < Relais.length; i++){
            setState(Relais[i], false);
        }
    }
    

    .

    B ZarelloZ 2 Antworten Letzte Antwort
    0
    • W WolfgangFB

      Ich habe ein Heizungssteuerungsskript und heute morgen habe ich gesehen, dass nicht mehr geheizt wird und frage mich, warum. Ich habe darin eine Funktion "Log", die in eine eigene Logdatei in meine Homeverzeichnis schreibt (Datum,Uhrzeit und Logtext).
      Die entscheidende Funktion ist die folgende:

      function CheckVerdichterNochNichtZuLangeAn(){
          // bei true alles ok, false: wurde nach 120 Minuten abgeschaltet
          var Ergebnis = true;
          Log("CheckVerdichterNochNichtZuLangeAn");
          if (GetVerdichterZustand() == true){
              var VerdichterLaufzeit = GetVerdichterLaufzeit();
              Log("VerdichterLaufzeit = " + VerdichterLaufzeit);
              if (VerdichterLaufzeit >=120){
                  Log("Verdichter ist mehr als 120 Minuten gelauf, Zeit fuer eine Pause");
                  SchalteAlleRelaisAus("Verdichter mehr als 120 min");
                  Ergebnis = false;
                  }
          }
          return Ergebnis;
      }
      

      Diese Funktion solte beim Aufruf also zuerst (unabhängig davon was später passiert) in die Logdatei "CheckVerdichterNochNichtZuLangeAn" schreiben.
      Aufgerufen wird diese Funktion in einer anderen Funktion mit folgendem Code:

      ...
          var IstEinRelaiswunschAn = CheckRelaisWunsch();
          Log("IstEinRelaiswunschAn: " + IstEinRelaiswunschAn);
          var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
          Gesamtbedingung = Gesamtbedingung && CheckVerdichterNochNichtZuLangeAn();
          Einschaltbedingung = Einschaltbedingung && CheckVerdichterNochNichtZuLangeAn();
          Einschaltbedingung = Einschaltbedingung && IstEinRelaiswunschAn;
          Log("Einschaltbedingung: " + Einschaltbedingung);
          if (Einschaltbedingung === true){
      
      

      D.h. die Funktion CheckVerdichterNochNichtZuLangeAn wird zweimal direkt hintereinander aufgerufen.

      In der Logdatei sehe ich jetzt aber, dass diese Funktion mal zweimal, mal einmal und mal garnicht aufgerufen wird (könnte man optimieren, darum geht es aber hier nicht).
      Beispiel der Logeinträge:

      08.02 21:46:00 SindAlleRelaisAus: true
      08.02 21:46:00 IstEinRelaiswunschAn: true
      08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
      08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
      08.02 21:46:00 Einschaltbedingung: true
      
      

      (sieht für mich OK aus)

      Zwei Minuten später

      08.02 21:48:00 IstEinRelaiswunschAn: true
      08.02 21:48:00 CheckVerdichterNochNichtZuLangeAn
      08.02 21:48:00 Einschaltbedingung: false
      
      

      (Nur noch einmal ausgeührt)

      09.02 06:36:00 SindAlleRelaisAus: true
      09.02 06:36:00 IstEinRelaiswunschAn: true
      09.02 06:36:00 Einschaltbedingung: false
      09.02 06:36:00 Gesamtbedingung: false
      
      

      ab hier wird die Funktion überhaupt nicht mehr aufgerufen und das Ergebis ist immer false (und damit geht die Heizung nicht mehr an).

      Jetzt die Frage: Wie debugge ich sowas? Im "normalen" Log is nichts auffälliges zu finden. Selbst wenn die Unterfunktionen GetVerdichterZustand() oder GetVerdichterLaufzeit() oder SchalteAlleRelaisAus() irgend ein Problem haben sollte doch zumindest (nach meinem Verständnis) die Zeile

          Log("CheckVerdichterNochNichtZuLangeAn");
      
      

      ausgeführt werden. Die 3 Unterfunktionen sind meiner Meinung nach völlig unspektakulär und funktionieren an anderer Stelle einwandfrei.

      function GetVerdichterZustand(){
          var Ergebnis = (VerdichterPower > 500);
          if (LastVerdichterAusschaltzeit > LastVerdichterEinschaltzeit){// Zeit noch nicht gesetzt
              Ergebnis = false;
          }
          return Ergebnis;
      }
      function GetVerdichterLaufzeit(){
          var Laufzeit = -1;// laeuft nicht
          if (GetVerdichterZustand()){
              Laufzeit = TimeToMinutes(Now - LastVerdichterEinschaltzeit);
          }
          return Laufzeit;
      }
      
      function SchalteAlleRelaisAus(Grund){
          Log("Alle Relais aus wegen " + Grund);
          for (var i = 0; i < Relais.length; i++){
              setState(Relais[i], false);
          }
      }
      

      .

      B Offline
      B Offline
      Blockmove
      schrieb am zuletzt editiert von
      #2

      Was ist mit den Bedingungen?

      code_text
      var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
      

      Sind diese erfüllt?

      The difference beetween Man and Boys:
      The price of their toys 😀

      1 Antwort Letzte Antwort
      0
      • W WolfgangFB

        Ich habe ein Heizungssteuerungsskript und heute morgen habe ich gesehen, dass nicht mehr geheizt wird und frage mich, warum. Ich habe darin eine Funktion "Log", die in eine eigene Logdatei in meine Homeverzeichnis schreibt (Datum,Uhrzeit und Logtext).
        Die entscheidende Funktion ist die folgende:

        function CheckVerdichterNochNichtZuLangeAn(){
            // bei true alles ok, false: wurde nach 120 Minuten abgeschaltet
            var Ergebnis = true;
            Log("CheckVerdichterNochNichtZuLangeAn");
            if (GetVerdichterZustand() == true){
                var VerdichterLaufzeit = GetVerdichterLaufzeit();
                Log("VerdichterLaufzeit = " + VerdichterLaufzeit);
                if (VerdichterLaufzeit >=120){
                    Log("Verdichter ist mehr als 120 Minuten gelauf, Zeit fuer eine Pause");
                    SchalteAlleRelaisAus("Verdichter mehr als 120 min");
                    Ergebnis = false;
                    }
            }
            return Ergebnis;
        }
        

        Diese Funktion solte beim Aufruf also zuerst (unabhängig davon was später passiert) in die Logdatei "CheckVerdichterNochNichtZuLangeAn" schreiben.
        Aufgerufen wird diese Funktion in einer anderen Funktion mit folgendem Code:

        ...
            var IstEinRelaiswunschAn = CheckRelaisWunsch();
            Log("IstEinRelaiswunschAn: " + IstEinRelaiswunschAn);
            var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
            Gesamtbedingung = Gesamtbedingung && CheckVerdichterNochNichtZuLangeAn();
            Einschaltbedingung = Einschaltbedingung && CheckVerdichterNochNichtZuLangeAn();
            Einschaltbedingung = Einschaltbedingung && IstEinRelaiswunschAn;
            Log("Einschaltbedingung: " + Einschaltbedingung);
            if (Einschaltbedingung === true){
        
        

        D.h. die Funktion CheckVerdichterNochNichtZuLangeAn wird zweimal direkt hintereinander aufgerufen.

        In der Logdatei sehe ich jetzt aber, dass diese Funktion mal zweimal, mal einmal und mal garnicht aufgerufen wird (könnte man optimieren, darum geht es aber hier nicht).
        Beispiel der Logeinträge:

        08.02 21:46:00 SindAlleRelaisAus: true
        08.02 21:46:00 IstEinRelaiswunschAn: true
        08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
        08.02 21:46:00 CheckVerdichterNochNichtZuLangeAn
        08.02 21:46:00 Einschaltbedingung: true
        
        

        (sieht für mich OK aus)

        Zwei Minuten später

        08.02 21:48:00 IstEinRelaiswunschAn: true
        08.02 21:48:00 CheckVerdichterNochNichtZuLangeAn
        08.02 21:48:00 Einschaltbedingung: false
        
        

        (Nur noch einmal ausgeührt)

        09.02 06:36:00 SindAlleRelaisAus: true
        09.02 06:36:00 IstEinRelaiswunschAn: true
        09.02 06:36:00 Einschaltbedingung: false
        09.02 06:36:00 Gesamtbedingung: false
        
        

        ab hier wird die Funktion überhaupt nicht mehr aufgerufen und das Ergebis ist immer false (und damit geht die Heizung nicht mehr an).

        Jetzt die Frage: Wie debugge ich sowas? Im "normalen" Log is nichts auffälliges zu finden. Selbst wenn die Unterfunktionen GetVerdichterZustand() oder GetVerdichterLaufzeit() oder SchalteAlleRelaisAus() irgend ein Problem haben sollte doch zumindest (nach meinem Verständnis) die Zeile

            Log("CheckVerdichterNochNichtZuLangeAn");
        
        

        ausgeführt werden. Die 3 Unterfunktionen sind meiner Meinung nach völlig unspektakulär und funktionieren an anderer Stelle einwandfrei.

        function GetVerdichterZustand(){
            var Ergebnis = (VerdichterPower > 500);
            if (LastVerdichterAusschaltzeit > LastVerdichterEinschaltzeit){// Zeit noch nicht gesetzt
                Ergebnis = false;
            }
            return Ergebnis;
        }
        function GetVerdichterLaufzeit(){
            var Laufzeit = -1;// laeuft nicht
            if (GetVerdichterZustand()){
                Laufzeit = TimeToMinutes(Now - LastVerdichterEinschaltzeit);
            }
            return Laufzeit;
        }
        
        function SchalteAlleRelaisAus(Grund){
            Log("Alle Relais aus wegen " + Grund);
            for (var i = 0; i < Relais.length; i++){
                setState(Relais[i], false);
            }
        }
        

        .

        ZarelloZ Offline
        ZarelloZ Offline
        Zarello
        schrieb am zuletzt editiert von Zarello
        #3

        @wolfgangfb sagte in Funktion wird scheinbar nicht ausgeführt:

            Gesamtbedingung = Gesamtbedingung && CheckVerdichterNochNichtZuLangeAn();
            Einschaltbedingung = Einschaltbedingung && CheckVerdichterNochNichtZuLangeAn();
        

        Ich wage zu behaupten, würdest Du die beiden Seiten der &&-Operatoren vertauschen, also:

            Gesamtbedingung = CheckVerdichterNochNichtZuLangeAn() && Gesamtbedingung;
            Einschaltbedingung = CheckVerdichterNochNichtZuLangeAn() && Einschaltbedingung;
        

        Wird das Skript wie erwartet funktionieren.
        Das ist eine Optimierung, die davon ausgeht, dass die aufgerufene Funktion keine "Nebenwirkung" hat. In diesem Fall hat sie mindestens eine, nämlich der Log-Eintrag und vermutlich auch der Aufruf von SchalteAlleRelaisAus.
        Denn wenn die linke Seite des Ausdrucks bereits false ist, kann der Gesamtausdruck nicht mehr true werden und der Interpreter kann sich die Auswertung der rechten Seite sparen.
        Ich bin mir bei JavaScript nicht 100% sicher, ob es so ist, aber in C/C++ ist das Verhalten genau so definiert.

        Edit:
        Wenn CheckVerdichterNochNichtZuLangeAn immer aufgerufen werden soll würde ich es vermutlich wie folgt ändern, da vermutlich ein doppelter Aufruf der Funktion nicht nötig ist:

            let noch_nicht_zu_lange_an = CheckVerdichterNochNichtZuLangeAn() ;
            Gesamtbedingung = noch_nicht_zu_lange_an && Gesamtbedingung;
            Einschaltbedingung = noch_nicht_zu_lange_an && Einschaltbedingung;
        

        Edit 2:
        Oder:

            if (!CheckVerdichterNochNichtZuLangeAn()) {
                Gesamtbedingung = false;
                Einschaltbedingung = false;
            }
        
        W 1 Antwort Letzte Antwort
        0
        • ZarelloZ Zarello

          @wolfgangfb sagte in Funktion wird scheinbar nicht ausgeführt:

              Gesamtbedingung = Gesamtbedingung && CheckVerdichterNochNichtZuLangeAn();
              Einschaltbedingung = Einschaltbedingung && CheckVerdichterNochNichtZuLangeAn();
          

          Ich wage zu behaupten, würdest Du die beiden Seiten der &&-Operatoren vertauschen, also:

              Gesamtbedingung = CheckVerdichterNochNichtZuLangeAn() && Gesamtbedingung;
              Einschaltbedingung = CheckVerdichterNochNichtZuLangeAn() && Einschaltbedingung;
          

          Wird das Skript wie erwartet funktionieren.
          Das ist eine Optimierung, die davon ausgeht, dass die aufgerufene Funktion keine "Nebenwirkung" hat. In diesem Fall hat sie mindestens eine, nämlich der Log-Eintrag und vermutlich auch der Aufruf von SchalteAlleRelaisAus.
          Denn wenn die linke Seite des Ausdrucks bereits false ist, kann der Gesamtausdruck nicht mehr true werden und der Interpreter kann sich die Auswertung der rechten Seite sparen.
          Ich bin mir bei JavaScript nicht 100% sicher, ob es so ist, aber in C/C++ ist das Verhalten genau so definiert.

          Edit:
          Wenn CheckVerdichterNochNichtZuLangeAn immer aufgerufen werden soll würde ich es vermutlich wie folgt ändern, da vermutlich ein doppelter Aufruf der Funktion nicht nötig ist:

              let noch_nicht_zu_lange_an = CheckVerdichterNochNichtZuLangeAn() ;
              Gesamtbedingung = noch_nicht_zu_lange_an && Gesamtbedingung;
              Einschaltbedingung = noch_nicht_zu_lange_an && Einschaltbedingung;
          

          Edit 2:
          Oder:

              if (!CheckVerdichterNochNichtZuLangeAn()) {
                  Gesamtbedingung = false;
                  Einschaltbedingung = false;
              }
          
          W Offline
          W Offline
          WolfgangFB
          schrieb am zuletzt editiert von
          #4

          @zarello

          Danke. Es war tatsächlich so, dass die Optimierung hier zugeschlagen hat. Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, da muss ich mich bei Javaskript noch umgewöhnen und eben absolut notwendige Funktionsaufrufe separat aufrufen.

          B ZarelloZ 2 Antworten Letzte Antwort
          0
          • W WolfgangFB

            @zarello

            Danke. Es war tatsächlich so, dass die Optimierung hier zugeschlagen hat. Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, da muss ich mich bei Javaskript noch umgewöhnen und eben absolut notwendige Funktionsaufrufe separat aufrufen.

            B Offline
            B Offline
            Blockmove
            schrieb am zuletzt editiert von
            #5

            @wolfgangfb

            Das ist nicht nur bei Javascript so, sondern bei vielen anderen Programmiersprachen auch.

            Aber letztlich war doch nicht die Fehlerursache die Optimierung, sondern weil vorher schon eine Bedingung gefehlt hat. Sonst hätte ja die Optimierung nicht zugeschlagen

            The difference beetween Man and Boys:
            The price of their toys 😀

            1 Antwort Letzte Antwort
            0
            • W WolfgangFB

              @zarello

              Danke. Es war tatsächlich so, dass die Optimierung hier zugeschlagen hat. Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, da muss ich mich bei Javaskript noch umgewöhnen und eben absolut notwendige Funktionsaufrufe separat aufrufen.

              ZarelloZ Offline
              ZarelloZ Offline
              Zarello
              schrieb am zuletzt editiert von
              #6

              @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

              Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, ...

              Bei welcher Sprache ist das so?

              1 Antwort Letzte Antwort
              0
              • W Offline
                W Offline
                WolfgangFB
                schrieb am zuletzt editiert von
                #7

                @zarello sagte in Funktion wird scheinbar nicht ausgeführt:

                @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, ...

                Bei welcher Sprache ist das so?

                Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen". Die habe ich vor Jahren aktiviert weil ich genau über solche Seiteneffekte gestolpert bin und in der Zwischenzeit habbe ich das als selbstverständlich angenommen habe ohne darüber nachzudenken, dass das ja nicht der Standard ist).

                CodierknechtC 1 Antwort Letzte Antwort
                0
                • W WolfgangFB

                  @zarello sagte in Funktion wird scheinbar nicht ausgeführt:

                  @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                  Ich war (bin) es gewohnt, dass Funktionen mit Seiteneffekt auf jeden Fall aufgerufen werden, ...

                  Bei welcher Sprache ist das so?

                  Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen". Die habe ich vor Jahren aktiviert weil ich genau über solche Seiteneffekte gestolpert bin und in der Zwischenzeit habbe ich das als selbstverständlich angenommen habe ohne darüber nachzudenken, dass das ja nicht der Standard ist).

                  CodierknechtC Online
                  CodierknechtC Online
                  Codierknecht
                  Developer Most Active
                  schrieb am zuletzt editiert von Codierknecht
                  #8

                  @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                  Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen"

                  Ist aber auch in Delphi nicht Standard (bin selbst hauptsächlich mit Delphi unterwegs).
                  d7da4f5a-3e5e-4e04-9b1f-5c06e69bfe1b-image.png
                  Du verbiegst damit den Standard, um selbst verursachte Seiteneffekte auszubügeln.
                  Solltest Du Dir auch in Delphi abgewöhnen und in solchen Fällen Statusvariablen verwenden. Die kann man dann beliebig kombinieren.

                  var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
                  var VerdichterChecked = CheckVerdichterNochNichtZuLangeAn();
                  Gesamtbedingung = Gesamtbedingung && VerdichterChecked;
                  Einschaltbedingung = Einschaltbedingung && VerdichterChecked;
                  

                  "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                  Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                  HmIP|ZigBee|Tasmota|Unifi
                  Zabbix Certified Specialist
                  Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                  CodierknechtC W 2 Antworten Letzte Antwort
                  0
                  • CodierknechtC Codierknecht

                    @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                    Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen"

                    Ist aber auch in Delphi nicht Standard (bin selbst hauptsächlich mit Delphi unterwegs).
                    d7da4f5a-3e5e-4e04-9b1f-5c06e69bfe1b-image.png
                    Du verbiegst damit den Standard, um selbst verursachte Seiteneffekte auszubügeln.
                    Solltest Du Dir auch in Delphi abgewöhnen und in solchen Fällen Statusvariablen verwenden. Die kann man dann beliebig kombinieren.

                    var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
                    var VerdichterChecked = CheckVerdichterNochNichtZuLangeAn();
                    Gesamtbedingung = Gesamtbedingung && VerdichterChecked;
                    Einschaltbedingung = Einschaltbedingung && VerdichterChecked;
                    
                    CodierknechtC Online
                    CodierknechtC Online
                    Codierknecht
                    Developer Most Active
                    schrieb am zuletzt editiert von
                    #9

                    @WolfgangFB
                    CheckVerdichterNochNichtZuLangeAn() ist auch ein denkbar schlechter Name für die Methode, wenn die außer Check noch andere Dinge macht.

                    CleanCode ... klingt komisch, hilft aber ungemein.

                    "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                    Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                    HmIP|ZigBee|Tasmota|Unifi
                    Zabbix Certified Specialist
                    Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                    W 1 Antwort Letzte Antwort
                    0
                    • CodierknechtC Codierknecht

                      @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                      Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen"

                      Ist aber auch in Delphi nicht Standard (bin selbst hauptsächlich mit Delphi unterwegs).
                      d7da4f5a-3e5e-4e04-9b1f-5c06e69bfe1b-image.png
                      Du verbiegst damit den Standard, um selbst verursachte Seiteneffekte auszubügeln.
                      Solltest Du Dir auch in Delphi abgewöhnen und in solchen Fällen Statusvariablen verwenden. Die kann man dann beliebig kombinieren.

                      var Gesamtbedingung = (HeizOK || ZeitOK) && HeizungAuto && Notwendig;
                      var VerdichterChecked = CheckVerdichterNochNichtZuLangeAn();
                      Gesamtbedingung = Gesamtbedingung && VerdichterChecked;
                      Einschaltbedingung = Einschaltbedingung && VerdichterChecked;
                      
                      W Offline
                      W Offline
                      WolfgangFB
                      schrieb am zuletzt editiert von
                      #10

                      @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                      @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                      Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen"

                      Ist aber auch in Delphi nicht Standard (bin selbst hauptsächlich mit Delphi unterwegs).

                      Ich weiß, habe ich ja auch geschrieben. "...ohne darüber nachzudenken, dass das ja nicht der Standard ist".

                      CodierknechtC 1 Antwort Letzte Antwort
                      0
                      • CodierknechtC Codierknecht

                        @WolfgangFB
                        CheckVerdichterNochNichtZuLangeAn() ist auch ein denkbar schlechter Name für die Methode, wenn die außer Check noch andere Dinge macht.

                        CleanCode ... klingt komisch, hilft aber ungemein.

                        W Offline
                        W Offline
                        WolfgangFB
                        schrieb am zuletzt editiert von
                        #11

                        @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                        @WolfgangFB
                        CheckVerdichterNochNichtZuLangeAn() ist auch ein denkbar schlechter Name für die Methode, wenn die außer Check noch andere Dinge macht.

                        Na ja, CheckVerdichterNochNichtZuLangeAnUndWennDochDannAusschalten() war mir eben zu lange

                        Aber prinzipiell gebe ich Dir 100% recht, dass saubere Strukturierung und aussagekräftige Namen sehr wertvoll sind. In der Entwicklungsphase kommt es eben ab und an mal vor, dass sich etwas ändert, z.B. aus einer Prozedur eine Funktion wird. In Delphi werde ich dann vom Compiler direkt darauf hingewiesen, das z.B. eine Prozedur keinen Rückgabewert hat, in Javaskript mit den vielen typunsicheren Schreibweisen stolpere ich eben ab und zu noch über solche Dinge.

                        CodierknechtC 1 Antwort Letzte Antwort
                        0
                        • W WolfgangFB

                          @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                          @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                          Borland Delphi (mit eingeschalteter Compileroption "Boolsche Ausdrücke vollständig prüfen"

                          Ist aber auch in Delphi nicht Standard (bin selbst hauptsächlich mit Delphi unterwegs).

                          Ich weiß, habe ich ja auch geschrieben. "...ohne darüber nachzudenken, dass das ja nicht der Standard ist".

                          CodierknechtC Online
                          CodierknechtC Online
                          Codierknecht
                          Developer Most Active
                          schrieb am zuletzt editiert von
                          #12

                          @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                          dass das ja nicht der Standard ist

                          Und ich dachte, Du hättest das auf Programmiersprache im Allgemeinen bezogen.

                          Ich habe mir schon seit längerem versucht anzugewöhnen, dass Funktionen:

                          • Nur noch wirklich eine einzige, simple Aufgabe ausführen
                            "CleanCode does one thing well"
                          • Aussagekräftige Namen erhalten. Auch wenn die z.T. recht sperrig werden können.

                          Wie gesagt - "versucht" - das Ganze ist eher ein Prozess als etwas in Stein gemeißeltes.
                          Da zieht dann immer wieder die Pfadfinderregel: "hinterlasse den Code immer in einem besseren Zustand als Du ihn vorgefunden hast"

                          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                          HmIP|ZigBee|Tasmota|Unifi
                          Zabbix Certified Specialist
                          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                          W 1 Antwort Letzte Antwort
                          0
                          • W WolfgangFB

                            @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                            @WolfgangFB
                            CheckVerdichterNochNichtZuLangeAn() ist auch ein denkbar schlechter Name für die Methode, wenn die außer Check noch andere Dinge macht.

                            Na ja, CheckVerdichterNochNichtZuLangeAnUndWennDochDannAusschalten() war mir eben zu lange

                            Aber prinzipiell gebe ich Dir 100% recht, dass saubere Strukturierung und aussagekräftige Namen sehr wertvoll sind. In der Entwicklungsphase kommt es eben ab und an mal vor, dass sich etwas ändert, z.B. aus einer Prozedur eine Funktion wird. In Delphi werde ich dann vom Compiler direkt darauf hingewiesen, das z.B. eine Prozedur keinen Rückgabewert hat, in Javaskript mit den vielen typunsicheren Schreibweisen stolpere ich eben ab und zu noch über solche Dinge.

                            CodierknechtC Online
                            CodierknechtC Online
                            Codierknecht
                            Developer Most Active
                            schrieb am zuletzt editiert von Codierknecht
                            #13

                            @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                            mit den vielen typunsicheren Schreibweisen

                            :+1:

                            ... ist manchmal echt zum Abgewöhnen ... gruselig :grin:

                            @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                            werde ich dann vom Compiler direkt darauf hingewiesen

                            OT:
                            Für Dinge, die der Compiler nicht mitbekommt, haben wir mittlerweile "FixInsight" im Einsatz.
                            Methode zu lang, zu viele Parameter, leere Exceptions usw. meckert der Compiler ja alles nicht an.


                            c1411236-ea91-4fca-80be-275c5be99edf-image.png

                            @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                            CheckVerdichterNochNichtZuLangeAnUndWennDochDannAusschalten()

                            :grin: :grin: :grin:

                            "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                            Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                            HmIP|ZigBee|Tasmota|Unifi
                            Zabbix Certified Specialist
                            Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                            1 Antwort Letzte Antwort
                            0
                            • CodierknechtC Codierknecht

                              @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                              dass das ja nicht der Standard ist

                              Und ich dachte, Du hättest das auf Programmiersprache im Allgemeinen bezogen.

                              Ich habe mir schon seit längerem versucht anzugewöhnen, dass Funktionen:

                              • Nur noch wirklich eine einzige, simple Aufgabe ausführen
                                "CleanCode does one thing well"
                              • Aussagekräftige Namen erhalten. Auch wenn die z.T. recht sperrig werden können.

                              Wie gesagt - "versucht" - das Ganze ist eher ein Prozess als etwas in Stein gemeißeltes.
                              Da zieht dann immer wieder die Pfadfinderregel: "hinterlasse den Code immer in einem besseren Zustand als Du ihn vorgefunden hast"

                              W Offline
                              W Offline
                              WolfgangFB
                              schrieb am zuletzt editiert von
                              #14

                              @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                              @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                              dass das ja nicht der Standard ist

                              Und ich dachte, Du hättest das auf Programmiersprache im Allgemeinen bezogen.

                              Nein, ich habe eben seit über 20 Jahren fast nichts anderes mer als Delphi (mit meinen Einstellungen) gemacht und fange jetzt mer oder weniger mit Javaskript an.

                              Ich habe mir schon seit längerem versucht anzugewöhnen, dass Funktionen:

                              • Nur noch wirklich eine einzige, simple Aufgabe ausführen
                                "CleanCode does one thing well"

                              Die Frage ist eben, wie man "one thing" definiert... Ich halte mich da eher am modifizierten KISS (Keep it Simple and Stupid Small). Eine Funktion oder Proedur sollte immer auf eine Bildschirmseite passen.
                              Was ich mir partout nicht abgewöhnen kann ist die Mischung aus englischen und deutschen Bezeichnungen.

                              • Aussagekräftige Namen erhalten. Auch wenn die z.T. recht sperrig werden können.

                              Wie gesagt - "versucht" - das Ganze ist eher ein Prozess als etwas in Stein gemeißeltes.
                              Da zieht dann immer wieder die Pfadfinderregel: "hinterlasse den Code immer in einem besseren Zustand als Du ihn vorgefunden hast"

                              Der Satz gefällt mir.

                              CodierknechtC 1 Antwort Letzte Antwort
                              0
                              • W WolfgangFB

                                @codierknecht sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                                @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                                dass das ja nicht der Standard ist

                                Und ich dachte, Du hättest das auf Programmiersprache im Allgemeinen bezogen.

                                Nein, ich habe eben seit über 20 Jahren fast nichts anderes mer als Delphi (mit meinen Einstellungen) gemacht und fange jetzt mer oder weniger mit Javaskript an.

                                Ich habe mir schon seit längerem versucht anzugewöhnen, dass Funktionen:

                                • Nur noch wirklich eine einzige, simple Aufgabe ausführen
                                  "CleanCode does one thing well"

                                Die Frage ist eben, wie man "one thing" definiert... Ich halte mich da eher am modifizierten KISS (Keep it Simple and Stupid Small). Eine Funktion oder Proedur sollte immer auf eine Bildschirmseite passen.
                                Was ich mir partout nicht abgewöhnen kann ist die Mischung aus englischen und deutschen Bezeichnungen.

                                • Aussagekräftige Namen erhalten. Auch wenn die z.T. recht sperrig werden können.

                                Wie gesagt - "versucht" - das Ganze ist eher ein Prozess als etwas in Stein gemeißeltes.
                                Da zieht dann immer wieder die Pfadfinderregel: "hinterlasse den Code immer in einem besseren Zustand als Du ihn vorgefunden hast"

                                Der Satz gefällt mir.

                                CodierknechtC Online
                                CodierknechtC Online
                                Codierknecht
                                Developer Most Active
                                schrieb am zuletzt editiert von
                                #15

                                @wolfgangfb sagte in [Gelöst] Funktion wird scheinbar nicht ausgeführt:

                                Nein, ich habe eben seit über 20 Jahren fast nichts anderes mer als Delphi (mit meinen Einstellungen) gemacht und fange jetzt mer oder weniger mit Javaskript an.

                                Willkommen im Club.

                                Was ich mir partout nicht abgewöhnen kann ist die Mischung aus englischen und deutschen Bezeichnungen.

                                Bei mir steht auch überall GetNewAuftragsnummer oder SaveVersandauftragToDB :grin:

                                "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                                HmIP|ZigBee|Tasmota|Unifi
                                Zabbix Certified Specialist
                                Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                1 Antwort Letzte Antwort
                                0
                                Antworten
                                • In einem neuen Thema antworten
                                Anmelden zum Antworten
                                • Älteste zuerst
                                • Neuste zuerst
                                • Meiste Stimmen


                                Support us

                                ioBroker
                                Community Adapters
                                Donate

                                664

                                Online

                                32.6k

                                Benutzer

                                82.3k

                                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