Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add poo/value_objects #15

Open
wants to merge 21 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
## Programmation orientée objet

- `📑` [Abstraction - définition, utilité et exemples](poo/abstraction)
- `📑` [Value objects - définition, explications et exemples](poo/value_objects)

## Java

Expand Down
11 changes: 11 additions & 0 deletions poo/value_objects/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
# Value objets
Emalios marked this conversation as resolved.
Show resolved Hide resolved

> Écrit par [Emalios](https://github.com/Emalios)

Cette présentation porte sur la notion de **value objects**, un type d'objet que tout le monde devrait connaître.
Emalios marked this conversation as resolved.
Show resolved Hide resolved

Bien que ces objets peuvent exister dans de nombreux langages de programmation, les exemples seront écrits en `Java` pour cette présentation.

## Table des matières

- [Value objects - définition, explications et exemples](fr/VALUE_OBJECTS.MD)
16 changes: 16 additions & 0 deletions poo/value_objects/code/Address.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
public class Address {

//value object
private final String cityName;
private final String streetAddress;

public Address(String cityName, String streetAddress) {
this.cityName = cityName;
this.streetAddress = streetAddress;
}

@Override
public String toString() {
return String.format("%s - %s", this.cityName, this.streetAddress);
}
}
16 changes: 16 additions & 0 deletions poo/value_objects/code/Currency.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
public enum Currency {

EUR("€"),
USD("$");

private final String formattedString;

Currency(String formattedString) {
this.formattedString = formattedString;
}

@Override
public String toString() {
return this.formattedString;
}
}
50 changes: 50 additions & 0 deletions poo/value_objects/code/Money.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import java.util.Objects;

public class Money {

//value object
private final long value;
private final Currency currency;

public Money(long value, Currency currency) {
if(value<0) {
this.value = 0;
this.currency = currency;
return;
}
this.currency = currency;
this.value = value;
}
Emalios marked this conversation as resolved.
Show resolved Hide resolved

public Money(long value) {
this(value, Currency.USD);
}

public Money addMoney(Money moneyToAdd) {
return new Money(this.value+moneyToAdd.value, this.currency);
}

public Money removeMoney(Money moneyToRemove) {
return new Money(this.value-moneyToRemove.value, this.currency);
}

@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Money money = (Money) o;
return value == money.value &&
currency == money.currency;
}

@Override
public int hashCode() {
return Objects.hash(value, currency);
}

@Override
public String toString() {
return String.format("%s%s", this.value, this.currency);
}

}
16 changes: 16 additions & 0 deletions poo/value_objects/code/Order.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import java.util.List;
import java.util.UUID;

public class Order {

//Not a value objet because have an id
private final UUID orderId;
private Products products;
private Address addressToDeliver;

public Order(Products products, Address addressToDeliver) {
this.orderId = UUID.randomUUID();
this.products = products;
this.addressToDeliver = addressToDeliver;
}
}
12 changes: 12 additions & 0 deletions poo/value_objects/code/Product.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
public class Product {

private final Money cost;

public Product(Money cost) {
this.cost = cost;
}

public Money getCost() {
return cost;
}
}
24 changes: 24 additions & 0 deletions poo/value_objects/code/Products.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import java.util.ArrayList;
import java.util.List;

public class Products {

private final List<Product> products;

public Products() {
this.products = new ArrayList<>();
}

public void addProduct(Product product) {
this.products.add(product);
}

public Money getProductsCost() {
Money money = new Money(0);
for (Product product : products) {
money = money.addMoney(product.getCost());
}
return money;
}

}
35 changes: 35 additions & 0 deletions poo/value_objects/fr/VALUE_OBJECTS.MD
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
# Value objects.

## Qu'est-ce qu'un value object ?

Eh bien il se caractérise par deux caractéristiques principales que nous allons détailler ainsi que leurs conséquences.

## -Ils n'ont pas d'identité.

En effet, les value objects ne possèdent pas d'identité, car ce n'est pas du tout ce qui nous intéresse dans ces objets, ce qui nous intéresse,
c'est les valeurs qu'ils contiennent.
Par exemple, prenons deux objets `Money`, un qui est composé d'un billet de 10€ et un autre qui est composé de deux billets de 5€.
Eh bien ces deux value objects **sont identiques** car ils ont la **même valeur** bien qu'ils n'aient **pas la même identité**.
Emalios marked this conversation as resolved.
Show resolved Hide resolved

## -Ils sont immuables.

Pour faciliter leur utilisation les value objects **doivent être immutable**.
Emalios marked this conversation as resolved.
Show resolved Hide resolved
Si vous souhaiter changer les valeurs dans le value object, il suffit d'en **créer un nouveau**. Bien souvent des méthodes pour faire cela sont présentes dans un value object.
Emalios marked this conversation as resolved.
Show resolved Hide resolved
Emalios marked this conversation as resolved.
Show resolved Hide resolved
Et le fait que ces objets soient immuables permet qu'ils deviennent totalement **interchangeables** et **réutilisables**.
Par exemple imaginons un value objet `Address` qui représente l'adresse d'une personne, et bien si deux personnes habitent au même endroit, on peut **réutiliser** le même object, ce qui optimise notre application.
Emalios marked this conversation as resolved.
Show resolved Hide resolved
Emalios marked this conversation as resolved.
Show resolved Hide resolved

## -Ils dépendent d'autres objets.
Emalios marked this conversation as resolved.
Show resolved Hide resolved

Si ces objets ne dépendent pas d'un "objet mère" ils n'auraient aucune utilité, si je reprends les exemples d'au-dessus on peut identifier certains "objets mères" potentiels :

-`Money` pourrait dépendre d'un portefeuille ou bien d'un compte bancaire.

-`Address` pourrait dépendre d'une livraison ou bien d'une maison.

## -Exemple d'implémentation

Voici une petite [implémention](../code) autour d'un système de livraison, qui lie les deux exemples `Money` et `Address`, ce n'est qu'une base, mais ça permet d'entrevoir ce qu'on peut faire avec les value objects.

## -Conclusion

Les value objects sont des objets immuables, dépendant d'autres objets, n'ayant aucune identité.