반응형
반응형



다운로드 버튼 클릭




맥 OS 다운로드




import할 뭐가 없으므로




check box 선택 후 Continue 계속 클릭



응 통계 안해, Don't send



개발은 역시 black 간지지




그냥 왼쪽 선택함


+추가.. 와 개발하면서 초답답 이전에 사용해보셨던 분들은 오른쪽 선택하세요




그냥 Default plugins 선택




많구나~ 하고서 Next




IDE Features Trainer 빼고 모두 Install함




Jetbrains 계정에 라이센스가 있으면 Activate에 본인 계정/비번




없으면 나처럼 그냥 Free ㅠㅠ




설치하는 군



Create New Project 선택




이제 New Project 셋팅하면 끝




혹시 몰라서 jdk 설치 방법 및 환경변수 설정 궁금할 경우, 지난 포스팅


반응형

추상(abstract) 클래스와 인터페이스(interface) 클래스


1. 추상  클래스와  추상 메소드란?

추상클래스란 말 그대로 추상적으로 밖에 그려지지 않은 클래스라고 한다. 즉, 클래스가 전체적인 구성을 다 가지지 못한 채 설계만 되어있는 클래스이다. 미완성 설계도로 완성된 제품을 만들 수 없듯이 추상클래스로 인스턴스를 생성할 수는 없다. 추상클래스는 상속(Extends)을 통해서 자식 클래스에 의해 완성이 된다. 그래서 추상클래스 자체로는 제 기능을 다하지는 못하지만, 새로운 기능을 정의하는데 있어서 바탕(틀)이 될 수 있다!


package ch7;


// 추상 클래스는 class 선언부 앞에 abstract를 적어준다.

abstract class 클래스명 {

.....

abstract 메소드명();  // 추상 메소드

}

  • 추상 메소드가 하나 이상 포함되면 반드시 추상클래스로 선언이 되어야 한다.
  • 추상클래스에서 추상 메소드가 아닌 일반 메소드를 포함시킬 수 있다.
  • 추상클래스를 상속하는 자식 클래스에서 부모가 가진 메소드를 모두 오버라이딩 해야 한다.
  • 추상 메소드는 몸체가 없고 선언부만 존재한다.
예제 1

package ch7;


// 추상클래스 선언

// 구현부가 없이 선언부만 존재하는 것을 확인할 수 있다.

abstract class Player{

boolean pause;

int currentPos;

// 생성자로 변수 초기

Player(){

pause = false;

currentPos = 0;

}

abstract void play(int pos);

abstract void stop();

}


class AudioPlayer extends Player{

// play 메소드의 구현부

void play (int pos){

System.out.println("AudioPlayer.play");

}

// void 메소드의 구현부 

void stop (){

System.out.println("AudioPlayer.stop");

}

}


class CDPlayer extends Player{

// play 메소드의 구현부

void play (int pos){

System.out.println("CDPlayer.play");

}

// void 메소드의 구현부 

void stop (){

System.out.println("CDPlayer.stop");

}

}


class abEx02{

public static void main (String args[]){

AudioPlayer ap = new AudioPlayer();

ap.play(1);

CDPlayer cp = new CDPlayer();

cp.play(1);

}

}


2. 인터페이스(Interface) 클래스란?

인터페이스는 추상클래스처럼 추상 메소드를 갖지만 추상 클래스보다 추상화 정도가 높아서 추상 클래스와 달리 몸통을 갖춘 일반 메소드 또는 멤버 변수를 구성원으로 가질 수 없다. 오직 추상 메소드와 상수만을 멤버로 가질 수 있으므로 그 외의 다른 어떠한 요소도 허용하지 않는다. 추상클래스를 부분적으로 미완성된 설계도라고 했다면, 인터페이스 클래스는 아무 것도 없고 밑그림만 그려져 있는 상태이다.


package ch7;


interface 클래스{

public static final 변수타입 변수명 = ;

public abstract 메소드(매개변수);

}

  • 모든 멤버변수는 public static final 이어야하며, 이를 생략할 수 있다.
  • 모든 메소드는 public abstract 이어야 하며, 이를 생략할 수 있다.
  • 인터페이스는 인터페이스로부터만 상속(Extends)받을 수 있으며, 클래스와 달리 다중 상속이 가능하다.
    ex) interface Fightable extends Movable, Attackable{ } 
    여기서 MovableAttackable은 모두 interface 클래스다.
