22일차 강의 정리


1. ArrayList

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
    public static void main(String[] args) {
        //ArrayList
        //crud
        ArrayList list;
        list = new ArrayList();
        
        list.add(1);
        list.add(2);
        list.add(3);
        
        System.out.println("---------출력1---------");
        for (int i = 0; i < list.size(); i++) {
            System.out.println("list["+i+"]="+list.get(i));
        }
//        System.out.println("---------출력2---------");
//        Iterator ite = list.iterator();
//        int idx=0;
//        while(ite.hasNext()){
//            System.out.println("list["+(idx++)+"]="+ite.next());
//        }
        ArrayList list2 = (ArrayList) list.clone();    //clone -> return타입이 Object
        
        list2.set(1"이");
        list2.addAll(list);    //뒤에 list 모두 추가
        
        System.out.println("---------출력3---------");
        System.out.println("\"이\"가 있는가?"+list2.contains("이"));    //true/false 출력
        System.out.println("3의 인덱스번호: "+list2.indexOf(3));        //값이없으면 -1 출력,인덱스번호출력
        
        for (int i = 0; i < list2.size(); i++) {
            System.out.println("list2["+i+"]="+list2.get(i));
        }
        
        System.out.println("값\'3\'의 인덱스번호 : "+list2.lastIndexOf(3));    //"3"이 들어있는 인덱스번호 출력
        
//        list2.clear();
        System.out.println("list2 가 비어있는가? "+list2.isEmpty());
//        list2.remove(1);        //인덱스1의 값 삭제
//        list2.remove(new Integer(3));    //값이 3 을 삭제
//        list2.removeAll(list);    //전부삭제
        
        System.out.println("======================================");
        Object[] obj = list2.toArray();
        for (int i = 0; i < list2.size(); i++) {
            System.out.println("list2["+i+"]="+list2.get(i));
        }
//        System.out.println("---------출력4---------");
//        for (int i = 0; i < obj.length; i++) {
//            System.out.println(obj[i]);
//        }
        System.out.println("---------출력5---------");
        ArrayList list3 = new ArrayList(list2);
        for (int i = 0; i < list3.size(); i++) {
            System.out.print("list3["+i+"]="+list3.get(i)+" / ");
        }
        list3.clear();
        
    }//main end
cs

결과


2. LinkedList

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
    public static void main(String[] args) {
        //LinkedList
        LinkedList list;
        list = new LinkedList();
        
        list.add(1);
        list.add(2);
        list.add(3);
        
        System.out.println(list.get(1));
        System.out.println("-------------------------1---");
        for(int i=0; i<list.size(); i++){
            System.out.println("list["+i+"]="+list.get(i));
        }
        System.out.println("-------------------------2---");
        Iterator ite = list.iterator();
        int idx =0;
        while(ite.hasNext()){
            System.out.println("list["+(idx++)+"]="+ite.next());
        }
        System.out.println("-------------------------3---");
        LinkedList list2 = new LinkedList(list);
        for(int i=0; i<list2.size(); i++){
            System.out.println("list2["+i+"]="+list2.get(i));
        }
        System.out.println("-------------------------4---");
        List list3 = (List)list2.clone();
        for(int i=0; i<list3.size(); i++){
            System.out.println("list3["+i+"]="+list3.get(i));
        }
    }
cs

결과


3. ArrayList & LinkedList 비교

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
    public static void main(String[] args) {
        //ArrayList & LinkedList 비교
        ArrayList arr = new ArrayList();
        LinkedList link = new LinkedList();
        int temp = 100000;
        
        //ADD/////////////////////////////////////////////////////////////////
        Date time1 = new Date();
        long start1 = time1.getTime();        //ArrayList 시작 시간
        
        for (int i = 0; i < temp; i++) {
            arr.add(String.valueOf(i));
        }
        time1 = new Date();
        long end1 = time1.getTime();        //ArrayList 종료 시간
        System.out.println("ArrayList - add time : "+(end1-start1)+" nanoSec");
        
        Date time2 = new Date();
        long start2 = time2.getTime();        //LinkedList 시작 시간
        for (int i = 0; i < temp; i++) {
            link.add(String.valueOf(i));
        }
        time2 = new Date();
        long end2 = time2.getTime();        //LinkedList 종료 시간
        System.out.println("LinkedList - add time : "+(end2-start2)+" nanoSec");
        
        //GET//////////////////////////////////////////////////////////////////
        time1 = new Date();
        start1 = time1.getTime();            //ArrayList 시작 시간
        
        for (int i = 0; i < temp; i++) {
            arr.get(i);
        }
        time1 = new Date();
        end1 = time1.getTime();                //ArrayList 종료 시간
        System.out.println("ArrayList - get time : "+(end1-start1)+" nanoSec");
        
        time2 = new Date();
        start2 = time2.getTime();            //LinkedList 시작 시간
        for (int i = 0; i < temp; i++) {
            link.get(i);
        }
        time2 = new Date();
        end2 = time2.getTime();                //LinkedList 종료 시간
        System.out.println("LinkedList - get time : "+(end2-start2)+" nanoSec");        
 
    }//main end
