15.  IO(Input Output)

(1) java.io

(2) 모든 입출력은 Stream으로 구현된다.

- 단방향

- 원칙적으로 순차적 

- 지연 발생 가능

- 어떤 장치를 사용 하던 간에 사용법은 거의 동일하다 

(3) 자바에서 제공하는 Stream 방식

1) Byte Stream

- 1byte씩 기계가 사용하기 편한 방식 

- InputStream, OutputStream

- 속도가 빠름

- FileInputStream ,FileOutputStream

- DataInputStream ,DataOutputStream

2) Character Stream (내부적으로 ByteStream으로 변환)

- 2byte씩 사람이 사용하기 편한 방식

어짜피byte Stream 으로 바껴서 사용되기 때문에 성능이 저하된다.

-Filter 방식

-Reader, Writer

도스창에서

Copy con 새로만들파일명

Txt 경우 글써놓고ctrl+z


* Print Stream

Serializable (직렬화)한줄로처리된다.

쓰는 방식 : public Interface Serializable {} 

* PrintWrite :문자 Stream 방식 (이것저것 좋은 기능은 다 넣은 것)

ByteStream

- Object InputStream , ObjectOutputStream

->객체(복잡한 데이터), 다양한 ,많은 데이터들을 하나의 객체로 묶어서 넘길 수 있다.



bytestream


bytestream.zip


charstream


charstream.zip





14. 예외 처리

(1) 정의 : 예외가 발생했을 때 예외에 대한 제어권을 시스템(JVM)이 아니라 개발자가 가질 수 있게 하는 방법

(2) why?

1) 예외가 발생했을 때 메시지에 대한 표현 문제

(3) try, catch, throw, finally

(4) try / catch throw

(5) 예외 클래스

Throwable

Exception 소프트웨어 // 

- RuntimeException //해도되고안해도되는 것

- IOException // 반드시해야된다.

Error 하드웨어에 대한 문제점 //수많은 자식클래스들이 있다.

(6) throw // 일부로 예외를 발생 시켜, catch가 잡게끔하기

예외처리를 다른 곳에 하기 위해 쓰임

1) block안에서만 사용하는

2) 단 1개만 던질 수 있다.여러 개 (x)

3) 예외를 발생시킨 후(예외가 발생한 후) 에 던짐

(7) throws

1) 예외가 발생하기 전에 던짐 (혹시나 발생할 수 있으니 대신 처리해달라)

2) 여러 개의 예외를 던짐

3) 메서드 밖에서만 사용

(8) finally

1) block

2) try/catch와 함께 사용

Try{

}

Catch(..){

}

Finally{

}

3) 반드시 실행을 보장받을 수 있는 영역



'Java' 카테고리의 다른 글

[JAVA 정리] 16. Thread  (0) 2017.06.24
[JAVA 정리] 15. IO(Input Output)  (0) 2017.06.24
[JAVA 정리] 13. Generic  (0) 2017.06.24
[JAVA 정리] 12. 유용한 클래스들 (java.lang, java.util, java.text)  (0) 2017.06.24
[JAVA 정리] 11. Interface  (0) 2017.06.24

13. Generic

(1) 용도

1) 특정 ( 데이터)타입 (객체형)을 미리 검사

  - 사전에 잘못된 데이터 타입을 미리 체크

2) c++의 Template

(2) 문법 

1) 만드는 법 

 - class클래스명<이름>{…} // 이렇게 만든 클래스는 제네릭 클래스

2) 사용하는 법

 - 클래스명<데이터타입>변수명= new 클래스명<데이터타입>();




12. 유용한 클래스들(java.lang, java.util, java.text)

(1) Wrapper Class

Int I =10; // 비객체

i.변수,메서드(x)

Integer I =10; //객체

i.변수,메서드(o)

(2) 시간측정

System.currentTimeMillis()

(3) 문자열 추출하기

String - >split()

(4) Random

(5) 날짜와 시간 : Date, Calendar

(6) 문자열 과싱하기 :StringTokenizer

(7) ***** Collection

   Set List

1) set

 - 중복된 데이터를 저장하지 않는다.

 - 정렬 순서가 없다.

 - HashSet, LinkedHashSet, …

(SortedSet // Set계열의 자식 인터페이스)

2) SortedSet

 - 정렬 기능 추가

 - TreeSet, …

