기본 콘텐츠로 건너뛰기

java version 특징 (jdk, java, version)


1996
JDK 1.0 / Java 1
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
1997
JDK 1.1 / Java 1
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
1998
JDK 1.2 / Java 2
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2000
JDK 1.3 / J2SE 1.3
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2002
JDK 1.4 / J2SE 1.4 / JRE 1.4
java version 1.4.0
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2004
JDK 5 / Java SE 5 / JRE 5
java version 1.5.0
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
2006
JDK 6 / Java SE 6 / JRE 6
java version 1.6.0
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

2011
JDK 7 / Java SE 7 / JRE 7
java version 1.7.0

- 다이아몬드 연산자 적용
- Generics 사용성 개선
    JDK 7 이전
    case 1 : List<Integer> list = new LinkedList();         
            Integer외에 다른 타입을 대입해도 컴파일 오류가 나지 않지만, 런타임 오류 발생
    case 2 : List<Integer> list = new LinkedList<Integer>();
            권장 문법
    JDK 7부터는 위 case 1 에 해당하는 문법 사용불가, 다이아몬드 연산자를 반영하여 아래와같이 사용
        List<Integer> list = new LinkedList<>();

- Switch문 문자열 지원
- 리소스 자동 해제
    JDK 7 이전 (리소스를 직접 해제)
        try{
            FileInputStream f = new FileInputStream("test.xml");
            BufferedReader br = new BufferedReader(new InputStreamReader(f));
            // resource open
            // to do
        }catch (Exception ex){
            // to do
        }finally{
            // resource close
            if(f != null)
                f.close();
        }
    JDK 7부터는 try with resource 구문의 추가로인해 resource들을 자동으로 close 해준다
    단, AutoClosable, Closeable 인터페이스 구현시 try(resource)내의 리소스 close()를 수행
    보통 streams, files, socket, db connection등은 해당 인터페이스를 구현해서 쓰거나..
    클래스에 AutoCloseable 을 implements AutoCloseable 하여 사용한다
        try (   
                // 꼭 아래와같이 개별적으로 변수선언과 함께 사용되어야 각각 close된다
                FileInputStream f = new FileInputStream("test.xml");
                BufferedReader br = new BufferedReader(new InputStreamReader(f));

                // 이렇게 사용할경우 FileInputStream에 대한 리소스는 해제되지 않는다
                // BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream("test.xml"))); (X)
            ) {
            // to do
        }catch (Exception ex){
            // to do
        }


- Garbage Collector 기능 개선
- int 변수에 2진수 입력 지원
    int b = 0B10; // print 2
    int b = 0B11111111; // print 255

- 숫자 밑줄 지원
    int i = 123_456_789; // 123456789로 인식하며 가독성을 위해 사용하는 수준

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

2014
JDK 8 / Java SE 8 / JRE 8
java version 1.8.0
- Lambda 표현식 추가 (관련내용 참고 : https://jdm.kr/blog/181)
    : 식별자 없이 실행 가능한 함수 표현식
    : ( parameters ) -> { expression body }

    [기존코드]
        new Thread(new Runnable(){
            @Override
            public void run() {
            // To do ...
            }
        }).start();

    [Lambda 코드]
        new Thread(()->{
            // To do ...
        }).start();

    ex)
    // 인터페이스 작성
    @FunctionalInterface
    interface Func {
        public int calc(int a, int b)
    }

    // 람다표현식 실행함수 작성
    Func add = (int a, int b) -> a + b;

    위 처럼 사용할 경우 인퍼테이스상에 함수는 calc 하나여야만한다, 하나 이상 존재하면 오류가 날것이다
    따라서 이 인터페이스는 람다식을 위한것이다라는 표현을 위해 @FunctionalInterface 어노테이션을 사용하고
    이 어노테이션을 적용함으로서 interface상에 한개의 함수만 선언할 수 있게 된다 (하나 이상 선언시 컴파일 오류 발생)