인터페이스의 구현
 class A2 {

    void autoPlay(I i) {

          i.play();

     }

 }


 interface I {

      public abstract void play();

 }


 class B2 implements I {

     public void play() {

          System.out.println("play in B class");

     }

 }


 class C2 implements I {

     public void play() {

          System.out.println("play in C class");

     }

 }


class InterfaceTest2 {

public static void main(String[] args) {

A2 a = new A2();

a.autoPlay(new B2()); 

a.autoPlay(new C2());

}

}

결과 

play in B class

play in C class


인터페이스 클래스의 장점

  1. 개발 시간을 단축시킬 수 있다.
    메소드를 호출하는 쪽에서는 메소드의 내용에 관계없이 선언부만 알면 되기 때문이다. 
  2. 표준화가 가능하다.
    프로젝트에 사용되는 기본 틀을 인터페이스로 작성한 다음, 개발자들에게 인터페이스를 구현하여 프로그램을 작성하도록 함으로써 보다 일관되고 정형화된 프로그램의 개발이 가능하다.
  3. 서로 관계없는 클래스들에게 관계를 맺어 줄 수 있다.
    서로 상속관계에 있지도 않고, 같은 조상 클래스를 가지고 있지 않은 서로 아무런 관계도 없는 클래스들에게 하나의 인터페이스를 공통적으로 구현하도록 함으로써 관계를 맺어줄 수 있다.

  4. 독립적인 프로그래밍이 가능하다.
    인터페이스를 이용하면 클래스의 선언과 구현을 분리시킬 수 있기 때문에 실제 구현에 독립적인 프로그램을 작성하는 것이 가능하다.
    클래스와 클래스 간의 직접적인 관계를 인터페이스를 통해서 간접적인 관계로 변경하면 한 클래스의 변경이 관련된 다른 클래스에 영향을 미치지 않는 독립적인 프로그래밍이 가능하다.



참고링크

  • 자바의 정석


반응형

쓰레드(Thread)와 런에이블(Runnable) 1편

본 게시물은 jdk 1.8 기준으로 작성되었습니다.

1. 쓰레드(Thread)란?

프로그램을 실행하면 OS로부터 실행에 필요한 자원(메모리)를 할당 받아서 프로그램이 실행된다. 프로그램이 실행된 결과물이 바로 프로세스이다예를 들어 윈도우의 Ctrl + Shift + ESC를 하면 탭 부분에 프로세스가 보이는데 클릭해보면 실행 중인 프로세스 리스트가 보인다. 즉, 실행 중인 프로그램 = 프로세스!

  • 프로세스 = 데이터(data) + 자원(memory) + 쓰레드(Thread) 로 구성되어서 실제로 프로그램이 실행되기까지는 쓰레드(Thread)가 바로 데이터(data)+자원(memory)를 활용하여서 작업을 수행한다.
  • 쓰레드(Thread) 작업을 수행하려면 메모리 공간이 필요하므로 메모리의 한계에 따라서 최대로 생성할 수 있는 쓰레드 수가 결정된다.
  • 모든 프로세스에는 최소한 하나 이상의 쓰레드(Thread)가 존재하며, 두 개 이상의 쓰레드(Thread)를 가지면 멀티-쓰레드(multi-threaded) 라고 한다.

2. 쓰레드(Thread) 구현하기

자바에서 쓰레드를 구현하는 방식은 Thread를 이용하는 방법과 Runnable을 이용하는 방법 2가지가 있다. Thread 클래스는 상속(Extends)를 받아서 사용해야 하므로 다른 클래스들을 상속받을 수 없다. (자바는 기본적으로 다중상속 금지) 그러나 Runnable 인터페이스는 구현(implements) 받아서 사용하므로 필요하다면 다른 클래스를 상속받아서 재사용성과 코드의 일관성을 높일 수 있다. 또한 Thread 를 한번 사용하면 재사용이 불가능하지만, Runnable 를 이용하여 Thread를 구현하면 재사용할 수 있다.


잘 와닿지 않을테니 아래의 예제를 통해서 내용을 확인하자. 혹시 이 게시물을 읽기전 상속(Extends)와 구현(implement), 인터페이스 클래스 등을 잘 모르겠다면 'http://aileen93.tistory.com/107' 이전 게시물 참고!



[방법 1]  Thread로 쓰레드 구현하기


예제 1

package ch13_Thread;


