From http://docs.oracle.com/javase/tutorial/essential/concurrency/imstrat.html :
Don't provide "setter" methods — methods that modify fields or objects referred to by fields. Make all fields final and private. Don't allow subclasses to override methods. The simplest way to do this is to declare the class as final. A more sophisticated approach is to make the constructor private and construct instances in factory methods. If the instance fields include references to mutable objects, don't allow those objects to be changed: Don't provide methods that modify the mutable objects. Don't share references to the mutable objects. Never store references to external, mutable objects passed to the constructor; if necessary, create copies, and store references to the copies. Similarly, create copies of your internal mutable objects when necessary to avoid returning the originals in your methods.
A class called Employee has a Instance variable a of type Address
My Question : what should be done to make this class immutable ( condition: I want to return the same instance variable a from getAddress() getter).
Should I make the address class immutable ?
Note: I understand defensive copy, but do not want to use this