cs

결과



'* Programming > JAVA' 카테고리의 다른 글

DAY22 컬렉션프레임워크 Map  (0) 2016.08.03
DAY22 컬렉션프레임워크 Set  (0) 2016.08.03
DAY22 컬렉션프레임워크 Vector  (0) 2016.08.03
DAY21 컬렉션 프레임워크  (0) 2016.08.03
DAY21 싱글톤 패턴  (0) 2016.08.02

22일차 강의 정리


소스1 * import 는 import java.util.*; 로 고정

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
public class Ex01 {
    public static void main(String[] args) {
        //Vector
        //data 관리 -  정보 관리
        //변수,,배열(정적),,->동적할당
        //jdk 1.0 ~ Vector(List, Set) - 입력, 삭제
        //List - 순서, 인덱스, 값의 중복, 수정, 추가
        //Set - 집합, 순서x, 중복x, 수정,추가개념 x
        
        Vector vec = new Vector();
        System.out.println("1 capasity: "+vec.capacity());    //처음 공간 10
        vec.add("일");
        vec.add("이");
        vec.add("삼");
        vec.addElement("사");
        
        vec.trimToSize();    //없는 공간 자르기
        System.out.println("2 capasity: "+vec.capacity());    //잘라내서 저장공간4
        
        vec.add("이");
        System.out.println("3 capasity: "+vec.capacity());    //추가하면 +4(기존용량의 2배로증가)
        vec.add(3);
        vec.addElement(4);
        System.out.println("4 capasity: "+vec.capacity());    
        System.out.println("---------------------------------");
        System.out.println("size: "+vec.size());    //실제들어있는 용량
        
        vec.remove(1);                //idx번호 1 삭제
        vec.removeElement("삼");    //() 값 삭제
        //출력방법 1
        for (int i = 0; i < vec.size(); i++) {
            System.out.print(vec.get(i)+" ");
        }
        System.out.println("\n---------------------------------");
        //출력방법 2
        Enumeration enu = vec.elements();
        while(enu.hasMoreElements()){
            System.out.println(enu.nextElement());
        }
 
    }
}
cs

처음 용량을 10으로 할당된다.

처음의 용량을 넘어서 값이 추가 된다면 현재의 용량의 X2 로 증가한다.

결과1

소스2

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
public class Ex02 {
    public static void main(String[] args) {
        Vector vec = new Vector(53);        //(초기용량, 증가량)
        System.out.println("1 capasity: "+vec.capacity());
        System.out.println("size: "+vec.size());    //실제들어있는 용량
        
        vec.add(1);
        vec.add(2);
        vec.add("일");
        vec.add("이");
        vec.add("삼");
        System.out.println("2 capasity: "+vec.capacity());
        System.out.println("size: "+vec.size());
        
        vec.add("사");    //초기용량 5를 넘어선순간 증가량+3을 더해 공간이 8로 증가
        System.out.println("3 capasity: "+vec.capacity());
        System.out.println("size: "+vec.size());
        
        System.out.println("--------------------------");
        System.out.println("인덱스번호(2)의 값: "+vec.get(2));
        System.out.println("인덱스번호(3)의 값: "+vec.elementAt(3));
        System.out.println("\"3\"이 있는가? "+vec.contains(new Integer(3)));//내부에 값이 있는지 true/false 
        System.out.println("내용(이)의 인덱스번호 : "+vec.indexOf("이"));    //"이"라는 값의 인덱스번호 출력
        
        System.out.println("--------------------------");
        Enumeration enu = vec.elements();
        while(enu.hasMoreElements()){
            System.out.print(enu.nextElement()+" ");
        }
        System.out.println();
        //커서가 끝까지 가 있어서 다시출력하기위해서는 객체다시생성필요
//        System.out.println("---------------------------------------------------");
//        enu = vec.elements();        
//        while(enu.hasMoreElements()){
//            System.out.println(enu.nextElement());
//        }    
        System.out.println("--------------------------");
//        vec.clear();        //모든 내용 삭제
//        vec.trimToSize();    //모든 용량 삭제
        System.out.println("3 capasity: "+vec.capacity());
        System.out.println("size: "+vec.size());
 
        System.out.println("--------------------------");
        System.out.println("--------------------------");
        Iterator ite = vec.iterator();        //Enumeration와 동일 커서
        while(ite.hasNext()){
            System.out.print(ite.next()+" ");
//            ite.remove();        //vec 내용을 삭제
//        }
//        System.out.println("--------------------------");
//        System.out.println("--------------------------");
//        ite = vec.iterator();        //Enumeration와 동일 커서
//        while(ite.hasNext()){
//            System.out.println(ite.next());    //remove 로 삭제되어 아무것도 출력없음
//            ite.remove();
        }
        System.out.println();
        System.out.println("=======================================");
        Object[] arr = new Object[vec.size()+1];
        vec.copyInto(arr);        //백터 -> 배열로
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i]+" ");        //null값은 null로 출력
        }
 
    }//main end
}//class end
cs

