#define 을 통해 __LINE__, __FUNCTION__ 을 쓰더라도 실제 매크로에 의해 전환되는 line, function 을 출력하게 해주세요!
글쓴이: saintlife / 작성시간: 목, 2012/06/28 - 8:29오후
약간 어렵게 제목을 달았는데요.. 코드는 아래와 같습니다.
#define debug_printf(x), printf("[%d, %s]"x, __LINE__, __FUNCTION__)
int main() {
debug_printf("hello\n");
return 0;
}
이렇게 하면..
[4, main()]hello
로 출력되기를 바랍니다..! 그런데..
[1, ??]hello
이렇게 밖에 출력이 안되요..ㅠ
정리하자면, #define 을 통해 __LINE__ 을 쓰더라도 실제 매크로에 의해 전환되는 지점의 line 을 __LINE__ 으로 받게 해주세요! 부탁드립니다!!
Forums:
__FUNCTION__ 대신 __func__를 써도
__FUNCTION__ 대신 __func__를 써도 안되나요?
Signature :) - "여유를 갖고 행동하되 게을러지지 말자"
그 부분을 해보지는 못했지만.. function
그 부분을 해보지는 못했지만.. function 보다도 line 이 더 중요합니다 ㅠ
__func__ 도 한번 써볼게요 정말로 감사합니다!
컴파일이 됐을리가 없는데...
컴파일이 됐을리가 없는데...
어... 저는 잘 되는데요? 본문 코드가 좀 깨져
어... 저는 잘 되는데요?
본문 코드가 좀 깨져 있어서 정확히 어떻게 하셨는지 몰라서 제가 다시 만들었는데,
리눅스 gcc 4.1.2
윈도우 Visual C++ express 2010
양쪽에서 다 잘 나왔습니다.
(KLDP에 올릴 때 코드 내 특정한 패턴이 먼저 처리되면서 제대로 안 올라가는군요. 다른 곳에 올리고 링크로 대체합니다)
https://gist.github.com/3015590
좋은 하루 되세요!
... #define xxx(x),
가 컴파일이 된다는 거죠 ?
링크 보시면 아시겠지만, xxx(x) 뒤에 있는
링크 보시면 아시겠지만,
xxx(x) 뒤에 있는 컴마야 뺐지요. 오타려니 하고... :-)
좋은 하루 되세요!
[ 가 문제인것 같더군요.. 한칸 띄면 잘
원글의 답글은 아닙니다...
[ 가 문제인것 같더군요.. 한칸 띄면 잘 되는듯..
네, [ 하고 %하고 붙여 썼을 때 그게 다른 치환이
네, [ 하고 %하고 붙여 썼을 때 그게 다른 치환이 먼저 되나보더라고요.
좋은 하루 되세요!
허.. 답변 주신 분들 감사합니다!
바뻐서 이제야 확인했네요..ㅠ
코드 자체 올라간게 저런식으로 깨져 보인다는 것도...;;
gcc 4.1.2 에서 된다는 거죠...
한번 해보겠습니다..ㅠ
답변 주신 분들 모두 감사드립니다!
댓글 달기