모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    봄아님의
    개인페이지입니다
    가입 : 15-05-11
    방문 : 1927회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_22758
    작성자 : 봄아
    추천 : 0
    조회수 : 1426
    IP : 125.128.***.86
    댓글 : 6개
    등록시간 : 2018/12/28 13:13:07
    http://todayhumor.com/?programmer_22758 모바일
    Java for문 테스트
    옵션
    • 창작글
    • 본인삭제금지
    http://todayhumor.com/?programmer_22747
        
    지난 링크에서 for 문 사용할 때 List의 size 호출 관련 효율성이 어쩌구 언급 한 적이 있음.
    그래서 어떤 것이 가장 좋을 까? 하고 무식하게 테스트 해 봤음.

    약간 흥미롭게 결과가 나왔는데 JDK 버전마다 조금씩 결과가 다름.
    그리고 동일한 JDK 버전으로 PC와 https://wandbox.org 에서 컴파일 했을 때 결론도 각기 다르게 나왔음.

    일단은 테스트 코드

    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.Iterator;
    import java.util.List;


    public class TestRepeat {
        
        private final static List<String> getList(){
            final List<String> result = new ArrayList<String>();
            
            for( int i=0 ; i<60000 ; i++ ){
                result.add( String.format("%08d", i) );
            }
            
            return result;
        }
        
        private final static String resultMessage(List<Long> lst){
            long max=Collections.max(lst), min=Collections.min(lst), aver, sum=0;
            
            int cnt = 0;
            for( long l : lst ){
                sum += l;
                if( l == 0 )
                    cnt ++;
            }
            
            aver = sum / lst.size();
            
            return String.format("Max=%7d\t\tMin=%7d\t\tAver=%7d\t\tZero Count=%7d", max, min, aver, cnt);
        }

        public static void main(String[] args) {
            
            final int MaxCount = 5000;
            
            final List<Long> sizeList = new ArrayList<Long>();
            {
                
                final List<String> lst = getList();
                
                for( int i=0 ; i<MaxCount ; i++ ){
                    
                    final long start = System.nanoTime();
                    for( int j=0 ; j<lst.size() ; j++ ){
                        lst.get(j);
                    }
                    
                    sizeList.add( System.nanoTime() - start );
                }
            }
            
            final List<Long> constList = new ArrayList<Long>();
            {
                final List<String> lst = getList();
                
                for( int i=0 ; i<MaxCount ; i++ ){
                    
                    final int size = lst.size();
                    final long start = System.nanoTime();
                    for( int j=0 ; j<size ; j++ ){
                        lst.get(j);
                    }
                    
                    constList.add( System.nanoTime() - start );
                }
            }
            
            final List<Long> forList = new ArrayList<Long>();
            {
                final List<String> lst = getList();
                
                for( int i=0 ; i<MaxCount ; i++ ){
                    
                    final long start = System.nanoTime();
                    for( String s : lst ){
                        ;
                    }
                    
                    forList.add( System.nanoTime() - start );
                }
            }

            final List<Long> iterList = new ArrayList<Long>();
            {
                final List<String> lst = getList();
                
                for( int i=0 ; i<MaxCount ; i++ ){
                    
                    final long start = System.nanoTime();
                    for( Iterator<String> s = lst.iterator(); s.hasNext(); ){
                        s.next();
                    }
                    
                    iterList.add( System.nanoTime() - start );
                }
            }
            
            System.out.println("size 매번 호출\t" + resultMessage(sizeList) );
            System.out.println("size 한번 호출\t" + resultMessage(constList) );
            System.out.println("foreach        \t" + resultMessage(forList) );
            System.out.println("Iterator 패턴\t" + resultMessage(iterList) );

        }

    }



    ◈ JDK 1.7 PC Windows7
    size 매번 호출    Max=3459601        Min=      0        Aver=   1441         Zero Count=   4693
    size 한번 호출    Max=1818125        Min=      0        Aver=    976          Zero Count=   4786
    foreach            Max=8044722        Min= 192511   Aver= 204727        Zero Count=      0
    Iterator 패턴     Max=4768303        Min=  81171    Aver=  84916        Zero Count=      0



    ◈ JDK 1.8 PC Windows7
    size 매번 호출    Max=3579648        Min=      0        Aver=  22607        Zero Count=   4390
    size 한번 호출    Max=1686260        Min=      0        Aver=   1776         Zero Count=   4693
    foreach            Max=3399266        Min= 121913    Aver= 142415       Zero Count=      0
    Iterator 패턴     Max=2076569        Min=   4976      Aver=   9294        Zero Count=      0



    ◈ JDK 1.7 wandbox.org
    size 매번 호출    Max=9959131        Min=   1145        Aver=   5156        Zero Count=      0
    size 한번 호출    Max= 714845         Min= 271180      Aver= 296579        Zero Count=      0
    foreach            Max=18782974       Min= 276058      Aver= 344822        Zero Count=      0
    Iterator 패턴     Max=10282601      Min= 466734       Aver= 535358        Zero Count=      0



    ◈ JDK 1.8 wandbox.org
    size 매번 호출    Max=8511093        Min=   1340        Aver=  48145        Zero Count=      0
    size 한번 호출    Max=3233879        Min=      0           Aver=  34890        Zero Count=    360
    foreach            Max=15693267      Min= 277988        Aver= 339264      Zero Count=      0
    Iterator 패턴     Max=3507748        Min= 497543        Aver= 640804      Zero Count=      0



    ◈ JDK 1.9+181 wandbox.org
    size 매번 호출    Max=7186845        Min=  73194        Aver= 201134        Zero Count=      0
    size 한번 호출    Max=6043744        Min=  73189        Aver= 164352        Zero Count=      0
    foreach            Max=7884471        Min= 333090        Aver= 412907        Zero Count=      0
    Iterator 패턴     Max=1248011        Min= 519698        Aver= 566357        Zero Count=      0



    ◈ JDK 1.10+23 wandbox.org
    size 매번 호출    Max=6827381        Min=  52742        Aver= 205384        Zero Count=      0
    size 한번 호출    Max=3576097        Min=  73169        Aver= 130013        Zero Count=      0
    foreach            Max=7937696        Min= 349524        Aver= 419772        Zero Count=      0
    Iterator 패턴     Max=1812288        Min= 632961        Aver= 739575        Zero Count=      0



    컴파일 버전마다 조금씩은 차이가 있지만 size 함수를 한번만 호출 하는 것이 대체적으로 좋은 결과를 보여줌.
    foreach 방식은 속도가 안습임. 왜그러지? ㅡ,ㅡ;;; 내가 좋아하는 for문이였는데 쩝...
    허나 극악의 속도를 원하는 것 아니면 크게 문제 없으니 걍 참고만 하고 잘 쓰면 될꺼라 생각함.

    아... 일해야지. ㅋ

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    84
    개발자 구인란 적는 곳은 없나요? [2] 봄아 19/02/20 16:10 77 0
    83
    아이즈원. 향후 방향은 어찌하나.... [4] 창작글 봄아 19/02/11 11:02 361 3
    82
    연습생 질문요~ [5] 창작글 봄아 19/01/22 15:54 181 1
    81
    [중드] 랑야방 보신 분 없나요? [5] 봄아 19/01/18 11:10 47 3
    80
    걸스데이 안녕이네요 ㅠㅠ [5] 펌글 봄아 19/01/11 17:07 256 3
    Java for문 테스트 [6] 창작글본인삭제금지 봄아 18/12/28 13:13 100 0
    78
    딸의 귀여움 [3] 창작글본인삭제금지 봄아 18/12/23 02:00 192 5
    77
    나의 코딩 룰. [7] 봄아 18/12/21 12:00 132 2
    76
    [java] NIO Socket 예제 창작글본인삭제금지 봄아 18/12/18 15:07 59 0
    75
    나쁜 인증 시도 방어하기! 4편(final) [5] 창작글본인삭제금지 봄아 18/12/17 10:28 100 7
    74
    나쁜 인증 시도 방어하기! 3편 [3] 창작글본인삭제금지 봄아 18/12/14 17:56 50 9
    73
    나쁜 인증 시도 방어하기! 2편 창작글본인삭제금지 봄아 18/12/13 11:08 88 11
    72
    나쁜 인증 시도 방어하기! 1편 [2] 창작글본인삭제금지 봄아 18/12/12 16:14 93 8
    71
    오피스 누나 이야기... [1] 펌글 봄아 18/09/10 10:09 137 0
    70
    야호 봄아 18/08/26 07:04 156 0
    69
    더민주 투표 완료. [1] 봄아 18/08/20 13:23 171 3
    68
    인디 음악 밴드 찾아주세요. [1] 본인삭제금지 봄아 18/05/24 13:40 37 0
    67
    스타 리마스터 할인! 11,000원! [4] 펌글 봄아 17/12/21 15:01 64 2
    66
    지금 여의도 뭔일 있나요??? [2] 창작글 봄아 17/11/28 17:45 134 0
    65
    안찰스 최악의 생각.... ㅎㄷㄷ [7] 창작글 봄아 17/11/21 14:01 1925 7
    64
    LG G3.Cat6 로 찍은 사진들. 12 pic [1] 창작글외부펌금지 봄아 17/11/16 17:46 84 6
    63
    와잎님이 처가에서 자요. TT [1] 창작글 봄아 17/11/12 01:54 245 12
    62
    뽀로로의 놀라운 사실! [4] 창작글 봄아 17/09/29 17:22 154 10
    61
    불법 현수막 신고좀 해 주세요 [4] 창작글본인삭제금지 봄아 17/09/13 19:40 189 7
    60
    아빠의 일기(2) 창작글 봄아 17/08/20 01:26 61 4
    59
    아빠의 일기 [1] 창작글 봄아 17/07/31 01:09 75 11
    58
    Google의 화성 지도 중 놀라운 것!!! [7] 펌글 봄아 17/06/28 10:49 230 12
    57
    계피나무만으로도 모기 퇴치 효과 있을까요?? [2] 창작글본인삭제금지 봄아 17/06/12 23:27 40 1
    56
    이미지 첨부 된 녀석을 만들고 싶은데 어떻게 뭘로 만들 수 있나요? [9] 봄아 17/05/18 11:51 65 0
    55
    저는 담배피는 사람 정말 싫어요~! 극혐. [5] 봄아 17/05/16 15:27 114 1
    [1] [2] [3] [4]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