3) List

 - 중복된 데이터를 저장

 - 정렬 순서가 있다.

 - ArrayList, Vector, LinkedList, …

4) Map

- Collection의 자식이 아니라, add 대신 put을 사용

- 키와값을한쌍으로 묶어서 쓴다.

- HashMap, HashTable, …


* 배열이나 컬렉션에서 좀 더 편리하게 사용할 수 있는 반복문

For(변수 :배열or컬렉션){

}

'Java' 카테고리의 다른 글

[JAVA 정리] 14. 예외 처리  (0) 2017.06.24
[JAVA 정리] 13. Generic  (0) 2017.06.24
[JAVA 정리] 11. Interface  (0) 2017.06.24
[JAVA 정리] 10. Package  (0) 2017.06.24
[JAVA 정리] 9. 클래스3  (0) 2017.06.24

11. interface

(1) 클래스를 만들기 위한 설계도

(2) 표준화,일관성

(3) 순수(완전)추상 클래스

// 100퍼센트 추상메서드

(4) 다중 상속 지원

(5) 클래스에게 상속할 경우 implements 키워드를 사용.

(6) 인터페이스에게 상속할 경우 extends 키워드 사용

'Java' 카테고리의 다른 글

[JAVA 정리] 13. Generic  (0) 2017.06.24
[JAVA 정리] 12. 유용한 클래스들 (java.lang, java.util, java.text)  (0) 2017.06.24
[JAVA 정리] 10. Package  (0) 2017.06.24
[JAVA 정리] 9. 클래스3  (0) 2017.06.24
[JAVA 정리] 8. 클래스2  (0) 2017.06.24

10. Package

(1) 묶음(클래스)

(2) 목적

(3) 쟤료:폴더

(4) 패키지는 상위폴더에서 실행해야함.

Java BookPack.BookTest

(5) classpath

(6) jar

(7) 패키지 컴파일

(8) java.lang

(9) src zip


Protected 

패키지 안에서 외부로부터의 접근을 막아준다.

'Java' 카테고리의 다른 글

[JAVA 정리] 12. 유용한 클래스들 (java.lang, java.util, java.text)  (0) 2017.06.24
[JAVA 정리] 11. Interface  (0) 2017.06.24
[JAVA 정리] 9. 클래스3  (0) 2017.06.24
[JAVA 정리] 8. 클래스2  (0) 2017.06.24
[JAVA 정리] 7. Array 배열  (0) 2017.06.24

prjClass3.zip


9. 클래스 3 :상속

(1) 상속 예외

   1)생성자

   2) private

(2) 부모의 생성자를 호출 할 수 있다.

Super(….) – this(…)

단 주소만 다름

This 현재 자신의 주소 super 은 부모의 주소

Super.변수 또는 super.메서드() – this.변수 또는 메서드

Super도 참조 변수다

반드시 생성자 안에서만 호출 가능 일반 메서드 에서는 호출 불가능 

이것은 this 도 마찬가지!

"반드시 첫줄에 작성"

(3) 생성자의 호출 순서

(4) 상속은 확장의 개념이다.

(5) 자바는 단일상속만을 지원한다.

부모는 반드시 가장 기본적인 것만 가지고 있어야 된다.

- 상속 설계 과제

(6) 부모 클래스와 자식 클래스의 참조 관계

- 서로 다른 클래스는 참조할 수 없다.

- 단, 부모 자식관계는 참조 할 수 있다.

- 단, 부모만 자식을 참조 할 수 있다.

- 단, 부모는 자신이 물려준 범위 내에서만 참조가 가능하다. 

    1) 인스턴스가 결정되지 않았을 때

O - > A, B

    O(부모) A, B(자식)

A a1 = New A();

O a2 = new ?(); // 주소는 임시로 받음.

… 

A a3 = (A)a2 ; //캐스팅으로 넘겨주기.

    2) 여러 개의 자식 인스턴스를 배열로 관리하기 위해서

A a1 = new A();

B a1 = new B();

C a1 = new C();

D a1 = new D();

O o1[] = {a1, b1, c1, d1, new E()};


(7) 메서드의오버라이딩(Overriding)

메서드에서만 적용된다.

1) 재정의(부모로부터 상속받은 메서드를 고쳐서 사용)

2) 반드시 상속에서만 사용할 수 있는 문법

(8) 추상 클래스와 추상 메서드