결과2


21일차 강의 정리

* 이번강의는 기초적인것으로 모아넣었다.

다음 강의에 분리해서 자세히 볼 예정이다.


1. ArrayList / LinkedList

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
 
public class Ex03 {
    public static void main(String[] args) {
        ArrayList list = new ArrayList(6);
//      LinkedList list = new LinkedList();    //거의 동일
        
        list.add(new Integer(1));
        System.out.println(list.size()+"개");
        list.add(2);
        System.out.println(list.size()+"개");
        list.add(3);
        System.out.println(list.size()+"개");
        list.add(4);
        list.add(new String("오"));
        list.add("육");
        
        list.remove(1);    //인덱스번호 1 번 delete
//        list.clear();    //delete All
        list.set(4new Integer(7));    //수정
        list.add(410);    //4번째 자리에 10 추가
        
        //출력방법 1
//        for (int i = 0; i < list.size(); i++) {        
//            System.out.println(list.get(i));
//        }
        //출력방법 2
        Iterator ite = list.iterator();        //iterator은 모든 컬렉션프레임워크가 사용할수있다
        while(ite.hasNext()==true){
            System.out.print(ite.next()+" ");
        }
        
    }//main end
}//class end
cs

결과


2. Vector

Data 관리 - 정보관리

배열은 정적이라면, Vector은 동적이다.

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import java.util.Enumeration;
import java.util.Iterator;
import java.util.Vector;
 
public class Ex04 {
 
    public static void main(String[] args) {
        Vector vec = new Vector();
        vec.add("abc");
        vec.add("def");
        vec.add("gji");
        
        //출력방법 1
        for (int i = 0; i < vec.size(); i++) {
            System.out.println("idx:"+i+", value:"+vec.get(i));
        }
        System.out.println("=============================");
        //출력방법 2
        Enumeration ve = vec.elements();    //vector만을위한것 (열거자~라고 명명)
        while(ve.hasMoreElements()==true){
            System.out.println(ve.nextElement());
        }
        System.out.println("=============================");
        ve = vec.elements();     //새롭게 객채를 생성하지않으면 출력이 되지않는다. 위에서 넘어가있기때문
        while(ve.hasMoreElements()==true){
            System.out.println(ve.nextElement());
        }
        //출력방법 3
//        Iterator ite = vec.iterator();        //iterator은 모든 컬렉션프레임워크가 사용할수있다 (반복자~라고 명명)
//        while(ite.hasNext()==true){
//            System.out.println(ite.next());
//        }
 
    }//main end
}//class end
cs

결과


3. Set type

순서가 없다.

동일한 값을 넣어도 중복되어 하나만 출력된다.

HashSet -  집합의 개념으로 순서x

TreeSet - 뒤이어질 Map 승계, 출력시 순서를 보장받음

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import java.util.HashSet;
import java.util.Iterator;
 
public class Ex05 {
    public static void main(String[] args) {

        HashSet set = new HashSet();
        set.add("일");
        set.add("이");
        set.add("삼");
        set.add("네엣");
        set.add("다섯");
        set.add("이");    //중복x
        set.remove("이");
 
        Iterator ite = set.iterator();
        while(ite.hasNext()){
            System.out.println(ite.next());
        }
    }//main end
}//class end
cs

결과


4. Map type

list - idx : value

map - key : value

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import java.util.HashMap;
import java.util.*;
 
