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