//----------------------------
아래 소스코드는 웹 컴파일러에서 확인한 경우입니다. http://www.codepad.org/
C로 하면. 그냥 되고.
C++로 하면. 이와 같은 오류 메시지가 발생합니다.
#include <stdio.h>
cc1plus: warnings being treated as errors
In function 'int main(int, char**)':
Line 12: warning: format '%x' expects type 'unsigned int*', but argument 3 has type 'int**'
Line 13: warning: format '%x' expects type 'unsigned int', but argument 2 has type 'int*'
//C에서는 컴파일이 성공하고. C++에서는 오류가 발생한 경우
int main(int argc, char** argv)
{
char test[20] = "0x123456";
int* a;
sscanf(test, "%x", &a);
printf("%x\n", a);
return 0;
}
#include <stdio.h>
//int 형 변수로 성공한 경우
int main(int argc, char** argv)
{
char test[20] = "0x123456";
unsigned int a;
sscanf(test, "%x", &a);
printf("%x\n", a);
return 0;
}
#include <stdio.h>
//new 로 할당해서 성공한 경우
int main(int argc, char** argv)
{
char test[20] = "0x123456";
unsigned int* a = NULL;
a = new unsigned int[1];
sscanf(test, "%x", a);
printf("%x\n", *a);
delete a;
return 0;
}
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
64비트 머신 기준으로 포인터는 8바이트이고 unsigned int는 4바이트인데 sscanf에서 %x (unsigned int) 를 사용했으니 4바이트만 공간을 채워주고 나머지는 쓰레기값이 들어가겠죠. 컴파일해 보니 gcc는 다음과 같이 경고를 내주네요.
$ cat x.c
#include <stdio.h>
#include <string.h>
int main(void)
{
char test[] = "0x123456";
int *a;
sscanf(test, "%x", &a);
return 0;
}
$ gcc -W -Wall x.c
x.c: In function ‘main’:
x.c:8:5: warning: format ‘%x’ expects argument of type ‘unsigned int *’, but argument 3 has type ‘int **’ [-Wformat=]
sscanf(test, "%x", &a);
^
경고는 에러라고 생각하고 -W -Wall 켜고 다 잡는 게 좋습니다.
%x 대신 %p를 써보세요. (이게 표준으로 보장이 되는지는 잘 모르겠습니다만 적어도 linux gcc에서는 되는 것 같군요.)
의견
len = strlen(test);
int mask = -1; // 11111111
mask <<= len; // 11000000
mask = ~mask; // 00111111
a &= mask;
딱 떠오른 방법인데 이런 건 어떤가요? 성능은 썩 좋아보이지는 않긴 한데.
저는 이렇게 생각했습니다.
의견 추가.
C를 이용한 구현입니다.
#include <stdio.h> #pragma warning(disable:4996) int main(void) { char test[20] = "0x7f123456"; int* a; int len; int mask; // get pointer value from string first sscanf(test, "%x", &a); printf("before\t: %016p \n", a); // make got pointer value valid len = 6; mask = ~(-1 << (len * 4)); // 4 bit for 1 digit a = (int *)((int)a & mask); printf("after\t: %016p \n", a); return 0; }저는 이렇게 생각했습니다.
DevC++ 로 해보니. 그냥 되네요.
DevC++ 5.11 (.CPP 파일)
WindowsXP 32비트 (서비스팩 없는 버전)
질문하신분 소스 그대로 해도. 123456 그냥 나옵니다.
//----------------------------
아래 소스코드는 웹 컴파일러에서 확인한 경우입니다.
http://www.codepad.org/
C로 하면. 그냥 되고.
C++로 하면. 이와 같은 오류 메시지가 발생합니다.
#include <stdio.h> cc1plus: warnings being treated as errors In function 'int main(int, char**)': Line 12: warning: format '%x' expects type 'unsigned int*', but argument 3 has type 'int**' Line 13: warning: format '%x' expects type 'unsigned int', but argument 2 has type 'int*' //C에서는 컴파일이 성공하고. C++에서는 오류가 발생한 경우 int main(int argc, char** argv) { char test[20] = "0x123456"; int* a; sscanf(test, "%x", &a); printf("%x\n", a); return 0; } #include <stdio.h> //int 형 변수로 성공한 경우 int main(int argc, char** argv) { char test[20] = "0x123456"; unsigned int a; sscanf(test, "%x", &a); printf("%x\n", a); return 0; } #include <stdio.h> //new 로 할당해서 성공한 경우 int main(int argc, char** argv) { char test[20] = "0x123456"; unsigned int* a = NULL; a = new unsigned int[1]; sscanf(test, "%x", a); printf("%x\n", *a); delete a; return 0; }----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
...
64비트 머신 기준으로 포인터는 8바이트이고 unsigned int는 4바이트인데 sscanf에서 %x (unsigned int) 를 사용했으니 4바이트만 공간을 채워주고 나머지는 쓰레기값이 들어가겠죠. 컴파일해 보니 gcc는 다음과 같이 경고를 내주네요.
$ cat x.c #include <stdio.h> #include <string.h> int main(void) { char test[] = "0x123456"; int *a; sscanf(test, "%x", &a); return 0; } $ gcc -W -Wall x.c x.c: In function ‘main’: x.c:8:5: warning: format ‘%x’ expects argument of type ‘unsigned int *’, but argument 3 has type ‘int **’ [-Wformat=] sscanf(test, "%x", &a); ^경고는 에러라고 생각하고 -W -Wall 켜고 다 잡는 게 좋습니다.
%x 대신 %p를 써보세요. (이게 표준으로 보장이 되는지는 잘 모르겠습니다만 적어도 linux gcc에서는 되는 것 같군요.)
댓글 달기