모바일 오유 바로가기
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
    조회수 : 1425
    IP : 125.128.***.86
    댓글 : 6개
    등록시간 : 2018/12/28 13:13:07
    http://todayhumor.com/?programmer_22758 모바일
    Java for문 테스트
    옵션
    • 창작글
    • 본인삭제금지
    <a target="_blank" href="http://todayhumor.com/?programmer_22747">http://todayhumor.com/?programmer_22747</a> <br>    <br>지난 링크에서 for 문 사용할 때 List의 size 호출 관련 효율성이 어쩌구 언급 한 적이 있음.<br>그래서 어떤 것이 가장 좋을 까? 하고 무식하게 테스트 해 봤음.<br><br>약간 흥미롭게 결과가 나왔는데 JDK 버전마다 조금씩 결과가 다름.<br>그리고 동일한 JDK 버전으로 PC와 <a target="_blank" href="https://wandbox.org">https://wandbox.org</a> 에서 컴파일 했을 때 결론도 각기 다르게 나왔음.<br><br>일단은 테스트 코드<br><br><font face="Courier New">import java.util.ArrayList;<br>import java.util.Collections;<br>import java.util.Iterator;<br>import java.util.List;<br><br><br><b>public </b><font>class </font><b>TestRepeat </b>{<br>    <br>    <b>private </b><font>final static</font> List<String> <b>getList</b>(){<br>        final List<String> result = new ArrayList<String>();<br>        <br>        for( int i=0 ; i<60000 ; i++ ){<br>            result.add( String.format("%08d", i) );<br>        }<br>        <br>        return result;<br>    }<br>    <br>    <b>private </b><font>final static</font> String <b>resultMessage</b>(List<Long> lst){<br>        long max=Collections.max(lst), min=Collections.min(lst), aver, sum=0;<br>        <br>        int cnt = 0;<br>        for( long l : lst ){<br>            sum += l;<br>            if( l == 0 )<br>                cnt ++;<br>        }<br>        <br>        aver = sum / lst.size();<br>        <br>        return String.format("<font face="Verdana">Max=%7d\t\tMin=%7d\t\tAver=%7d\t\tZero Count=%7d</font>", max, min, aver, cnt);<br>    }<br><br>    <b>public </b><font>static </font>void <b>main</b>(String[] args) {<br>        <br>        final int MaxCount = 5000;<br>        <br>        final List<Long> sizeList = new ArrayList<Long>();<br>        {<br>            <br>            final List<String> lst = getList();<br>            <br>            for( int i=0 ; i<MaxCount ; i++ ){<br>                <br>                final long start = System.nanoTime();<br>                for( int j=0 ; j<lst.size() ; j++ ){<br>                    lst.get(j);<br>                }<br>                <br>                sizeList.add( System.nanoTime() - start );<br>            }<br>        }<br>        <br>        final List<Long> constList = new ArrayList<Long>();<br>        {<br>            final List<String> lst = getList();<br>            <br>            for( int i=0 ; i<MaxCount ; i++ ){<br>                <br>                final int size = lst.size();<br>                final long start = System.nanoTime();<br>                for( int j=0 ; j<size ; j++ ){<br>                    lst.get(j);<br>                }<br>                <br>                constList.add( System.nanoTime() - start );<br>            }<br>        }<br>        <br>        final List<Long> forList = new ArrayList<Long>();<br>        {<br>            final List<String> lst = getList();<br>            <br>            for( int i=0 ; i<MaxCount ; i++ ){<br>                <br>                final long start = System.nanoTime();<br>                for( String s : lst ){<br>                    ;<br>                }<br>                <br>                forList.add( System.nanoTime() - start );<br>            }<br>        }<br><br>        final List<Long> iterList = new ArrayList<Long>();<br>        {<br>            final List<String> lst = getList();<br>            <br>            for( int i=0 ; i<MaxCount ; i++ ){<br>                <br>                final long start = System.nanoTime();<br>                for( Iterator<String> s = lst.iterator(); s.hasNext(); ){<br>                    s.next();<br>                }<br>                <br>                iterList.add( System.nanoTime() - start );<br>            }<br>        }<br>        <br>        System.out.println("<font face="Verdana">size 매번 호출\t</font>" + resultMessage(sizeList) );<br>        System.out.println("<font face="Verdana">size 한번 호출\t</font>" + resultMessage(constList) );<br>        System.out.println("<font face="Verdana">foreach        \t</font>" + resultMessage(forList) );<br>        System.out.println("<font face="Verdana">Iterator 패턴\t</font>" + resultMessage(iterList) );<br><br>    }<br><br>}</font><br><br><br>◈ JDK 1.7 PC Windows7<br><font face="Verdana">size 매번 호출    Max=3459601        Min=      0        Aver=   1441         Zero Count=   4693<br>size 한번 호출    Max=1818125        Min=      0        Aver=    976          Zero Count=   4786<br>foreach            Max=8044722        Min= 192511   Aver= 204727        Zero Count=      0<br>Iterator 패턴     Max=4768303        Min=  81171    Aver=  84916        Zero Count=      0</font><br><br><br>◈ JDK 1.8 PC Windows7<br><font face="Verdana">size 매번 호출    Max=3579648        Min=      0        Aver=  22607        Zero Count=   4390<br>size 한번 호출    Max=1686260        Min=      0        Aver=   1776         Zero Count=   4693<br>foreach            Max=3399266        Min= 121913    Aver= 142415       Zero Count=      0<br>Iterator 패턴     Max=2076569        Min=   4976      Aver=   9294        Zero Count=      0</font><br><br><br>◈ JDK 1.7 wandbox.org<br><font face="Verdana">size 매번 호출    Max=9959131        Min=   1145        Aver=   5156        Zero Count=      0<br>size 한번 호출    Max= 714845         Min= 271180      Aver= 296579        Zero Count=      0<br>foreach            Max=18782974       Min= 276058      Aver= 344822        Zero Count=      0<br>Iterator 패턴     Max=10282601      Min= 466734       Aver= 535358        Zero Count=      0</font><br><br><br>◈ JDK 1.8 wandbox.org<br><font face="Verdana">size 매번 호출    Max=8511093        Min=   1340        Aver=  48145        Zero Count=      0<br>size 한번 호출    Max=3233879        Min=      0           Aver=  34890        Zero Count=    360<br>foreach            Max=15693267      Min= 277988        Aver= 339264      Zero Count=      0<br>Iterator 패턴     Max=3507748        Min= 497543        Aver= 640804      Zero Count=      0</font><br><br><br>◈ JDK 1.9+181 wandbox.org<br><font face="Verdana">size 매번 호출    Max=7186845        Min=  73194        Aver= 201134        Zero Count=      0<br>size 한번 호출    Max=6043744        Min=  73189        Aver= 164352        Zero Count=      0<br>foreach            Max=7884471        Min= 333090        Aver= 412907        Zero Count=      0<br>Iterator 패턴     Max=1248011        Min= 519698        Aver= 566357        Zero Count=      0</font><br><br><br>◈ JDK 1.10+23 wandbox.org<br><font face="Verdana">size 매번 호출    Max=6827381        Min=  52742        Aver= 205384        Zero Count=      0<br>size 한번 호출    Max=3576097        Min=  73169        Aver= 130013        Zero Count=      0<br>foreach            Max=7937696        Min= 349524        Aver= 419772        Zero Count=      0<br>Iterator 패턴     Max=1812288        Min= 632961        Aver= 739575        Zero Count=      0</font><br><br><br>컴파일 버전마다 조금씩은 차이가 있지만 size 함수를 한번만 호출 하는 것이 대체적으로 좋은 결과를 보여줌.<br>foreach 방식은 속도가 안습임. 왜그러지? ㅡ,ㅡ;;; 내가 좋아하는 for문이였는데 쩝...<br><div>허나 극악의 속도를 원하는 것 아니면 크게 문제 없으니 걍 참고만 하고 잘 쓰면 될꺼라 생각함.</div> <div><br></div> <div>아... 일해야지. ㅋ<br></div> <div style="border:3px dashed #0000FF;display:none;"></div> <div style="display:none;width:100%;height:1724px;background:none repeat scroll 0% 0%;"></div>

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 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]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