1) 추상 클래스

 - 추상메서드를 하나 이상 가지고 있는 경우

 - abstract 키워드 사용

 - 인스턴스를 생성할 수 없다. // 자식에게만 물러줄 수 있는 용도로만 쓰겠다.

  

2) 추상 메서드

 - 내용은 없고 선언만 되어있는 메서드

Void a() {


}


Void a(); // 중괄호가 없는 건 쓸데없는 진입을 막겠다는 의미


// 혼란을 방지하기 위해서

   - Abstract 키워드 사용

Abstract void a();

//추상메서드는 앞에 Abstract 라는 키워드를 사용한다.

- 반드시 오버라이딩을 해야 한다.//이걸 상속 받는 자식클래스는


(9) final : class, method, variable

1) 변수 

Final inti=5;

I = 10;

Final int MAX_AGE = 100;

For(inti=0; i<MAX_AGE; i++) {

}



2) 메서드

Final void method(…) {

}

3) 클래스

Final class Classname{…}


(10) Object

'Java' 카테고리의 다른 글

[JAVA 정리] 11. Interface  (0) 2017.06.24
[JAVA 정리] 10. Package  (0) 2017.06.24
[JAVA 정리] 8. 클래스2  (0) 2017.06.24
[JAVA 정리] 7. Array 배열  (0) 2017.06.24
[JAVA 정리] 6. 매서드  (0) 2017.06.24

8. 클래스 2

(1) 배열의 단점을 보완하여 서로 다른 Type의 데이터를 묶음

(2) Access Modifier (접근제어 명시자) ->클래스, 메서드,변수 다 쓸수있음

1) default :생략된 형태,제한된 접근

2) public : 완전 개방

3) private :완전 폐쇄

4) protected : 제한된 폐쇄

(3) 매서드

1) 인자 전달 방식

 - 값에 의한 전달 (call by value) 

직접적으로 값만 전달 소량의 데이터 전달

 - 참조에 의한 전달(call by reference)

인스턴스의 주소전달 대량의 데이터 전달.

2) 재귀 호출(recursive call)

(4) Static

1) 인스턴스와는 상관 없이 별도의 메모리로 생성

2) 여러 인스턴스들이 공유할 수 있는 메모리

3) 클래스 변수

4) Static block

Static {

Static 변수들만 모아서 일괄적인 처리 가능

}

(5) 중첩 클래스 ( 내부 클래스)

1) static 클래스

2) 일반 클래스


* Design Pattern

- Singleton Pattern

Private, 생성자, static (새로운 Singleton Pattern을 만들 수 있다.)

Design Pattern 구현방법

  1. 절대로 외부에서 인스턴스를 만들지 못하게 한다.

  2. 클래스 내부에서 단 하나의 인스턴스를 만들게 한다.

  3. 만들어진 인스턴스를 외부에서 사용할 수 있게 한다.


prjClass2.zip


'Java' 카테고리의 다른 글

[JAVA 정리] 10. Package  (0) 2017.06.24
[JAVA 정리] 9. 클래스3  (0) 2017.06.24
[JAVA 정리] 7. Array 배열  (0) 2017.06.24
[JAVA 정리] 6. 매서드  (0) 2017.06.24
[JAVA 정리] 5. 클래스1  (0) 2017.06.24

7. Array

(1) 정의

   1) 많은 양의 데이터를 다루기 위한 방법(변수를 줄이기 위해)

   2) 같은 이름으로 정의된 연속적인 메모리 공간

int kor1, eng1, mat1;

int kor2, eng2, mat2;

int kor3, eng3, mat3;


int[] a1, a2, a3;

//배열은 반복문을 사용할 수 있음

(2) 문법

   1) 자바에서는 배열을 객체(=클래스)로 취급한다.

int[] a1 = new int[3];

int[] a2 = new int[3];

int[] a3 = new int[3];

//a1 참조변수 -> 인스턴스 해서


(3) 활용

   1) 검색

- Sequential Searching -순차검색

- Binary searching - 이분 검색

데이터의 중간위치를 구한다

해당 데이터가 찾고자 하는 데이터인지 확인.


For(int row=0; row<data.length-1; row++){

For(int col = row+1; col<data.length; col++){

If(data[row] < data[col]) // {

Int temp = data[row];

Data[row] = data[col];

Data[col]

}

}

}


2) 정렬 (오름차순,내림차순)

   (1) Swap algorithm(교체 알고리즘)

