2007년 11월 29일
try { throw } catch {} & do { break } while (false)
예외를 처리하기 위해 여러가지 방법이 있는데, C++에서 표준으로 제공하는 try-throw-catch가 있다. 그러나 이 방법은 exception을 처리하기 위해 갖가지 삽질을 내부적으로 하는 것으로 매우 느리다는게 잘 알려져 있다. 그래도 얼마나 느린지 알고 싶었다. 그래서 do {} while (false)와 비교해보기로 했다.
대충 컴파일해서 돌려본 결과...
좌절인데...
물론 try-throw-catch가 함수를 넘나들 수 있는 장점은 있지만, setjmp/longjmp도 할 수 있고...
편리한 것과 속도... trade-off할만하지 않아!
'>
'>
#include <exception>
#include <iostream>
#include <sys/time.h>
using namespace std;
static size_t gTestCount(100000);
typedef long long ts_t;
ts_t
getTimestamp(void)
{
static __thread struct timeval tv;
gettimeofday(&tv, NULL);
return 1000000LL * tv.tv_sec + tv.tv_usec;
}
inline
void
funcDOWHILE(void)
{
static __thread size_t i(0);
do
{
++i;
if ( i%2 ) break;
return;
} while (false);
++i;
return;
}
inline
void
funcEXCEPTION(void)
{
static __thread size_t i(0);
static exception _e;
try
{
++i;
if ( i%2 ) throw(exception());
}
catch(const exception&)
{
++i;
}
return;
}
int
main(int argc, char* argv[])
{
ts_t t1, t2, diff;
t1 = getTimestamp();
for (size_t i(0); i<gTestCount; i++ )
{
funcEXCEPTION();
}
t2 = getTimestamp();
diff = t2 - t1;
cout << "exception: " << diff << endl;
t1 = getTimestamp();
for (size_t i(0); i<gTestCount; i++ )
{
funcDOWHILE();
}
t2 = getTimestamp();
diff = t2 - t1;
cout << "do-while: " << diff << endl;
return 0;
}
대충 컴파일해서 돌려본 결과...
exception: 492746
do-while: 250좌절인데...
물론 try-throw-catch가 함수를 넘나들 수 있는 장점은 있지만, setjmp/longjmp도 할 수 있고...
편리한 것과 속도... trade-off할만하지 않아!
Powered by ScribeFire.
# by | 2007/11/29 14:06 | IT | 트랙백(1) | 핑백(1) | 덧글(2)









제목 : C/C++의 예외 모델 차이
try { throw } catch {} & do { break } while (false) 에서 트랙백. C++의 예외 처리가 느리기 때문에 do while을 이용한 코드 블럭 탈출 / setjmp/longjmp를 이용한 함수간 예외 전달을 다뤘길래 문제가 있다고 ......more
... rein님의 C/C++의 예외 모델 차이 포스팅에서 C와 C++ 예외 모델 차이, 나와 다른 견해에 대해 깔끔하게 잘 설명하셨다. rein님 포스팅을 보고 내 포스팅에 덧글로 달까...라고 생각했지만 말도 길어지고 해서 트랙백납치!! 100년도 안 되는 삶을 살아오면서 실무에 setjmp/longjmp를 쓴 적은 단 한 번 ... more