웹마스터 팁
page_full_width" class="col-xs-12" |cond="$__Context->page_full_width">
++와 +=1 의 속도차이
2004.07.12 17:54
변수 $i를 가정하고
$i++ 과 $i+=1 은 $i를 1증가시키는 구문입니다.
과연 저 둘이 실제상황(?)에서 속도차이를 보일까 하는 의문에서
간단한 실험을 했습니다.
일단
for($i = 0; $i < 1000000; $i++); 와
for($i = 0; $i < 1000000; $i+=1); 를 따로 실행해서
마이크로초 단위로 실행시간을 계산해본 결과,
$i++ 일때
0.87869
0.859785
0.93886
0.882139
0.924311
0.872625
0.866393
0.890392
0.889265
0.866099
0.861506
0.880137
$i+=1 일때
0.928549
0.950968
0.995221
0.954347
0.941408
0.940832
0.957434
0.990631
0.936167
0.963263
0.966622
0.98165
백만번 루프에서 0.1초 이내의 차이가 나는것이 확인되었습니다.
아마도 파서에의해 번역될때,
++는 어셈블리 INC ecx 명령으로 번역되고,
+=1은 어셈블리 ADD ecx, 1 정도로 번역된다고 생각합니다.
저 둘의 처리 속도차이로 이와같은 결과가 생긴다고 생각되는군요. (;)
역시 크게 신경쓰문제는 아닐듯 합니다.
$i++ 과 $i+=1 은 $i를 1증가시키는 구문입니다.
과연 저 둘이 실제상황(?)에서 속도차이를 보일까 하는 의문에서
간단한 실험을 했습니다.
일단
for($i = 0; $i < 1000000; $i++); 와
for($i = 0; $i < 1000000; $i+=1); 를 따로 실행해서
마이크로초 단위로 실행시간을 계산해본 결과,
$i++ 일때
0.87869
0.859785
0.93886
0.882139
0.924311
0.872625
0.866393
0.890392
0.889265
0.866099
0.861506
0.880137
$i+=1 일때
0.928549
0.950968
0.995221
0.954347
0.941408
0.940832
0.957434
0.990631
0.936167
0.963263
0.966622
0.98165
백만번 루프에서 0.1초 이내의 차이가 나는것이 확인되었습니다.
아마도 파서에의해 번역될때,
++는 어셈블리 INC ecx 명령으로 번역되고,
+=1은 어셈블리 ADD ecx, 1 정도로 번역된다고 생각합니다.
저 둘의 처리 속도차이로 이와같은 결과가 생긴다고 생각되는군요. (;)
역시 크게 신경쓰문제는 아닐듯 합니다.
댓글 7
-
DearMai
2004.07.12 18:11
아주 대형 알고리즘이 들어가는 프로그램이 아니고선 크게 차이가 나지 않겠네요 ^ㅡ^ -
플로렐라
2004.07.12 18:38
DearMai // 버블쇼트 같은게 아니라면 크게 신경쓸건 못되죠^-^;;; 그저 이런것도 있다..란걸 알리기 위해;;;
(몇가지 더 속도차이에 대한걸 실험해볼 생각;; 제가 하는게 뭐 이렇다는;;; 으헤에;;)
(뭐, 더빠르고 효율적인 처리로 우주의 엔트로피 증가를 느리게해 우주종말을 연기하는 효과도 있을지 모른다는 생각도;;;;;;) -
TheMics
2004.07.12 20:56
저것들은 애초에 방식이 다르죠;
관련글을 아마 플로렐라님께서 직접 올리셨었죠 아마? -
chipper
2004.07.12 22:57
읽어볼만한 글입니다.
++ 와 += 의 차이가 극명하게 날 정도의 알고리즘이라면 php 보다는 c 나 c++ 을 쓰겠지만요^^ -
플로렐라
2004.07.13 17:09
더믹스 // 전에 ++와 +=가 다르다고 올렸었는데,
이번에 다시해보니 ++쪽도 2^31+1이 되니 변수형이 더블로 변하면서 숫자가 올라가던..
php파서 버전에 따라 다른건가.. 설정이 있는건가..
c언어에서도 ++와 +=가 다르게 번역(컴파일)될듯 하군요.. (역시 아주약간의 속도차이..;) -
☆~
2004.07.13 17:29
++은 cpu의 레지스터 인지 머시기 (이름이 잘 =_=)에서 직접 가산한다고 하더군요..
++와 +=의차이가 있었는데.. ++은 16비트인지 32비트인지의 정수형까지밖에 가산이 않된다는군요..
( ++은 위의 cpu의 이름모를 곳에서 처리를 하고 리턴하는것 떼문이라고 하던것 같은... -0ㅡ;
요즘의 컴파일러는 최적화를 하면서 i = 1 + i; 가 있으면 i++;와 같은 코드가 나온다던데.. 그건 php와 상관 없군요 =_=;; -
권순현
2004.09.17 23:39
++ 같은경우 cpu 의 Register에 Accumulator(누산기)가 INC dx 이라는 Parser 에 의해 번역된 문장을 실행하는 걸로 알고 있었던데.. 아닌가요?
+= 같은경우 cpu 의 Register에 LOAD 하고, ADD dx,1 하고, STORE(맞나요?) 하고...
높은 Clock 을 가지고 있는 CPU 는, 차이가 미미하지만,
낮은 Clock 을 가지고 있는 CPU 는, 차이가 조금 더 합니다.
(166Mhz 짜리로 실험하려고 했습니다만, 학교측에서 무리를 준다고 허가를 받지 못했습니다)
(서버측쪽에서 계산하는 php 의 경우는 서버사양, 클라이언트쪽에서 계산하는 jas 는 클라이언트사양입니다.)
제목 | 글쓴이 | 날짜 |
---|---|---|
rand함수와 mt_rand함수의 비교 [6] | 심심타 | 2004.07.30 |
트랙백 구현하기 - 4. PHP로 트랙백 핑 받기 | TheMics | 2004.07.18 |
트랙백 구현하기 - 3. PHP로 트랙백 핑 보내기 [4] | TheMics | 2004.07.18 |
히어닥 문법 활용 [14] | ☺심심 | 2004.07.13 |
++와 +=1 의 속도차이 [7] | 플로렐라 | 2004.07.12 |
<와 <=의 속도차이? [23] | 플로렐라 | 2004.07.07 |
서버가 느려졌을경우... [20] | 신상우 | 2004.06.28 |
파일업로드시 파일명 중복되지 않게 저장하기.. [8] | 페리 | 2004.06.28 |
페이지에 암호를 걸자..=_= [27] | ☺심심 | 2004.06.25 |
아이피 접근을 막고 메세지 출력하기.. [11] | ☺심심 | 2004.06.24 |
오늘의 명언을 출력해주는 함수 [10] | 김재경 | 2004.06.15 |
3. if문 [13] | 티다 | 2004.06.05 |
응용편 - BMI 측정 테스트 소스를 만들어보자 [5] | 티다 | 2004.06.04 |
게시판내용에 코멘트를 달자!! -마지막- [2] | 이혁 | 2004.06.03 |
게시판내용에 코멘트를 달자!! -2- [1] | 헉스 | 2004.06.02 |
게시판내용에 코멘트를 달자!! [3] | 헉스 | 2004.06.02 |
2. array [5] | 티다 | 2004.06.02 |
1. 연산자 [2] | 티다 | 2004.06.02 |
주식정보출력코드 [2] | 김재경 | 2004.06.01 |
윈도우계정에서 현재 남은 용량과 DB 용량 알기 [6] | 지으니 | 2004.05.31 |