Generic으로 만들어 사용하기

박근수·2024년 11월 26일
0

01. raw type은 사용하지 마라

만약 type parameter가 없다면

//(비권장 코드)
List test = new ArraysList<>();
tset.add("no1");
test.add(1);

//unbounded wildcard type
private int add(List<?> s1){
	s1.add(1); //error
    return 1;
}

명확하게 타입 추론이 가능하게 하자

그렇지 않다면 런타임 시 예외가 발생할 수 있다.

List< Objct > 는 명확하게 내가 Objct라는 타입을 제시한 것임
하단과 같이 merge해 버린다면, 다른 타입이 들어왔을 때 문제가 생김

//잘못된 코드
static List listMerge(List a, List b){
	List c = new ArrayList();
    c.addAll(a);
    c.addAll(b);
    
    return c;
}

Generic Class / Generic Interface

List<String> test = new ArraysList<>(); 

//List : Generic Interface
public interface List<E> extends Collecntion<E> {}

//ArrayList : Generic class
public class ArrayList<E> extends AbstractList<E>
	implments List<E>, RadomAccess, Cloneable, java.io.Serializable

예외적인 케이스를 제외하면 명확히 타입을 명시하도록 하자.

02. 비검사 경고를 제거하라

Complier가 보내는 warning을 제거하라

Warning이 print 된다는 것은 말 그대로 경고를 보내는 것이다.


만약 안전하다고 확신할 수 있으면 @SupperWarnings("unckecker")를 통해 경고를 숨기자

단점

* 서버의 치명적인 에러 감지 불가
* 잘못 작성한 코드 감지 불가
* 내가 만든 많은 waning을 통해, 정작 봐야 할 중요한 warning을 볼 수 없음

03. 배열 대신 리스트를 사용하라

배열 보다는 제네릭

//Runtime Error
Object[] objects = new Long[1];
objects[0] = "test";

//Compile Error
List<Object> objectList = new ArrayList<Long>();
profile
개발블로그

0개의 댓글