Neste exercício devemos escrever um método para a classe MyCalculator que pegue o input de dois ints n
e p
.
Pede-se para que declaremos duas exceções: uma se ambos os inputs forem 0 e outra se algum dos inputs forem negativos.
Para resolver o problema, fazemos um simples if
e um else if
. Entretanto, ao invés de simplesmente imprimirmos um System.out.println("Exceção")
, usamos o throw new Exception
, dizendo que vamos "pegar" a exceção e, a partir da exceção que for reconhecida pela máquina, passamos a mensagem específica.
É importante lembrar que também devemos passar o throws Exception
na declaração do método. Assim, o resultado final será o seguinte:
class MyCalculator {
public int power(int n, int p) throws Exception {
if (n == 0 && p == 0) {
throw new Exception("n and p should not be zero.");
} else if (n < 0 || p < 0) {
throw new Exception("n or p should not be negative.");
}
return (int) Math.pow(n, p);
}
}
=========
Referências
How to throw Exceptions : Oracle
============
Essa publicação faz parte de uma série de exercícios resolvidos em Java no HackerRank. Acesse a série completa:
- HackerRank #6 | Scanner e End-of-file
- HackerRank #7 | Int to String / String to Int
- HackerRank #8 | Date and Time
- HackerRank #9 | Static Initializer Block
- HackerRank #10 | Currency Formatter
- HackerRank #11 | DataTypes
- HackerRank #12 | Strings Introduction
- HackerRank #13 | Substring Comparisons
- HackerRank #14 | Abstract Class
- HackerRank #18 | BigInteger
- HackerRank #19 | Loops II
- HackerRank #20 | String Reverse
- HackerRank #23 | Instanceof keyword
- HackerRank #26 | Generics
- HackerRank #27 | 1D Array
- HackerRank #28 | Anagrams
- HackerRank #33 | Arraylist
- HackerRank #34 | Exception Handling Try / Catch
- HackerRank #36 | Exception Handling
- HackerRank #37 | List
- HackerRank #38 | SubArray
- HackerRank #40 | Java Dequeue
- HackerRank #39 | HashSet
Top comments (0)