197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes/* 297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * Copyright (C) 2009 Google Inc. 397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * 497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * Licensed under the Apache License, Version 2.0 (the "License"); 597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * you may not use this file except in compliance with the License. 697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * You may obtain a copy of the License at 797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * 897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * http://www.apache.org/licenses/LICENSE-2.0 997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * 1097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * Unless required by applicable law or agreed to in writing, software 1197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * distributed under the License is distributed on an "AS IS" BASIS, 1297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * See the License for the specific language governing permissions and 1497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * limitations under the License. 1597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes */ 1697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 1797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughespackage benchmarks.regression; 1897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 1997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport com.google.caliper.Benchmark; 2097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport com.google.caliper.Param; 2197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport com.google.caliper.Runner; 2297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport com.google.caliper.SimpleBenchmark; 2397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport java.text.*; 2497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughesimport java.util.*; 2597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 2697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes/** 2797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes * Benchmarks creation and cloning various expensive objects. 2897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes */ 2997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughespublic class ExpensiveObjectsBenchmark extends SimpleBenchmark { 3097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewDateFormatTimeInstance(int reps) { 3197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 3297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes DateFormat df = DateFormat.getTimeInstance(DateFormat.SHORT); 3397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes df.format(System.currentTimeMillis()); 3497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 3597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 3697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 3797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedDateFormatTimeInstance(int reps) { 3897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes DateFormat df = DateFormat.getTimeInstance(DateFormat.SHORT); 3997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 4097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes ((DateFormat) df.clone()).format(System.currentTimeMillis()); 4197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 4297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 4397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 4497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeReusedDateFormatTimeInstance(int reps) { 4597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes DateFormat df = DateFormat.getTimeInstance(DateFormat.SHORT); 4697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 4797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes synchronized (df) { 4897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes df.format(System.currentTimeMillis()); 4997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 5097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 5197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 5297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 5397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewCollator(int reps) { 5497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 5597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes Collator.getInstance(Locale.US); 5697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 5797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 5897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 5997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedCollator(int reps) { 6097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes Collator c = Collator.getInstance(Locale.US); 6197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 6297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes c.clone(); 6397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 6497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 6597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 6697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewDateFormatSymbols(int reps) { 6797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 6897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes new DateFormatSymbols(Locale.US); 6997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 7097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 7197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 7297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedDateFormatSymbols(int reps) { 7397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes DateFormatSymbols dfs = new DateFormatSymbols(Locale.US); 7497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 7597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes dfs.clone(); 7697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 7797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 7897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 7997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewDecimalFormatSymbols(int reps) { 8097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 8197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes new DecimalFormatSymbols(Locale.US); 8297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 8397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 8497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 8597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedDecimalFormatSymbols(int reps) { 8697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes DecimalFormatSymbols dfs = new DecimalFormatSymbols(Locale.US); 8797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 8897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes dfs.clone(); 8997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 9097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 9197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 9297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewNumberFormat(int reps) { 9397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 9497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes NumberFormat.getInstance(Locale.US); 9597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 9697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 9797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 9897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedNumberFormat(int reps) { 9997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes NumberFormat nf = NumberFormat.getInstance(Locale.US); 10097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 10197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes nf.clone(); 10297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 10397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 10497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 10597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNumberFormatTrivialFormatLong(int reps) { 10697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes NumberFormat nf = NumberFormat.getInstance(Locale.US); 10797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 10897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes nf.format(1024L); 10997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 11097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 11197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 11297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeLongToString(int reps) { 11397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 11497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes Long.toString(1024L); 11597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 11697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 11797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 11897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNumberFormatTrivialFormatDouble(int reps) { 11997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes NumberFormat nf = NumberFormat.getInstance(Locale.US); 12097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 12197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes nf.format(1024.0); 12297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 12397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 12497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 12597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewSimpleDateFormat(int reps) { 12697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 12797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes new SimpleDateFormat(); 12897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 12997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 13097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 13197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedSimpleDateFormat(int reps) { 13297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes SimpleDateFormat sdf = new SimpleDateFormat(); 13397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 13497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes sdf.clone(); 13597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 13697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 13797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 13897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeNewGregorianCalendar(int reps) { 13997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 14097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes new GregorianCalendar(); 14197aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 14297aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 14397aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes 14497aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes public void timeClonedGregorianCalendar(int reps) { 14597aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes GregorianCalendar gc = new GregorianCalendar(); 14697aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes for (int i = 0; i < reps; ++i) { 14797aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes gc.clone(); 14897aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 14997aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes } 15097aba27f961a5a6f37dcaf7f455df371e250ede3Elliott Hughes} 151