Nesse exercício, testamos uma situação com uma classe abstrata. Classes abstratas não podem ter instâncias, por isso a resolução inclui criar uma nova classe que extenda à classe mâe.
Nesse caso, como a classe mãe já tem o getter que vamos usar, só precisamos sobreescrever o método com a palavras reservada @Override
. O código é praticamente o mesmo (inclui o void
, o setTitle
e a String s
), mas precisamos usar a palavra super.
para demarcar que estamos acessando uma função/método da classe mãe.
=========
O passo a passo é:
- Criar uma
class MyBook
que extenda àclass Book
- Sobreescrever o método
void setTitle(String s)
- Especificar que o método chama a classe mãe a partir da palavra
super.
=========
Código final:
import java.util.*;
abstract class Book{
String title;
abstract void setTitle(String s);
String getTitle(){
return title;
}
}
class MyBook extends Book {
@Override
void setTitle(String s) {
super.title = s;
}
}
/... aqui entra a public class Main
Enter fullscreen mode Exit fullscreen mode
============
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 #39 | HashSet
- HackerRank #40 | Java Dequeue
暂无评论内容