- Streams 인터페이스 추가
    : 리스트, 배열을 대상으로 연결된 작업을 처리한다는것으로 이해됨
    1) stream 얻기
        Arrays.asList(1,2,3).stream(); // (output : 1)
        Arrays.asList(1,2,3).parallelStream(); // (output : 2) 병렬처리시 사용하며 기본적으로 CPU코어수만큼 Thread를 생성하여 동시에 작업한다

        Arrays.asList(1,2,3).stream()
                            .map(i -> i*i)
                            .forEach(System.out::println); // 1,4,9

        Arrays.asList(1,2,3).stream()
                            .limit(1)
                            .forEach(System.out::println); // 1
        
        Arrays.asList(1,2,3).stream()
                            .skip(1)
                            .forEach(System.out::println); // 2,3
        
        Arrays.asList(1,2,3).stream()
                            .filter(i -> 2>=i)
                            .forEach(System.out::println); // 1,2
        
        Arrays.asList(Arrays.asList(1,2), Arrays.asList(3,4,5), Arrays.asList(6,7,8,9)).stream()
                            .flatMap(i -> i.stream())
                            .forEach(System.out::println); // 1,2,3,4,5,6,7,8,9
        
        Arrays.asList(1,2,3).stream()
                            .reduce((a,b) -> a-b)
                            .forEach(System.out::println); // -4 ==>> ( 1 - 2 ) - 3 = -4

        // get(make) collection
        Arrays.asList(1,2,3).stream()
                            .collect(Collectors.toList());
        // get(make) collection
        Arrays.asList(1,2,3).stream()
                            .iterator();

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

2017.9월
JDK 9 / Java SE 9 / JRE 9
java version 9
- Java Platform Module System (Jigsaw) 추가
- Java 9 JShell 추가
- HTML5 Javadoc 추가
- 익명 클래스에 대한 Diamond Operator 허용
- 프로세스 API 추가

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

2018.3월 (6개월)
JDK 10 / Java SE 10 / JRE 10
java version 10
- 로벌 변수 타입 추론 (Local-Variable Type Inference) = var 변수 선언 기능
    1) 초기화 된 로컬변수 선언시 (초깃값이 없을 경우 Object로 인식)
        ex) var list = new ArrayList<String>(); // infers ArrayList<String>
        ex) var stream = list.stream();         // infers Stream<String>
    
    2) 반복문(for문, for each문)의 지역변수 선언시 사용가능
        ex) java for-each구문 에서 var 사용
            var numbers = List.of(1,2,3,4,5);
            for( var item : numbers ){
                // To do ...
            }
            or
            for( var item = 0; item < numbers.size(); i++ ){
                // To do ...
            }
    
- Garbage Collector Interface 개선
- Parallel Full GC for G1 : -XX:ParallelGCThreads 옵션을 이용해 쓰레드 수 조절
- Application Class-Data Sharing : 자바프로세스간 클래스 공유, startup 시간 단축, 메모리 최적화

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

2021.9월 JAVA 11 예정

= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =

댓글

이 블로그의 인기 게시물

변액보험판매자격시험공부 요점정리

