Beiträge von Kaliber

    Wo steht das?


    Wie sieht denn deine Funktion aus zum Erstellen des Pools?


    //Edit: Wie öffnest du auch die Datenbank? Das ist doch nicht phpmyadmin?


    Es kann auch sein, dass dir nur 1000 angezeigt werden.
    Kannst ja mal SELECT COUNT(*) FROM `t_0` machen, ich wette, da steht dann 8998.

    Für die Kennzeichen/Telefonnummer würde ich einfach aufsteigende Zahlenfolge nutzen.

    Das freut mich :)


    Selbst ein Index ist wahrscheinlich overkill, wenn wir von 1000 Zahlen reden, aber gut.

    Ja, das versuche ich dir ja gerade zu vermitteln.
    Desweiteren kannst du in Pawn nicht mal dynamisch Speicher allozieren, also würde das so gar nicht gehen.
    Schon gar nicht bei mehreren Pools.
    (Ja Memory Plugin außen vor, dennoch hat man dann noch O(n) Zugriffe auf das Array)

    Wenn man für die Zufallszahl einen Index erstellt, dann ist der Check auf Duplikate relativ schnell

    Wie willst du das machen?
    Du musst ja trotzdem alle vorherigen Zahlen durchgehen, dein Ansatz ist der naive Ansatz, wie oben erklärt.
    Und wenn du einen Pool von 10.000 Zahlen hast, dann viel Spaß. Dein Array musst du ja auch irgendwie deklarieren und das bezieht auch Speicher.



    da es sonst zu viel Speicher frisst.

    Nah jede Zahl frisst nur 4 Bytes.
    Also selbst wenn du einen Pool aus 1.000.000 Zahlen hast, frisst das ((1.000.000*4)/1024) = 3.906,25kB = ~4MB


    Also das ist ein RIESEN Pool, ich wüsste nicht, wofür man so viele eindeutig zufällige Zahlen bräuchte und man benötigt nur 4MB, was jeder Rechner locker zur Verfügung hat, immerhin Reden wir hier nicht von RAM, sondern von Festplattenspeicher.
    Und wenn ich überlege, dass heute sogar Handys Teil schon 1TB haben (Galaxy S10 mit 1TB Speicher) sollte das mit den 4MB kein Problem sein ^^

    Hallo Brotfische,


    ich bin es mal wieder *nerv nerv* mit einem neuen Include.
    Inspiriert durch diesen Thread: Kennzeichen System / Polizei KFZ Akte


    Es geht, wie der Titel es schon vermuten lässt um "Eindeutig zufällige Zahlen".


    Aber was heißt das eigentlich?
    Nun, wenn man z.B. die Funktion random(n) verwendet, dann erhält man zufällige Zahlen im Intervall von [0, n-1]. (Also zum Beispiel random(100) gibt uns die Zahlen von 0-99.)
    So, verwenden wir diese Funktion jetzt noch einmal, dann erhalten wir mit Pech, die Selbe Zahl wie zuvor.
    Das ist natürlich ärgerlich, wenn man jetzt Telefonnummern vergibt oder eindeutige Kennzeichen haben will.


    Naive Lösung?
    Eine naive Lösung wäre jetzt, eine Zahl zu generieren und dann zu speichern.
    Anschließend alle Nachfolgenden generierten Zahlen durch die, die schon erstellt wurden zu iterieren und zu schauen, ob es bereits schon so eine Zahl gibt.
    Falls dem so ist, eine neue generieren. Ansonsten hat man ja seine eindeutige Zahl gefunden.
    Problem: Der Aufwand wird immer größer (je mehr Zahlen man generiert hat) und das will man gerade im Laufenden betrieb natürlich nicht. (O(n^x) n=Wie viele Zahlen es bereits gibt. x=Wie viele Versuche benötigt werden, eine zu finden, die noch nich existiert.)


    Meine Lösung?
    Es ist einfacher, einen Zahlen Pool abzubilden.
    Sprich man will eine zufällige Zahl von 0-1000, dann speichert man einfach alle 1000 Zahlen in einer Datenbank.
    Anschließend wird einfach eine zufällig ausgewählt und aus der Liste gelöscht (das heißt, je mehr verwendet werden, desto kleiner wird der Speicherplatz bedarf.)
    Das bedeutet, egal wie viele Zahlen man hat, es ist immer gleich schnell (O(1)).


    Das Gute hier ist noch, dass man Multi-Threaded querys nutzen kann (nur in MySQL, nicht SQLite), dann wird das eh ausgelagert alles und beeinflusst 0 den Server.


    MySQL VS SQLite
    Ich habe 2 Versionen geschrieben.
    Definitiv zu präferieren wäre hier die MySQL Version (aber für die, die kein MySQL haben und das benötigen, habe ich eine SQLite Version geschrieben).


    MySQL
    Wie oben schon erwähnt, können wir hier Multi-Threaded Querys nutzen und das Asynchron gestalten.
    Somit läuft hier alles sehr schnell und glatt.


    SQLite
    Hier belastet das die Server-Laufzeit. (Gerade der Server-Start, wenn die Pools inistialisiert werden, kann das (je nach Größe der Pools) bis zu einer Minute dauern.)
    Die spätere Generierung dauert ~0.5ms. Also nicht soo viel, aber doch schon etwas, gerade wenn man hintereinander mehrere Zahlen generiert.


    Beispiele
    MySQL Version


    SQLite Version


    Was passiert, wenn der Pool leer ist?
    Dann ist der status wie schon gezeigt -1.
    Allerdings, wenn beim Server Restart immer noch das CreateRandomPool steht, wird dieser automatisch wieder aufgefüllt.


    Download


    Wer die MySQL Version verwenden will, da ist die Neuste MySQL Version (R41) nötig!


    MySQL - Version - Links:


    SQLite - Version - Links:


    Wichtige Hinweise / Mögliche Errors


    Schlusswort
    Ich hoffe das Include ist für den ein oder anderen nützlich.


    Bei Fragen oder Anregungen, stehe ich euch wie immer gerne zur Verfügung.


    Viel Spaß weiterhin beim skripten :)


    Mit freundlichen Grüßen
    Euer Kalle :P

    Einfach:



    C
    if( strcmp( key , "BanReason" , true ) == 0 ) format(PlayerInfo[playerid][pBanReason], 64, ini_Get( Data )); //oder wie lang auch immer der Reason so sein kann
    if( strcmp( key , "BanAdmin" , true ) == 0 ) format(PlayerInfo[playerid][pBanAdmin], MAX_PLAYER_NAME, ini_Get( Data ));

    //Edit: Natürlich dini_get...

    Ich hab da am Ende ein Print aber soweit kommt der erst garnicht.

    Wenn ich sage..alles voller prints setzen, meine ich sicher nicht nur einen print ^^


    Sondern...überall in jede Code ebene.


    Also immer vor die { was setzen um eben zu schauen, was gemacht wird.


    und der string ist egal, wichtiger wäre sowas wie printf("A: %d",b); und beim Nächsten "B: %d" usw...xD

    also ich habe 8 Biz soll ich jetzt noch 6 Dummys hinterherschicken oder wie
    muss ich das verstehen?

    Richtig, so dass du gleichviele Ints, wie Bizzes hast.


    Sonst wie gesagt, bau es dynamisch auf, dann kannste einfach prüfen, ob das Biz schon einen Interior hat oder nicht.