Multi-layered applications often require to map between different object models (e.g. DTOs and entities). Writing such boiler plate mapping code is a tedious and error-prone task. A lot of object-to-object mapping Java frameworks aims to simplify this work and automate it. Some uses code instrospection (eg. Dozer). Other uses code generation (ex: MapStuct). This micro-benchmark compares performance of 5 frameworks. Results could be compared to the benchmark of a code written manually.
Benchmark are powered by a tool called JMH or also known as "Java Microbenchmarking Harness". JMH is developed by the OpenJDK team.
Github is for social coding platform: if you want to add another mapping framework or optimize an existing one, we encourage contributions through pull requests from forks of this repository. If you want to contribute code this way, please reference a GitHub ticket as well covering the specific issue you are addressing.
The data model used by this benchmark is very basic. It comes from the Comparison class from the ModelMapper framework. It includes combinations which usually appear in Java Beans, such as:
- Object types
- Collections
Pre-requisites: Maven 3.x and a JDK 6 (or above)
git clone git://github.com/arey/java-object-mapper-benchmark.git
mvn clean install
java -jar target/benchmarks.jar
Tests has been performed on:
- OS: MacOSX
- CPU: Core i7 2.8GHz 6MB cache × 4 cores
- RAM: 16GB
- JVM: Oracle 1.8.0_25 64 bits
Benchmark | Mode | Samples | Score | Margin error (+/-) | Units |
---|---|---|---|---|---|
Manual | thrpt | 200 | 17 277 097 | 146 095 | ops/s |
Selma | thrpt | 200 | 17 132 979 | 38 209 | ops/s |
MapStruct | thrpt | 200 | 14 493 144 | 67 522 | ops/s |
Orika | thrpt | 200 | 3 283 557 | 16 706 | ops/s |
ModelMaper | thrpt | 200 | 282 039 | 2 176 | ops/s |
Dozer | thrpt | 200 | 103 006 | 1 362 | ops/s |
Legend : Higher score is better
Total time: 00:49:06
- Micro-benchmark of Java mapping object frameworks (french article)