summaryrefslogtreecommitdiffstats
path: root/benchmarks/src/benchmarks/regression/DoPrivilegedBenchmark.java
blob: effb2844c9300701a12fdf970bedd6588e1fde37 (plain)
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
70
71
72
73
74
75
/*
 * Copyright (C) 2010 Google Inc.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 * http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package benchmarks.regression;

import com.google.caliper.Param;
import com.google.caliper.Runner;
import com.google.caliper.SimpleBenchmark;
import java.security.AccessController;
import java.security.PrivilegedAction;

public class DoPrivilegedBenchmark extends SimpleBenchmark {
    public void timeDirect(int reps) throws Exception {
        for (int i = 0; i < reps; ++i) {
            String lineSeparator = System.getProperty("line.separator");
        }
    }
    
    public void timeFastAndSlow(int reps) throws Exception {
        for (int i = 0; i < reps; ++i) {
            String lineSeparator;
            if (System.getSecurityManager() == null) {
                lineSeparator = System.getProperty("line.separator");
            } else {
                lineSeparator = AccessController.doPrivileged(new PrivilegedAction<String>() {
                    public String run() {
                        return System.getProperty("line.separator");
                    }
                });
            }
        }
    }
    
    public void timeNewAction(int reps) throws Exception {
        for (int i = 0; i < reps; ++i) {
            String lineSeparator = AccessController.doPrivileged(new PrivilegedAction<String>() {
                public String run() {
                    return System.getProperty("line.separator");
                }
            });
        }
    }
    
    public void timeReusedAction(int reps) throws Exception {
        final PrivilegedAction<String> action = new ReusableAction("line.separator");
        for (int i = 0; i < reps; ++i) {
            String lineSeparator = AccessController.doPrivileged(action);
        }
    }
    
    private static final class ReusableAction implements PrivilegedAction<String> {
        private final String propertyName;
        
        public ReusableAction(String propertyName) {
            this.propertyName = propertyName;
        }
        
        public String run() {
            return System.getProperty(propertyName);
        }
    }
}