1. 제네릭에 대한 설명으로 틀린 것은 무엇입니까?
(1) 컴파일 시 강한 타입 체크를 할 수 있다.
(2) 타입 변환을 제거한다.
(3) 제네릭 타입은 타입 파라미터를 가지는 제네릭 클래스와 인터페이스를 말한다.
(4) 제네릭 메소드는 리턴 타입으로 타입 파라미터를 가질 수 없다. → 가질 수 있다.
2. ContainerExample 클래스의 main() 메소드는 Container 제네릭 타입을 사용하고 있습니다. main() 메소드에서 사용하는 방법을 참고해서 Container 제네릭 타입을 선언해보세요.
public class ContainerExample {
public static void main(String[] args){
Container<String> container1 = new Container<String>();
container1.set("홍길동");
String str = container1.get();
Container<Integer> container2 = new Container<Integer>();
container2.set(6);
Integer value = container2.get();
}
}
정답:
public class Container<T> {
private T t;
public void set(T t){
this.t = t;
}
public T get(){
return t;
}
}
3. ContainerExample 클래스의 main() 메소드는 Container 제네릭 타입을 사용하고 있습니다. main() 메소드에서 사용하는 방법을 참고해서 Container 제네릭 타입을 선언해보세요.
package ch13.check.exam03;
public class ContainerExample {
public static void main(String[] args){
Container<String, String> container1 = new Container<String, String>();
container1.set("홍길동", "도적");
String name1 = container1.getKey();
String job = container1.getValue();
Container<String, Integer> container2 = new Container<String, Integer>();
container2.set("홍길동", 35);
String name2 = container2.getKey();
Integer age = container2.getValue();
}
}
정답:
public class Container<T, G> {
private T t;
private G g;
public void set(T t, G g){
this.t = t;
this.g = g;
}
public T getKey(){
return t;
}
public G getValue(){
return g;
}
}
4. 다음 Util 클래스의 정적 getValue() 메소드는 첫 번째 매개값으로 Pair 타입과 하위 타입만 받고, 두 번째 매개값으로 키값을 받습니다. 리턴값은 키값이 일치할 경우 Pair에 저장된 값을 리턴하고, 일치하지 않으면 null을 리턴하도록 Util 클래스와 getValue() 제네릭 메소드를 작성해보세요.
public class UtilExample {
public static void main(String[] args){
Pair<String, Integer> pair = new Pair<>("홍길동", 35);
Integer age = Util.getValue(pair, "홍길동");
System.out.println(age);
ChildPair<String, Integer> childPair = new ChildPair<>("홍삼원", 20);
Integer childAge = Util.getValue(childPair, "홍삼순");
System.out.println(childAge);
/* OtherPair<String, Integer> otherPair = new OtherPair<>("홍삼원", 20);
OtherPair는 Pair를 상속하지 않으므로 컴파일 에러 발생;*/
}
}
public class Pair <K, V>{
private K key;
private V value;
public Pair(K key, V value){
this.key = key;
this.value = value;
}
public K getKey() {
return key;
}
public V getValue(){
return value;
}
}
public class ChildPair<K, V> extends Pair<K, V>{
public ChildPair(K k, V v){
super(k, v);
}
}
public class OtherPair <K, V>{
private K key;
private V value;
public OtherPair(K key, V value){
this.key = key;
this.value = value;
}
public K getKey(){ return key;}
public V getValue(){ return value;}
}
정답:
public class Util {
/* 첫 번쨰 방법
public static<K, V> V getValue(Pair<K, V> p, K k){
if(p.getKey() == k){
return p.getValue();
}else {
return null;
}
}*/
//두 번째 방법
public static <P extends Pair<K, V>, K, V> V getValue(P p, K k) {
if (p.getKey() == k) {
return p.getValue();
} else {
return null;
}
}
}
'언어 > JAVA' 카테고리의 다른 글
String.valueOf()과 Object.toString() 차이점 (0) | 2023.05.02 |
---|---|
StringTokenizer (0) | 2023.04.02 |
[멀티 스레드2] (0) | 2023.02.27 |
[chapter 9] 확인 문제 (0) | 2023.02.06 |
[중첩 인터페이스] 익명 객체(익명 자식 객체, 익명 구현 객체) (0) | 2023.02.05 |