class ThreadEx01 {

public static void main(String args[]) {

ThreadEx2 t1 = new ThreadEx2();

t1.start();

}

}


class ThreadEx2 extends Thread {


// 쓰레드를 통해서 수행할 내용들을 정의

public void run() {

// 작업내용

for(int i=0; 5 > i; i ++)

System.out.println("쓰레드가 실행되었습니다.");

}

}

쓰레드가 실행되었습니다.

쓰레드가 실행되었습니다.

쓰레드가 실행되었습니다.

쓰레드가 실행되었습니다.

쓰레드가 실행되었습니다.


여기서 의문이 생길 것이다. run으로 구현되어있는데, 왜 start로 Thread를 실행 시키는지!

Thread 클래스의 메소드 API 문서를 확인해보자.

voidstart()
이 스레드가 실행을 시작하도록합니다. Java 가상 머신 run이 thread  메소드를 호출합니다 .
voidrun()
이 스레드가 별도의 Runnable실행 객체 를 사용하여 작성된 경우 해당 Runnable객체의 run메소드가 호출됩니다. 
그렇지 않은 경우, 이 메서드는 아무 것도 수행하지 않고 반환합니다.
  1. start 메소드는 thread의 메소드를 호출하고, run메소드는 Runnable 실행 객체를 사용하여서 작성된 경우에만 Runnable의 run메소드가 호출된다고 적혀있다. 그러므로 Thread를 실행시킬 때에는 start메소드를 통해서 실행시켜야하며, run을 통해서도 실행은 되지만 정확히는 Thread를 이용하여 실행시킨 것은 아니다.
  2. 1번의 내용을 더 자세하게 설명 하자면 JVM의 Call stack 메모리를 생각해보자. 쓰레드를 사용하기 위해서는 쓰레드 만의 독립적인 작업 공간(Memory)가 할당된 후 Call stack이 만들어진다. 그 후에 Call stack 안에 각 실행하고자 run()과 같은 메소드들이 올라가게 되고 Call stack에 있는 내용들이 모두 실행이 되고 나면 쓰레드는 작업 공간을 반환되며 메모리가 소멸된다. 그러므로 쓰레드를 정확히 사용하기위해서는 Start() 메소드를 사용하여야 한다.


[방법 2] Runnable로 쓰레드 구현하기


class RunnableImplements implements Runnable {


// Runnable인터페이스의 추상메서드 run()을 구현

public void run() {

// 작업내용

} 

}

  • Thread와 다른 점은 Runnable 클래스를 implements하였다는 점이다.
  • 그러므로 Thread보다 더 확장성 있는 코드를 만들 수 있다. (오버로딩하여서 작성하여야하므로)

예제 2

package ch13_Thread;


// view-source:https://docs.oracle.com/javase/8/docs/api/java/lang/Runnable.html

class RunnableEx01 {

public static void main(String args[]) {


Runnable r  = new ThreadEx1();

Thread   t1 = new Thread(r);

t1.start();

}

}


class ThreadEx1 implements Runnable {

// 스레드를 종료시키기 위한 플래그 변수

private boolean stopped = false;

// 스레드를 통해서 실행시킬 task 로직

public void run() {

while (!stopped) {

               System.out.println("Thread is alive :"+ stopped);

               try {

                   System.out.println("active.."+Thread.activeCount());

                   Thread.sleep(2000);

               } catch (Exception e) {

                   stop();

               }

               stop();

           }

}

// 스레드 종료시키기

public void stop(){

System.out.println(Thread.currentThread().getName()+"가 종료되었습니다.");

stopped = true;

}

}


3. 결론

Thread보다 Runnable이 더 확장성(유연성)있는 코드 작성이 가능하다. 

Runnable의 단점은 그럼 무엇일까?..


*쓰레드(Thread)와 런에이블(Runnable) 2편 


반응형