생명보험협회 주관 변액보험판매자격시험 (PBT)  요점 정리 입니다  아래 내용만 3일정도 외워서  모의고사 4번정도 풀고  시험봤구요  82.5점으로 합격했습니다 모두들 합격하세요 ~!  --------------------------------------------------------------------- 직접금융 / 간접금융 은행 : 간접금융 자금의 공급자와 수요자 사이에서 빌려주고,돌려받는것을 수행해준다 공급자와 수요자가 직접 거래하고 책임지지 않는다 증권사 : 직접금융 기업(공급자)은 주식/채권 발행 -> 증권사는 그것들을 인수역할을함 개인(수요자)는 기업이 발행한 주식/채권을 직접 매매한다 자금의 공급자와 수요자가 직접 책임진다 증권사는 중간연결다리 역할만 한다 금융시장의 기능 자금의 중계 금융자산의 가격결정 유동성 제공 거래비용 절감 ★ 탐색비용, 정보비용등이 금융시장이 있음으로 인해 비용이 절감된다 ★ 위험관리 위험 = 변동성, 위험이크다(변동성이크다), 위험에 대한 보상 = 위험프리미엄 위험회피도가 높은 투자자는 변동성이 높은 투자를 했을때 위험회피도가 낮은 투자자에 비해 위험프리미엄이 높다 시장규율 만기는 1년을 기준으로함 1년 미만 :  자금시장  (단기) 장기시장에비해  거래규모 크다 (유동성 풍부) 1년 이상 :  자본시장  (장기)  오래투자하므로 단기보다  변동폭이 크다 단기시장은 유동성이 풍부하고 변동폭이 크다 (X) : 변동폭이 큰건 장기시장이다 장기상품  주식 채권 자산유동화증권 단기상품 장기상품을 제외하고 전부다 단기상품 콜 금융 기관 끼리 돈을 빌리는것 만기 1일이 대다수 최장만기는 90일 RP (환매채권) 개인 의 채권 투자 방식  증권사가 사들인 기업채권을 개인이 투자하고, 증권사가 개인이 투자한 채권을 다시 사들이는 형태 예금자보호 불가  (영어로된 용어는 예금자보호불가)...

Android 스마트폰 기본 웹브라우저(Chrome:크롬) 호출하는 스키마(URL Scheme)

신용카드결제 페이지 주소를 카톡으로 던졌을때 카톡 내부에서 결제가 이루어지다보니 결제완료까지 정상적으로 처리되지 않는 경우가 발생한다더라 그래서 생각해본게.. 1) 카카오통 채팅방  2) 링크 전송  3) 링크를 클릭하면 스마트폰애 내장된 웹브라우저를 실행하는 URL스키마 실행  4) 실행된 웹브라우저에서 결제페이지로 이동 이 절차를 거치면 카톡 외부로 나와서 독립적인 웹브라우저상에서 결제를 진행하기때문에 정상처리가 가능할것이라고 판단 찾다 찾다가.. 알아낸것이 안드로이드 (가능) - 롤리팝부터 크롬 브라우저가 기본앱이다 - 크롬을 호출방법 intent://www.naver.com#Intent;scheme=http;package=com.android.chrome;end  아이폰 (조건부 가능) - 사파리를 호출하는 앱스키마가 없으며, 사파리를 통해서 검색어를 입력한 검색기능만 가능 - 크롬브라우저 앱이 설치되어있을경우 아래와같이 호출 가능 googlechrome:////www.naver.com <사용법> < html > < body > < script >      var currentOS = "else" ;      var mobile = ( /iphone | ipad | ipod | android/ i .test(navigator.userAgent.toLowerCase()));      if (mobile) {          var userAgent = navigator.userAgent.toLowerCase();    ...

웹 개발하면서 보안을 유지하기 위한 기본지식

몇개월전에 만들었던 웹기반 (HTML5, CSS3, Flash Player(VideoJS)) VOD플레이어에서 보안이슈가 발생했다. 웹또한 서버를통해 통신을하지만 사용자의 PC에서 실행되는만큼 클라이언트의 개념이 있으며 Javascript 야말로 클라이언트에서 작업하게 되는 영역이라는 점에서 보안상에 이슈 발생.  이유인즉슨  무료로 제공되고 있는것과 유료로 제공되고있는 서비스에 대하여  javascript 단에서 서비스 허용여부를 결정하게될경우  해킹을 통해 이부분을 우회하여 서비스이용이 가능했다는점.. 모든 인증이나, 중요데이터는 java 로 코딩해서 서버단에서 결단이 나도록 했어야했는데 이건 너무 기본적이면서도 아쉬운 실수를 저지르고 말았다..  하하..  많은 분들이 이런 부분을 간과할수도있을듯하여 작성해봅니다.  요즘 보안이슈가 많을탠데 모두들 보안 화이팅 !