Value object


In computer science, a value object is a small object that represents a simple entity whose equality is not based on identity: i.e. two value objects are equal when they have the same value, not necessarily being the same object.
Examples of value objects are objects representing an amount of money or a date range.
Being small, one can have multiple copies of the same value object that represent the same entity: it is often simpler to create a new object rather than rely on a single instance and use references to it.
Value objects should be immutable: this is required for the implicit contract that two value objects created equal, should remain equal. It is also useful for value objects to be immutable, as client code cannot put the value object in an invalid state or introduce buggy behaviour after instantiation.
Value objects are among the building blocks of DDD.

Implementation

Due to the nuances of various object-oriented programming languages, each has their own methods and patterns for implementing and using value objects.

C#

In C# a class is a reference type while a struct is a value type.
Hence an instance derived from a class definition is an object while an instance derived from a struct definition is said to be a value object.
The following procedure can be carried out to add value object properties to a C# class:
  1. Override the method to ensure the object is compared using business logic
  2. Operator overload the default behavior of and to use the method.
  3. Override the method and ensure that the hash is same for the objects who have same equality.
  4. Make the class immutable by removing any property setters and only passing member values through the constructors.

    C++

In C++ a value object can be built by overloading the assignment operator and using appropriate constness constraints on the fields and on the methods of the class.
However, if the fields themselves are declared const, then it won't be possible to fully overwrite such a value object with another.

Java

Unlike C# and C++, Java has no support for custom value types at the language level. Every custom type is a reference type, and therefore has identity and reference semantics, though extending support for custom value types is being considered.
Java programmers therefore emulate value objects by creating immutable objects, because if the state of an object does not change, passing references is semantically equivalent to copying value objects.
A class can be made immutable by declaring all attributes blank final, and declaring all attributes to be of immutable type, not of mutable type such an ArrayList or even a Date. They should also define equals and hashCode to compare values rather than references.
The term "VALJO" has been coined to refer to the stricter set of rules necessary for a correctly defined immutable value object.
Value type semantics will be introduced in Java by the Project Valhalla.

Example


public class StreetAddress