klassen auf dem stack erzeugen ohne new



  • Ja ich bau mir das ganze grad von hand mit nem einzelnen char buffer

    gibts in java ne funktion der man sagen kann nimm char 25-30 und mach mir n integer drauß?
    so wie atoi in c
    will vermeiden die chars vorher in nen string konvertieren zu müssn



  • Sovok schrieb:

    will vermeiden die chars vorher in nen string konvertieren zu müssn

    such mal nach 'parseInt' und 'java.util.Scanner'. müsste auch mit 'CharSequence' oder 'StringBuffer' gehen.
    🙂



  • da hab ich nix gefunden

    Integer.parseInt gibts nur für String und der Scanner scheint nur zu gehn wenn man ihn für den kompletten content benutzt

    noch andere ideen?



  • auch selber schreiben. ist ja nicht so schwer, gibt wahrscheinlich auch genug beispiele im netz



  • Sovok schrieb:

    Integer.parseInt gibts nur für String und der Scanner scheint nur zu gehn wenn man ihn für den kompletten content benutzt

    wie sieht den dein content aus? 'char' in Java ist 16-bittig (für unicode). falls du 1-byte pro zeichen hast, ist vielleicht besser, mit dem Java typ 'byte[]' zu arbeiten.
    🙂



  • StringBuilder -> richig benutzt: effizient

    StringBuffer -> das selbe, aber dazu noch "thread safe"

    zum gc: die falle ist, dass wenn man sachen, die man nicht mehr braucht nicht gleich "nullt" und somit die objekte noch rumliegen. wenn dann noch diverse calls kommen, während das objekt rumliegt, kann es passieren, dass zwischenzeitlich der gc aktiv wird und das besagte objekt das aufräumen überlebt und damit von generation0 zu generation1 befördert wird. hierdurch wird es noch schwerer, das ding wieder los zu werden.

    also es sollte eigentlich schon helfen, referenzen, wenn man weiss, dass man sie nicht mehr braucht, direkt null zu setzen. ansonsten kann man auch mit System.gc(); die garbage collection erzwingen, wenn es zeitlich gerade passt.

    hauptspeicherfragmentierung könnte auch ein grund für langsame gc sein, wie noch vieles weitere. i.d.r ist nicht der gc sondernder programmierer schuld. im zweifelsfall nochmal nachgoogeln, wie der gc wirklich funktioniert 😉



  • jule37 schrieb:

    ansonsten kann man auch mit System.gc(); die garbage collection erzwingen, wenn es zeitlich gerade passt.

    Nein, nein, nein. Kann man nicht! Und soll man auch nicht.
    http://java.sun.com/docs/hotspot/HotSpotFAQ.html#gc_pooling



  • okay, dann das nicht. wieder was gelernt. aber der rest müsste stimmen 😛



  • jule37 schrieb:

    StringBuilder -> richig benutzt: effizient

    StringBuffer -> das selbe, aber dazu noch "thread safe"

    Und was bringt ein StringBuffer, wenn man den String zerlegen will?



  • tfa schrieb:

    jule37 schrieb:

    ansonsten kann man auch mit System.gc(); die garbage collection erzwingen, wenn es zeitlich gerade passt.

    Nein, nein, nein. Kann man nicht! Und soll man auch nicht.
    http://java.sun.com/docs/hotspot/HotSpotFAQ.html#gc_pooling

    gilt halt wieder nicht für embedded systeme wie android
    hab vorher ein spiel mit einigen animationen programmiert

    ohne pooling und System.gc() hats da regelmäßig geruckelt weil der
    gc wenn er grad bock hatte reingesprungen is
    mit pooling und System.gc() zum richtigen zeitpunkt z.b. direkt nach ner user eingabe liefen die animationen einwandfrei flüssig



  • jule37 schrieb:

    StringBuilder -> richig benutzt: effizient
    StringBuffer -> das selbe, aber dazu noch "thread safe"

    die beiden mag ich insofern nich weil man um den string zu benutzen erst wieder nen immutable string objekt erzeugen muss

    hab aber rausgefunden dass die views in android auch mit CharBuffer arbeiten können... damit kann ich meine chars direkt aus dem hauptbuffer in die kleineren charbuffer kopiern und brauch keine extra allokation

    für die ints hab ich jetzt ne eigene konvertierungsfunktion von char nach int über den ascii wert geschrieben wobei jede stelle mit ner zehnerpotenz multipliziert wird (bin offen für effizientere vorschläge)... direkt mit byte zu arbeiten wär zwar noch besser weil damit ein kompletter kopiervorgang wegfällt aber damit kann CharBuffer wieder nich umgehn und java is ja leider typesafe ^^ (nich ernst nehmen) und hat keine 8 bit chars


Anmelden zum Antworten