OlliN's
statisch vs. new performance
Heute hatten wir eine Diskussion darüber, ob auf einen Wert via einem statischen Klassenmember oder über einen Getter zugegriffen werden soll oder ob es sogar egal ist wenn man jedes Mal eine neue Instanz erzeugt. Jetzt hat es mich gejuckt, mal einfach ein kleines Beispiel zu machen. Mir ist klar, dass entscheidend ist, wie teuer das erzeugen des Objektes ist. Aber hier sind einfach mal die Zahlen vom Beispiel um ein Gefühl zu bekommen:
count: 10 static msec: 0 get msec: 0 new msec: 0 count: 100 static msec: 0 get msec: 0 new msec: 0 count: 1000 static msec: 0 get msec: 0 new msec: 2 count: 10000 static msec: 4 get msec: 1 new msec: 16 count: 100000 static msec: 1 get msec: 1 new msec: 32 count: 1000000 static msec: 0 get msec: 0 new msec: 224 count: 10000000 static msec: 0 get msec: 0 new msec: 1848 count: 100000000 static msec: 0 get msec: 0 new msec: 19029
Und hier noch das Beispiel:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 | import java.util.HashMap; import java.util.HashSet; import java.util.Map; import java.util.Set; public class Main { private static final Person PERSON = new Person(); private static long timestamp; public static void main(String[] args) { int count = 10; for(int i = 1; i < 9; i++){ System.out.println("count: " + count); iterate(count); count *= 10; } } private static void iterate(int count){ timestamp = System.currentTimeMillis(); iterateStatic(count); out("static "); timestamp = System.currentTimeMillis(); iterateGetter(count); out("get "); timestamp = System.currentTimeMillis(); iterateNew(count); out("new "); } private static Person getPerson(){ return PERSON; } private static void iterateStatic(int count){ for(int i = 0; i < count; i++){ Person person = PERSON; person.blub(); } } private static void iterateNew(int count){ for(int i = 0; i < count; i++){ Person person = new Person(); person.blub(); } } private static void iterateGetter(int count){ for(int i = 0; i < count; i++){ Person person = getPerson(); person.blub(); } } private static void out(String s){ System.out.println(s + " msec: " + (System.currentTimeMillis()-timestamp)); } } class Person { private Map<?, ?> aMap = new HashMap<String, Object>(); private Set<?> aSet = new HashSet<String>(); public Person() { } void blub(){ } } |
-
Articles
- May 2012
- January 2012
- December 2011
- November 2011
- October 2011
- September 2011
- August 2011
- May 2011
- April 2011
- February 2011
- January 2011
- December 2010
- November 2010
- May 2010
- April 2010
- March 2010
- January 2010
- December 2009
- November 2009
- October 2009
- September 2009
- August 2009
- July 2009
- June 2009
- May 2009
- March 2009
- January 2009
- December 2008
- November 2008
- October 2008
- September 2008
- August 2008
- July 2008
- June 2008
- May 2008
- April 2008
- March 2008
- February 2008
- January 2008
- December 2007
- November 2007
- October 2007
- September 2007
- August 2007
- July 2007
- June 2007
- May 2007
- April 2007
- March 2007
- February 2007
- January 2007
- December 2006
- November 2006
- October 2006
- September 2006
- August 2006
- July 2006
- June 2006
-
Meta





