웹마스터 팁
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 는 클라이언트사양입니다.)
제목 | 글쓴이 | 날짜 |
---|---|---|
리눅스에서 APM 설치 [9] | zero | 2000.05.31 |
Zend Optimizer 4 설치 (아파치와 PHP4 Zend도 같이..) (리눅스) [6] | zero | 2000.06.04 |
쿠키(cookie)의 활용 [44] | zero | 2000.03.06 |
카운터를 만들어봅시다~ (수정본) [181] | zero | 2000.03.08 |
페이지 자동 이동 방법 3가지!!! [10] | zero | 2000.03.06 |
자동링크 만드는 방법!!! [28] | zero | 2000.03.06 |
MySQL DB 데이타 백업/복구 하는 방법 [38] | zero | 2000.08.26 |
윈2000, NT 또는 98에서 APM설치하기 [74] | zero | 2000.08.26 |
교육용 메모장 #1 [53] | zero | 2000.07.10 |
교육용 메모장 #2 [18] | zero | 2000.07.10 |
교육용 메모장 #3 [16] | zero | 2000.07.10 |
교육용 메모장 #4 [18] | zero | 2000.07.10 |
교육용 메모장 #5 [21] | zero | 2000.07.10 |
최근 게시물을 나타내는 원리와 방법 [55] | zero | 2000.03.06 |
전에 올렸던 폼메일 만들기입니당~~~ ^^ [38] | zero | 2000.03.08 |
교육용 방명록 #1 [전체구성 설정, 테이블 생성, 기본함수 정의] [50] | zero | 2000.07.03 |
교육용 방명록 #2 [글쓰기 폼 작성] [11] | zero | 2000.07.03 |
교육용 방명록 #3 [글쓰기 폼에서 넘어온 값을 DB에 입력하기] [5] | zero | 2000.07.03 |
교육용 방명록 #6 [수정된 값을 넘겨받아서 비밀번호를 비교하고 변경하여 줍니다.] [2] | zero | 2000.07.03 |
교육용 방명록 #7 [삭제 버튼을 눌렀을 때 비밀번호를 입력받는 부분입니다.] [5] | zero | 2000.07.03 |