Skip to content

Commit c5ec9c8

Browse files
ricardo-ramos-mouraRicardo Ramos
andauthored
translate: chain-of-responsability to pt-br (#2630)
* translate pattern chain-of-responsability to pt-br * set language pt in README.md --------- Co-authored-by: Ricardo Ramos <[email protected]>
1 parent dc058d3 commit c5ec9c8

File tree

1 file changed

+174
-0
lines changed
  • localization/pt/chain-of-responsability

1 file changed

+174
-0
lines changed
Lines changed: 174 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,174 @@
1+
---
2+
title: Chain of responsibility
3+
category: Behavioral
4+
language: pt
5+
tag:
6+
- Gang of Four
7+
---
8+
9+
## Propósito
10+
11+
Evitar acoplar o remetente de uma *request* ao seu destinatário, dando a mais de um objeto a chance de
12+
lidar com a solicitação. Encadeie os objeto recebidos e passe a solicitação ao longo da cadeia até um objeto
13+
lidar com isso.
14+
15+
## Explicação
16+
17+
Exemplo do mundo real
18+
19+
> O Rei Orc dá ordens ao seu exército. O primeiro a receber a ordem é o comandante, então
20+
> um oficial e depois um soldado. O comandante, o oficial e o soldado formam uma cadeia de responsabilidades.
21+
22+
23+
Em outras palavras
24+
25+
> Ajuda a construir uma cadeia de objetos. Uma solicitação entra de uma extremidade e continua indo de um objeto
26+
> para outro até encontrar um manipulador adequado.
27+
28+
Wikipedia diz
29+
30+
> Em orientação a objetos, Chain of Responsibility é um padrão cuja principal função é evitar a dependência
31+
> entre um objeto receptor e um objeto solicitante. Consiste em uma série de objetos receptores e de objetos
32+
> de solicitação, onde cada objeto de solicitação possui uma lógica interna que separa quais são tipos de
33+
> objetos receptores que podem ser manipulados. O restante é passado para os próximos objetos de solicitação da cadeia.
34+
35+
**Exemplo de programação**
36+
37+
Traduzindo nosso exemplo com os orcs acima. Primeiro, nós temos a classe `Request`:
38+
39+
```java
40+
public class Request {
41+
42+
private final RequestType requestType;
43+
private final String requestDescription;
44+
private boolean handled;
45+
46+
public Request(final RequestType requestType, final String requestDescription) {
47+
this.requestType = Objects.requireNonNull(requestType);
48+
this.requestDescription = Objects.requireNonNull(requestDescription);
49+
}
50+
51+
public String getRequestDescription() { return requestDescription; }
52+
53+
public RequestType getRequestType() { return requestType; }
54+
55+
public void markHandled() { this.handled = true; }
56+
57+
public boolean isHandled() { return this.handled; }
58+
59+
@Override
60+
public String toString() { return getRequestDescription(); }
61+
}
62+
63+
public enum RequestType {
64+
DEFEND_CASTLE, TORTURE_PRISONER, COLLECT_TAX
65+
}
66+
```
67+
68+
Em seguida, mostramos a hierarquia no request handler
69+
70+
```java
71+
public interface RequestHandler {
72+
73+
boolean canHandleRequest(Request req);
74+
75+
int getPriority();
76+
77+
void handle(Request req);
78+
79+
String name();
80+
}
81+
82+
@Slf4j
83+
public class OrcCommander implements RequestHandler {
84+
@Override
85+
public boolean canHandleRequest(Request req) {
86+
return req.getRequestType() == RequestType.DEFEND_CASTLE;
87+
}
88+
89+
@Override
90+
public int getPriority() {
91+
return 2;
92+
}
93+
94+
@Override
95+
public void handle(Request req) {
96+
req.markHandled();
97+
LOGGER.info("{} handling request \"{}\"", name(), req);
98+
}
99+
100+
@Override
101+
public String name() {
102+
return "Orc commander";
103+
}
104+
}
105+
106+
// OrcOfficer and OrcSoldier are defined similarly as OrcCommander
107+
108+
```
109+
110+
O Rei Orc dá as ordens e forma a cadeia
111+
112+
```java
113+
public class OrcKing {
114+
115+
private List<RequestHandler> handlers;
116+
117+
public OrcKing() {
118+
buildChain();
119+
}
120+
121+
private void buildChain() {
122+
handlers = Arrays.asList(new OrcCommander(), new OrcOfficer(), new OrcSoldier());
123+
}
124+
125+
public void makeRequest(Request req) {
126+
handlers
127+
.stream()
128+
.sorted(Comparator.comparing(RequestHandler::getPriority))
129+
.filter(handler -> handler.canHandleRequest(req))
130+
.findFirst()
131+
.ifPresent(handler -> handler.handle(req));
132+
}
133+
}
134+
```
135+
136+
O chain of responsibility em ação.
137+
138+
```java
139+
var king = new OrcKing();
140+
king.makeRequest(new Request(RequestType.DEFEND_CASTLE, "defend castle"));
141+
king.makeRequest(new Request(RequestType.TORTURE_PRISONER, "torture prisoner"));
142+
king.makeRequest(new Request(RequestType.COLLECT_TAX, "collect tax"));
143+
```
144+
145+
A saída do console.
146+
147+
```
148+
Orc commander handling request "defend castle"
149+
Orc officer handling request "torture prisoner"
150+
Orc soldier handling request "collect tax"
151+
```
152+
153+
## Diagrama de classe
154+
155+
![alt text](././etc/chain-of-responsibility.urm.png "Diagrama de classe Chain of Responsibility")
156+
157+
## Aplicabilidade
158+
159+
Usar Chain of Responsibility quando
160+
161+
* Mais de um objeto pode lidar com uma solicitação, e o manipulador não é conhecido a priori. O manipulador deve ser verificado automaticamente.
162+
* Você deseja emitir uma solicitação para um dos vários objetos sem especificar o destinatário explicitamente.
163+
* O conjunto de objetos que podem lidar com uma solicitação deve ser especificado dinamicamente.
164+
165+
## Exemplos do mundo real
166+
167+
* [java.util.logging.Logger#log()](http://docs.oracle.com/javase/8/docs/api/java/util/logging/Logger.html#log%28java.util.logging.Level,%20java.lang.String%29)
168+
* [Apache Commons Chain](https://commons.apache.org/proper/commons-chain/index.html)
169+
* [javax.servlet.Filter#doFilter()](http://docs.oracle.com/javaee/7/api/javax/servlet/Filter.html#doFilter-javax.servlet.ServletRequest-javax.servlet.ServletResponse-javax.servlet.FilterChain-)
170+
171+
## Créditos
172+
173+
* [Design Patterns: Elements of Reusable Object-Oriented Software](https://www.amazon.com/gp/product/0201633612/ref=as_li_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=0201633612&linkCode=as2&tag=javadesignpat-20&linkId=675d49790ce11db99d90bde47f1aeb59)
174+
* [Head First Design Patterns: A Brain-Friendly Guide](https://www.amazon.com/gp/product/0596007124/ref=as_li_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=0596007124&linkCode=as2&tag=javadesignpat-20&linkId=6b8b6eea86021af6c8e3cd3fc382cb5b)

0 commit comments

Comments
 (0)