public class Ex06 {
    public static void main(String[] args) {
        HashMap map = new HashMap();
        map.put(02);
        map.put("1"4);
        map.put("이""123");
        map.put("abc""abcde");
        map.put("1""abcdeffffff");
        
//        System.out.println(map.get(0));
//        System.out.println(map.get("1"));
//        System.out.println(map.get("이"));
//        System.out.println(map.get("abc"));
//        System.out.println(map.get("1"));    //키값의 중복은 허용하지않는다
        
        Set keys = map.keySet();
        Iterator ite = keys.iterator();        //key 값
        while(ite.hasNext()){
            String key = String.valueOf(ite.next());
            System.out.print(key+":");
            System.out.println(map.get(key));
        }
    }//main end
}//class end
cs

결과



21일차 강의 정리


1. 싱글톤 패턴(singleton pattern)

싱글톤패턴은 인스턴스가 사용될 때 똑같은 인스턴스를 만들어 내는 것이 아니라 

동일 인스턴스를 여러 곳에서 공유되고 사용할수 있는 것을 말한다.

싱글톤 패턴을 적용한 클래스는 단 하나의 객체만 만들어 질 수 있다.

반드시 디폴트 생성자를 구현 해야한다.

소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
class Am02{
    int a=1000;
    private static Am02 me;
 
    private Am02(){ // 반드시 디폴트 생성자를 구현
        System.out.println("생성자 호출");
    }
    
    public static Am02 func1(){
        if(me ==null){
            me = new Am02();    //생성자 한번만 호출
        }
        return me;
    }//func1() end
}//Am02 class end
public class Ex02 {
    public static void main(String[] args) {
        // 싱글톤패턴
        Am02 me = Am02.func1();        //me 객체생성
        Am02 me2 = Am02.func1();    //me2 객체생성
 
        me.a=me.a+100;                //me 객체의 a에+100
        System.out.println("me의 a= "+me.a);
        System.out.println("me2의 a= "+me2.a);    //me2 객체에 공유가 되서 me와 같은 결과
        
    }//main end
}//class end
cs

결과

소스2 (오버라이드!)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
class Am03{
    Am03 me;
    int idx=1;
    public Am03(int a) {
        super();    //Object
        me = this;
        System.out.println("Am03 디폴트 생성자/a = "+a);
    }
    @Override
    public String toString() {
        System.out.println(idx);
        return ""+idx;
    }
}//Am03 class end
 
class Amm03 extends Am03{        //Am03상속
    int idx=2;
    public Amm03() {
        super(4);
        System.out.println("Amm03 디폴트 생성자");
    }
    public Amm03(int a) {
        this();
        System.out.println("Amm03 생성자/a ="+a);
    }
    public Am03 func01(){
        System.out.println("func01()");
        return super.me;        //객체출력은 toString을 출력..(오버라이드된 값 출력)
    };
    @Override
    public String toString() {        //Am03의 toString 오버라이드
        System.out.println("Amm03 idx -> "+idx);
        return ""+idx;
    }
    @Override
    public boolean equals(Object obj) {
        return idx==((Am03)obj).idx;
    }
}//Amm03 class end
 
public class Ex03 {
    public Ex03() {
        System.out.println("me create");
    }
    
    public static void main(String[] args) {
        Amm03 mm= new Amm03(7);
        System.out.println("--------------------------");
        Am03 mm2 = mm.func01();
        System.out.println("------------mm--------------");
        System.out.println("mm -> "+mm);
        System.out.println("------------mm2-------------");
        System.out.println("mm2 ->"+mm2);
        System.out.println("--------------------------");
        System.out.println(mm2.equals(mm));
    }//main end
}//class end
cs

결과2



'* Programming > JAVA' 카테고리의 다른 글

DAY22 컬렉션프레임워크 Vector  (0) 2016.08.03
DAY21 컬렉션 프레임워크  (0) 2016.08.03
DAY20 Calendar/Date/Random/Arrays Class  (0) 2016.08.02
DAY20 Object클래스,리플렉션  (0) 2016.08.02
DAY20 this/super  (0) 2016.08.02

20일차 강의 정리


1. Calendar Class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import java.util.Calendar;
 