Int a = 10, b=5, c; //동시처리가 안되므로 변수 하나 더 생성

C=a;

A=b;

B=c;

   (2) 선택정렬 :기준을 하나 선택해서 정렬해 나가는 것

데이터 중 기준 선정하기(최대값/최소값, 맨끝)

->데이터값이아닌 위치를 기준

   (3) 버블정렬 :서로 이웃하는 것끼리 정렬

   (4) 삽입정렬



(4) 다차원 배월( 2차원 이상의 배열)

   1) 1차원 배열 :각각의 변수를 한 줄로 된 연속적인 공간

   2) 2차원 배열 : 1차원 배열을 하나로 합친 것

   3) 3차원 배열 : 2차원 배열을 하나로 합친 것

   4) 1차원 배열과 다차원 배열의 차이 

- 1차원 배열 :값에 직접 접근방식 (메모리에 접근)

- 다차원 배열 :주소(참조)에 의한 간접 접근


Int[] a1 = new int[3];

Int[] a2 = new int[3];

Int[] a3 = new int[3];

Int[][] = mew int[3][3];


(5) 불규칙 배열 (다차원 배열) ->동적 바인딩


Char[] name1 = {‘T’, ‘o’,‘m’};

Char[] name2 = {‘J’, ‘a’,‘n’, ‘e’};

Char[] name3 = {‘J’, ‘o’,‘h’, ‘n’, ‘s’, ‘o’, ‘n’};

Char[] name4 = {‘홍’, ‘길’,‘동’};


Char[][] names = new char[4][7];


Names[0] = new char[3];

Names[1] = new char[4];

Names[2] = new char[7];

Names[3] = new char[3];


(6) String

1) java.lang

2) 자바는 문자열을 객체로 취급한다.

3) 동일한 문자열(인스턴스)을 중복해서 생성하지 않는다.

  ->메모리 낭비를 하지 않는다.

단 new를 통해서 생성할 경우 강제로 인스턴스 생성

4)절대 수정 불가(읽기 전용)

5) StringBuffer 수정 가능


(7) CommandLine Argument(명령행 인자)

프로그램 실행할 때 넘어가는 인자.


*Scanner

 - java.util

알맹이 기능이 없고 다른 클래스의 도움을 주는 역할을 한다.


1차원배열은 노가다필요. 2차원배열은 가독성이 떨어짐.


데이터 보관 원초적인 방법

1) 변수화

장점 :쓰기편함

단점 :많은 양의 데이터 저장 x

2) 배열

장점 :많은 양의 데이터를 저장 가능

단점 :크기 정해야함( 많이 ->낭비/적음 ->부족)

같은 형식 ( 정수는 정수끼리 , 실수는 실수끼리)

삽입, 삭제 거이 불가능(데이터가 많으면 많을수록 불가능)

6. 메서드

   1) 동작(기능)을 구현하는 역할 (함수)

   2) 만드는법

반환형 메서드(…) {

기능정의

  }

   3) 사용하는 법

메서드명(…)

   4) 메서드의 호출방식

- 인자가 없는 방식

- 인자가 있는 방식

- 리턴값 (반환값)이 있는 방식


매개변수와 실인자는1대1형식,개수가 매칭되어야 한다.

   5) return

- 복귀할때 값을 반환(단 1개만 가능)

- 메서드 강제 종료 ( return밑에있는 코드는 실행 불가능)

   6) 메서드의 오버로딩(Overloading)

- 중복정의 ( 같은 이름의 메서드를 여러 개 만들 수 있다.)

- 다형성

- 매개변수의 개수,형식,순서

   7) 생성자(Constructor)

- 인스턴스(instance)를 생성해 주는 기능

- 용도 : 초기화

- 호출시점 :인스턴스를 생성할 때 만 호출 (일회용)

- 작성방법

메서드명(…) {

기능 정의

}

= >반환형이 없다. (void) 

- 메서드명은 클래스 명과 동일하게 지어야함

- 모든 클래스는 항상 기본 생성자를(인자 없는 생성자)소유

- 단,임의의 생성자(인자 있는 생성자)를 만들게 되면 더 이상 기본 생성자는 존재하지 않게 된다.


8) Garbage Collection 

- finalize(); 

이미 만들어 져있는 메소드

protected void finalize() {} = >현재 garbage collection이 호출된다는 것을 알수있다.

- 거꾸로호출 : callback



+ Recent posts