SunOS에서 컴파일시 warning...
clmu[i].arr = (void *)(record+CADDR(cnos[i]));
위와 같은 부분에서 Warning이 뜨는데 원인도 알고 해결방법도 대충 알겠는데 조금 더 깊은 부분을 알고 싶어서 글을 올립니다.
뜨는 Warning은 다음과 같습니다.
Table.c", line 154: warning: pointer to void or function used in arithmetic
clmu[i].arr은 void * 타입이며 record도 void *타입입니다. CADDR은 매크로인데 short로 보시면 되겠군요.
record안에 여러가지 타입의 데이타가 죽 이어져 들어가 있기 때문에 이 코드는 arr에 필요한 데이타의 시작 주소를 넣어주는 역할을 하는 것입니다. 즉 record의 시작주소에 CADDR만큼 더한 만큼의 주소값을 arr에 넣어주는 코드입니다.
물론 지금 상태대로도 컴파일과 실행에는 문제가 없습니다만..
워닝내용대로 void *타입에 사칙연산을 수행하는 것이 문제라고 했기 때문에 record를 (char *)로 캐스팅해서 컴파일하니 아무 메시지없이 잘 컴파일 되더군요.
clmu[i].arr = (void *)((char *)record+CADDR(cnos[i]));
근데 위의 코드를 -맨 위의 코드- 리눅스에서 컴파일할 때는 아무 메시지도 안 떴거든요. -Wall로 했었습니다만...
선 cc에서 저런 warning를 내는 이유를 알고 싶습니다.
그리고 제가 해결한 방법이 너무 어거지는 아닌지 -_- 알고 싶네요. 아니면 좀 더 나은 방법이 있는지...
void *타입의 로컬 변수 자체를 쓰지 않는게 더 나을까요?
시스템은 블레이드 2000이며 uname은.. SunOS blade2 5.8이라고 나오네요.
아마도 SUN compiler (WorkShop: SUNWspro) 의
아마도 SUN compiler (WorkShop: SUNWspro) 의 문법 check 가 원인 같군요.
Linux 에서는 문제가 발생하지 않는 것은 사용하신 GCC 의 문법 check 가 SUN compiler 에 비해서 엄하지 않기 때문이라고 생각되네요.
이 문제로 인해서 실제로 OpenSource 중에 SUN compiler 에서 compile 안되는 것도 꽤 있습니다.
Solaris 에서 GCC 사용하셔서 compile 해보시고 확인해 보세요.
그리고 해결하신 방법도 별 문제가 없다고 봅니다.
Good Luck!!! :wink:
Good Luck!
char *a;int *b;a += 1;b += 1;
char *a;
int *b;
a += 1;
b += 1;
포인터에 대한 + 연산은 포인터의 타입에 따라 달라 집니다.
a 변수의 경우 1 byte씩 증가 하지만 b의 경우는 4byte씩 증가 합니다.
제 생각은 프로그래머가 변수의 타입을 확인 할 수 있는도록 warning을 내주는 것이 나아보이네요.
그런면에선 해결하신 방법이 정석인듯 합니다^^ :)
아니면 처음부터 char * 를 쓰셔도......
pointer to void (void *)에 사칙 연산을 수행하는 것은
pointer to void (void *)에 사칙 연산을 수행하는 것은 안됩니다.
undefined behavior를 낳습니다.
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
댓글 달기