Beiträge von Kaliber

    Inwiefern lässt sich das irgendwo noch einsetzen.
    Ich meine, könnte ich z.B anstatt if(!strlen(string)) auch if(string[0] == EOS) einsetzen? Und inwiefern macht das dann auch Sinn? Dann könnte ich ja auch if(!string[0]) einsetzen oder nicht?
    Wo lässt sich EOS wo verwenden?

    Alles korrekt.
    Das prüft quasi nur, ob das erste Zeichen im String das NULL Zeichen ist und wenn dem so ist, dann ist der String leer. Das ist einfach nur etwas schneller und performanter, als strlen zu nutzen :)
    Ein krass ausführliches Tutorial zu Strings gibt es hier: https://forum.sa-mp.com/showthread.php?t=654471


    Wie LeonMrBonnie schon korrekt erklärt hat ist das % Zeichen der Modulo Operator: https://de.wikipedia.org/wiki/Division_mit_Rest

    Naja, man es kann aber sicherlich einrichten, das sobald einmal auf Weiter geklickt wurde, der Schließen Button als Zurück benutzt werden kann.

    Natürlich, ich wollte dich lediglich darauf hinweisen, dass das bei diesem System (deinem Grundsystem) nicht vorhanden war/ist.


    Probiere es mal so (nicht getestet):


    Naja der Tankverbrauch ist ja bei jeden Fahrzeug verscheiden ist schon etwas seltsam wen ich da alles umändern muss.

    Musst du doch nicht.


    Ich habe dir doch die Formel gegeben:


    Vehicle[i][vehFuel] -= floatdiv(Vehicle[i][Verbrauch], 1000);


    Egal was der Verbrauch ist (solange du ihn in L auf 100km angibst) wird der so umgerechnet, dass alle 100m das richtige abgezogen wird.

    Vehicle[i][vehKMStand] += 0.1;

    Das ist Zeile 15, da hat er also 100m zurückgelegt, da kannst du also Ansetzen mit dem Abziehen:


    Das ist einfacher Dreisatz:



    100km = 13.1L
    1km = 0.131L
    //Ergo
    1000m = 0.131L
    100m = 0.0131L (oder eben 13.1ml)


    Wir gehen also davon aus, dass Vehicle[i][Verbrauch] = 13.1 ist.


    Dann könntest du das in Zeile 16 z.B. einfach so abziehen:


    Vehicle[i][vehFuel] -= floatdiv(Vehicle[i][Verbrauch], 1000);


    Dann würde er alle 100m 13.1ml verbrauchen.


    Wenn das nicht zu frequentiert ist, einfach auf 50 oder 10m gehen.


    Einfach mit dem Dreisatz umrechnen ;)

    Dann setze mal prints und schau, wo er sich aufhängt :o
    Und aktivier evtl mal den Mysql Log


    //Edit:
    Habe es mal bei mir lokal getestet und es funzt einwandfrei.
    Bekomme keine Fehler oder dergleichen und habe exakt deine Datenstruktur gewählt.


    Das war der Code, den ich verwendet habe:



    Aber mir ist schleierhaft wie du die playerid an das PlayerQuery übergibst (Zeile 36)


    und wie fragst du die rows ab?


    Ich kenne halt nicht all deinen Code.


    An dem Stück Code liegt der Fehler zumindest nicht :)

    Hmmm, dann schreib es mal so:



    Ich bin mir ziemlich sicher, dass es ein Größen Problem ist.

    Mach mal das else eine Zeile drunter.

    Der Fehler ist es darf zwischen einem if und einem else kein Statement stehen.


    Sprich:


    C
    //Das okay
    if(a) {...bla}
    else {...bla}
    
    
    //Das nicht okay
    if(a) {...bla}
    Funktion();
    else {...bla} //Weil worauf bezieht sich jetzt das else?!


    Also so schreiben:



    Ahhh du speicherst die Sekunden :D


    Daran habe ich nicht gedacht, schreibe mal den Mittleren Teil so:


    Pack mal crashdetect rein und zeig mal deine Tabellen Struktur :)


    Und hast du mal Beispieldaten? Also mich interessiert die Länge der einzelnen Felder...


    //Edit:


    PS: Zeile 21 mal so schreiben:


    ShowPlayerDialog(playerid, D_PP, DIALOG_STYLE_TABLIST_HEADERS, "Spielerprotokoll", str, "Schließen", ((rows%10 == 0)?("Weiter"):("")));

    Geht sowas noch ?

    Die Frage ist doch eher, sollte es so gemacht werden?


    Und die Antwort ist ganz klar nein.


    Das hat seine Gründe, wieso diese Asynchronität eingeführt wurde.


    Natürlich muss man jetzt etwas umdenken, weil man es davor gewohnt war synchron zu arbeiten.


    Du brauchst den Wert nicht, du kannst einfach den Code, der danach kommt in den Callback packen und ihn da weiter ausführen lassen.


    Und dort quasi den Wert verarbeiten lassen.


    Danke aber hast du vielleicht noch ein paar Tipps, wo ich mehr darüber lernen kann, etc.
    Auch wenn es blöd klingt aber irgendwie finde ich nicht viel dazu.

    Hmmmm...learning by doing :D


    Einfach leicht anfangen, mit ein paar Keras Beispielen, etwas abändern und spielen, schauen was was macht.


    Vllt fällt dir auch TensorFlow JS leichter? Gibt glaube ich auch gute Tutorials von "The Coding Train" :)

    @Talykos Jetzt übertreiben wir mal nicht, zumal new query[MAX_PLAYERS_NAME+1]; das auch nicht geht, da der Rest des Querys ja noch drum rum muss.



    ProtocolRead[P_MAX][600][3]

    Das frisst deine Ressourcen.
    Lösche es, du kannst das alles schöner schreiben.


    Versuche es mal so:



    Das scheint mir ein eleganter Weg zu sein! :)


    Schlaf schön ;)

    Mal 2 ganz blöde Fragen.


    • Nutzt du ProtocolRead nur in diesen Codes?
    • Wie hast du das deklariert?
    • Mal ein paar Hinweise generell wegen der Performanz.
      • Nutze LIMIT in deinen SQL Abfragen. Das ist hier auch der Schlüssel, wie du das elegant hier alles lösen kannst. Dann brauchst du keine komischen if-Abfragen wie in Zeile 22. (Wenn du schon sowas nutzt, dann auch ein break, sonst läuft die Schleife ja sinnlos weiter xD)
      • Deine String-größen sind nicht wirklich optimal gewählt...allein bei deinem CMD kannst du 64, statt 256 verwenden.

    habe diesen Kurs gefunden

    "gefunden" du meinst wohl, du wurdest bei jedem YouTube Video mit dieser dummen Werbung belästigt.


    Also ich rate dir davon ab.


    Das Andere sieht doch ganz gut aus, der erklärt viel, wenn du es etwas peppiger haben magst empfehle ich dir Siraj Raval :D


    Ansonsten ist das schon mal ein guter Einstieg in die Thematik :)

    Das break ist falsch gesetzt.


    Das solltest du so schreiben: