Immutability using Lombok
A preferred best practice in Apache Pekko is to have immutable messages. Scala provides case class which makes it extremely easy to have short and clean classes for creating immutable objects, but no such facility is easily available in Java. We can make use of several third party libraries which help is achieving this. One good example is Lombok.
Project Lombok is a java library that automatically plugs into your editor and build tools, and helps get rid of much of the boilerplate code for java development.
Lombok handles the following details for you. It:
- modifies fields to be privateandfinal
- creates getters for each field
- creates correct equals,hashCodeand a human-friendlytoString
- creates a constructor requiring all fields.
Adding Lombok to your project
To add Lombok to a Maven project, declare it as a simple dependency:
- Maven
- <dependencies> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.10</version> </dependency> </dependencies>
- Gradle
- dependencies { implementation "org.projectlombok:lombok:1.18.10" }
Using lombok
@Value
public class LombokUser {
  String name;
  String email;
}
The example does not demonstrate other useful Lombok features like @Builder or @With which will help you create builder and copy methods. Be aware that Lombok is not an immutability library but a code generation library which means some setups might not create immutable objects. For example, Lombok’s @Data is equivalent to Lombok’s @Value but will also synthesize mutable methods. Don’t use Lombok’s @Data when creating immutable classes.
Using Lombok for creating a message class for actors is quite simple. In following example, Message class just defines the member variable and Lombok annotation @Value takes care of creating methods like getter, toString, hashCode, equals.
public class MyActor extends AbstractActor {
        private final LoggingAdapter log = Logging.getLogger(getContext().getSystem(), this);
        public Receive createReceive() {
            return receiveBuilder()
            .match(Message.class, message -> {
                System.out.println(message.getMessage());
            })
            .matchAny(o -> log.info("Received unknown message"))
            .build();
        }
        @Value
        public static class Message {
            private String message;
            public Message(String message) {
                this.message = message;
            }
        }
}
Integrating Lombok with an IDE
Lombok integrates with popular IDEs:
- To use Lombok in IntelliJ IDEA you’ll need the Lombok Plugin for IntelliJ IDEA and you’ll also need to enable Annotation Processing (Settings / Build,Execution,Deployment / Compiler / Annotation Processorsand tickEnable annotation processing)
- To Use Lombok in Eclipse, run java -jar lombok.jar(see the video at Project Lombok).