官术网_书友最值得收藏!

Fixture methods

Since a state object can be kept during the whole lifetime of the benchmark, it would useful to have methods that do state housekeeping. This concept is implemented with the usual fixture methods that you might encounter in JUnit or TestNG. You can only write these methods inside a class that's declared with the @State annotation, and these methods can only be invoked by threads which are using the state. In this way, the thread-local context is created and you don't have to use thread synchronization.

The method for initializing must be marked with the @Setup annotation and the method that's declared with the @TearDown annotation will be invoked at the end of the object's lifetime. The following code example demonstrates how this concept works:

@State(Scope.Thread)
public class MyBenchmark {

double x;

@Setup
public void prepare() {
System.out.println("prepare");
x = Math.PI;
}

@TearDown
public void check() {
System.out.println("check");
assert x > Math.PI : "Nothing changed?";
}

@Benchmark
public void measureRight() {
x++;
}

@Benchmark
public void measureWrong() {
double x = 0;
x++;
}
}

The output will contain prepare and check messages, which talk about the start and the end of each scope. The measureRight() method obviously does the correct thing. Incrementing the x field in the state.check() benchmark will never fail this way because we're always guaranteed to have at least one benchmark call. However, the measureWrong() method will fail the check() method, because we deliberately have the typo, and it will only increment the local variable. This shouldn't pass the check, and the JMH will fail to run.

主站蜘蛛池模板: 中山市| 江津市| 永寿县| 崇阳县| 长宁县| 彭山县| 睢宁县| 红河县| 天气| 沂源县| 永吉县| 五大连池市| 扎鲁特旗| 沅江市| 讷河市| 宜君县| 平山县| 读书| 正定县| 韶山市| 伊川县| 招远市| 尚义县| 宁陵县| 常宁市| 福州市| 民丰县| 巨鹿县| 雅江县| 岱山县| 正宁县| 道真| 洞头县| 平度市| 雅江县| 莆田市| 成都市| 衡阳市| 蒲城县| 于都县| 江口县|