public class Ex02 {
    public static void main(String[] args) {
        //캘린더
        Calendar now;
        now = Calendar.getInstance();
        
        int year = now.get(Calendar.YEAR);
        System.out.print(year+"년 ");
        int month = now.get(Calendar.MONTH);
        System.out.print(month+1+"월 ");
        int day = now.get(Calendar.DATE);
        System.out.print(day+"일 ");
 
        int week = now.get(Calendar.DAY_OF_WEEK);
        char[] weeks={'일','월','화','수','목','금','토'};
        System.out.println(weeks[week-1]+"요일");
        
        int ampm = now.get(Calendar.AM_PM);
        if(ampm==0){
            System.out.print("AM ");
        }else{
            System.out.print("PM ");
        }
        int hour = now.get(Calendar.HOUR);
        System.out.print(hour+":");
        int min = now.get(Calendar.MINUTE);
        System.out.print(min+":");
        int sec = now.get(Calendar.SECOND);
        System.out.println(sec);
        
        int hhour = now.get(Calendar.HOUR_OF_DAY);
        System.out.println(hhour+":"+min+":"+sec);
        
        int cntDay = now.get(Calendar.DAY_OF_YEAR);
        System.out.println(cntDay+"일째 입니다.");
        
        now.set(year, month, 4);
 
    }
}
cs

결과


2. Date Class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
import java.text.SimpleDateFormat;
import java.util.Date;
 
public class Ex03 {
    public static void main(String[] args) {
        //Date
        Date now = new Date();
        System.out.println(now);
        System.out.println(now.toString());
        System.out.println("-------------------------------");
        
        SimpleDateFormat sdf;
        sdf = new SimpleDateFormat("yyyy년 mm월 dd일 hh시 mm분 ss초");
        String kor = sdf.format(now);
        System.out.println(kor);
        System.out.println(now.getMonth());    //월 은 0부터시작해서 이번달이 7월이면 6이 출력
        System.out.println(now.getTime());
 
    }
 
}
cs

결과


3. Random Class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import java.util.Random;
 
public class Ex04 {
 
    public static void main(String[] args) {
        //Random
        double ran = Math.random();    
        System.out.println(ran);
        
        Random ran2 = new Random();
        System.out.println(ran2.nextInt());        //int자료형의 표현 범위 내에서 난수발생
        System.out.println(ran2.nextLong());    //long자료형의 표현 범위 내에서 난수발생
        System.out.println(ran2.nextDouble());    //= Math.random()
        //0~9난수
        System.out.println(ran2.nextInt(10));     //0<=ran2<인자
        //1~45
        System.out.println(ran2.nextInt(45)+1);
    }
 
}
cs

결과


4. Arrays Class

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import java.util.Arrays;
 
public class Ex05 {
    public static void main(String[] args) {
        //Arrays
        int[] arr1 = {30,45,20,3,1,35};
        Arrays.sort(arr1);        //정렬
        for (int i = 0; i < arr1.length; i++) {
            System.out.print(arr1[i]+" ");
        }
        System.out.println();
 
        int[] arr2 = new int[10];
        Arrays.fill(arr2, 11);
        Arrays.fill(arr2, 3,5,3);         //arr2에서 자리번호 3~5까지 2로 채워넣는다
        for (int i = 0; i < arr2.length; i++) {
            System.out.print(arr2[i]+" ");
        }
    }
}
cs

결과


응용 소스

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import java.util.Arrays;
 
public class Ex06 {
    public static void main(String[] args) {
        
        int[] lotto = {30,45,20,3,1,35};
        Arrays.sort(lotto);        //정렬
        int idx = Arrays.binarySearch(lotto, 30);
        
        System.out.println("30의 자리위치: "+idx);
        int[] arr2 = Arrays.copyOfRange(lotto, 1,3);    //복사-> 자리번호1에서 3이전까지
        System.out.println(Arrays.toString(arr2));        //복사한것 출력
        
        System.out.println("====================================");
        String[] names={"홍길동","김만수","김철수","고경아"};
        System.out.println(Arrays.toString(names));    //정렬 전
        Arrays.sort(names);        //binarySearch하기위해 필요(정렬)
        int idx2 = Arrays.binarySearch(names, "김만수");
        System.out.println("\'김만수\'의 자리 위치: "+idx2);
        System.out.println(Arrays.toString(names));    //정렬 후
        
        System.out.println("====================================");
        System.out.println("====================================");
//        String[] arr = Arrays.copyOf(names, names.length);    //복사, 몇번까지
        String[] arr = Arrays.copyOfRange(names, 1,3);        //복사 자리번호1에서 3전까지
        names[1]="바꿈";
        System.out.println(Arrays.toString(arr));
        System.out.println(Arrays.toString(names));
 
    }
}
cs

결과


'* Programming > JAVA' 카테고리의 다른 글

DAY21 컬렉션 프레임워크  (0) 2016.08.03
DAY21 싱글톤 패턴  (0) 2016.08.02
DAY20 Object클래스,리플렉션  (0) 2016.08.02
DAY20 this/super  (0) 2016.08.02
DAY19 익명클래스  (0) 2016.08.02

+ Recent posts