기본 콘텐츠로 건너뛰기

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 예정

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

댓글

이 블로그의 인기 게시물

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

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

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();          if (userAgent.search( "android" ) > - 1 )             currentOS = "android" ;          else if

tomcat 80포트 사용설정 및 GET방식 인코딩설정

톰캣 7.0 기준 server.xml 원본에 작성되어있는 내용중에서 아래와같은 내용이있다. <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />   1. 80포트 사용설정 외부에서 웹서버에 접근했을때 주소뒤에 www.xxx.com:8080   처럼 8080포트를 쓰지않는 방법은 두가지가 있는것같다.    - 첫번째 방법 - server.xml 수정 <Connector port="80" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />    - 두번째방법은 내가 작성한 리눅스 iptable를 수정하는것. 80포트로 들어온내용을 8080으로 리다이렉트시켜서 톰캣설정 변견없이 작동하게하는것이다. http://blog.naver.com/cyk7890/40189933263   2. GET 방식 한글인코딩 설정 - URIEncoding="UTF-8" 추가 <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" useBodyEncodingForURI="true" />