아파치 POI란? (https://ko.wikipedia.org/wiki/%EC%95%84%ED%8C%8C%EC%B9%98_POI)

아파치 POI(Apache POI)는 아파치 소프트웨어 재단에서 만든 라이브러리로서 마이크로소프트 오피스 파일 포맷을 순수 자바 언어로서 읽고 쓰는 기능을 제공한다. 주로 워드엑셀파워포인트와 파일을 지원하며 최근의 오피스 포맷인 Office Open XML File Formats [1] (OOXML, 즉 xml 기반의 *.docx, *.xlsx, *.pptx 등) 이나 아웃룩비지오퍼블리셔 등으로 지원 파일 포맷을 늘려가고 있다.


아파치 POI 다운로드 경로 : https://www.apache.org/dyn/closer.lua/poi/release/bin/poi-bin-3.15-20160924.tar.gz

Binary Distribution > poi-bin-3.15 버전 다운로드 

21 September 2016 - POI 3.15 available#

The Apache POI team is pleased to announce the release of 3.15. Featured are a handful of new areas of functionality and numerous bug fixes.

A summary of changes is available in the Release Notes. A full list of changes is available in the change log. People interested should also follow the dev list to track progress.

The POI source release as well as the pre-built binary deployment packages are listed below. Pre-built versions of all POI components are available in the central Maven repository under Group ID "org.apache.poi" and Version "3.15".



라이브러리 내용 : https://poi.apache.org/overview.html#components)

 파일명

 내용

 비고

 poi-3.15.jar

 

 

 poi-examples-3.15.jar

 

 

 poi-excelant-3.15.jar

 

 

 poi-ooxml-3.15.jar

 MS Office Open XML (https://en.wikipedia.org/wiki/Office_Open_XML)

 MS사의 XML 기반의 파일형식을 읽는데 필요한 lib

ooxml-lib\curvesapi-1.04.jar

ooxml-lib\xmlbeans-2.6.0.jar

commons-collections4-x.x.jar 

(https://commons.apache.org/proper/commons-collections/download_collections.cgi)

poi-ooxml-schemas-3.15.jar


위에 있는 lib 파일을 모두 import 해야 함..

디펜던시 ㅡㅡ 

 poi-ooxml-schemas-3.15.jar

 

 

 poi-scratchpad-3.15.jar

 

 


2003 Excel 버전은 XSSF(확장자가 xls)로 읽고

2007 Excel 버전 이후는 HSSF(확장자가 xlsx)를 통해서 파일을 읽고 쓸 수 있다. 


참고 예제 : 

https://www.mkyong.com/java/apache-poi-reading-and-writing-excel-file-in-java/

http://www.programcreek.com/java-api-examples/index.php?api=org.apache.poi.ss.usermodel.WorkbookFactory

파일 읽기

<기존 - 각각 읽어들이는 방법>

HSSFWorkbook wb = new HSSFWorkbook(new File("파일명.xls"));

XSSFWorkbook wb = new XSSFWorkbook(new File("파일명.xlsx"));


<WorkbookFactory를 통해선 구분없이 읽어들이는 방법> : https://poi.apache.org/apidocs/org/apache/poi/ss/usermodel/WorkbookFactory.html

Workbook wb = WorkbookFactory.create( File객체 );

Workbook wb = WorkbookFactory.create( File객체);


첫번째 Sheet 불러오기

Sheet sf = wb.getSheetAt(0); 


첫번째 Sheet의 rows수 가져오기

sf.getLastRowNum();


* 최종

 try {


            FileInputStream excelFile = new FileInputStream(new File(FILE_NAME));

            Workbook workbook = new XSSFWorkbook(excelFile);

            Sheet datatypeSheet = workbook.getSheetAt(0);

            Iterator<Row> iterator = datatypeSheet.iterator();


            while (iterator.hasNext()) {


                Row currentRow = iterator.next();

                Iterator<Cell> cellIterator = currentRow.iterator();


                while (cellIterator.hasNext()) {


                    Cell currentCell = cellIterator.next();

                    //getCellTypeEnum shown as deprecated for version 3.15

                    //getCellTypeEnum ill be renamed to getCellType starting from version 4.0

                    if (currentCell.getCellTypeEnum() == CellType.STRING) {

                        System.out.print(currentCell.getStringCellValue() + "--");

                    } else if (currentCell.getCellTypeEnum() == CellType.NUMERIC) {

                        System.out.print(currentCell.getNumericCellValue() + "--");

                    }


                }

                System.out.println();


            }

        } catch (FileNotFoundException e) {

            e.printStackTrace();

        } catch (IOException e) {

            e.printStackTrace();

        }


외 참고사항

MultipartFile to File로 변경하는 방법 : http://stackoverflow.com/questions/24339990/how-to-convert-a-multipart-file-to-file

File convFile = new File(multipart.getOriginalFilename());

multipart.transferTo(convFile); 

return convFile;



+ Recent posts