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

결과



+ Recent posts