invalid lvalue in assignment 가 나오는데 어떻게 고치면 될까요?
글쓴이: narusas / 작성시간: 금, 2006/03/24 - 2:46오후
오픈 소스를 컴파일하려고 했는데
*((unsigned char *)cursor))++ = cbyte;
*((unsigned int *)cursor)++ = mask;
이런 코드가 포함되어 있는 부분에서 컴파일 에러가 납니다.
컴파일 에러는
invalid lvalue in assignment
invalid lvalue in increment
이 두개인데요.
개인적으로 해석하기로는 왼쪽에 있는 놈에게 할당이나 증가를 시킬수 없다.. 라는 의미로 보입니다.
그런데 다른 메일링 리스트를 보니 이런 문제를 겪은 사람이 없어 보이는 것으로 보아 잘들 컴파일 해서 쓰는거 같은데요...
테스트해 본 gcc버전은
Suse 9.2에 포함된 gcc 3.3.4 와 fedora core 5에 포함된 gcc4.1.0 두개를 테스트해 봤습니다.
이걸 어떻게 해야 컴파일 시킬수 있을까요?
Forums:
컴파일러 버그로 보입니다.
오타가 아니라면, 컴파일러 버그로 보입니다
(여기서 cursor는 수정가능한 lvalue여야 합니다).
동일한 코드가 많지 않다면, 다음과 같이 수정해 보세요.
이것도 안된다면, 풀어써야 할것 같습니다.
가져온 open 소스의 게시판을 확인해 부는 것도 좋겠습니다.
컴파일러의 버그가
컴파일러의 버그가 아니라 코드가 잘못된 것입니다.
후위형 ++ 연산의 결과는 lvalue가 아니므로 대입을 하는 것은 잘못이죠.
코드의 의도도 이해하기 힘들군요. 이런 것일까요?
gcc 버전 문제인듯..
Rehat 6.x rehdat 7.2까지는 No problems, should work straight out of the box.하다고 하는데요..
예전 gcc에서는 제대로 컴파일 된거 같은데요.. 이걸 요즘 gcc에서 컴파일하게 변경하려면 어떻게 해야 하는지 모르겠네요.
원본 코드는 다음과 같습니다.
소스가 잘못된 거
소스가 잘못된 거 같습니다.
cursor 포인터 자체는 분명 lvalue입니다.
그러나 cursor 포인터를 캐스팅하면 캐스팅된 결과는 rvalue가 됩니다.
즉 ((unsigned char *)cursor)은 rvalue입니다.
이 코드가 될지 안될지를 따져보세요.
C99 p81
캐스트는 lvalue를 만들지 않는다.
(단, C++에서 캐스트의 반환 값 type이 Ref인 경우에는 lvalue)
string copy하는 루틴은
식으로들 곧잘 구현합니다.
위의 while문은 캐스트가 없으므로 전혀 문제가 안됩니다만,
*((unsigned char *)cursor))++ 는
cursor를 unsigned char*로 캐스트하고 ++를 하려고 하기 때문에
표준 위반입니다.
http://gcc.gnu.org/gcc-4.0/changes.html를 보니 4.0부터 표준대로 한다는군요.
The cast-as-lvalue, conditional-expression-as-lvalue and compound-expression-as-lvalue extensions, which were deprecated in 3.3.4 and 3.4, have been removed.
___________________________________
Less is More (Robert Browning)
___________________________________
Less is More (Robert Browning)
실은...
이 자체로는 위반이 아닙니다. 캐스팅한 결과는 lvalue가 아니지만 그것을 역참조한 값은 lvalue입니다.
즉
(unsigned char *)cursor
는 lvalue가 아니지만*((unsigned char *)cursor))
는 lvalue입니다.따라서
*((unsigned char *)cursor))++
역시 적법합니다.원 코드에서 잘못된 점은 후위형 ++을 한 결과가 lvalue가 아니기 때문에
*((unsigned char *)cursor))++ = some_value
처럼 대입을 할 수 없다는 것입니다.
글쎄요.
연산자 우선순위가 post increment가 앞설 텐데요.
http://www.swansontec.com/sopc.htm
*보다 ++가 먼저 겠지요...
___________________________________
Less is More (Robert Browning)
___________________________________
Less is More (Robert Browning)
Quote:연산자
그렇군요. 제가 착각했습니다.
문제는 저게 컴파일 된다는 겁니다..
gcc 2.9.2에서 정상적으로 컴파일 되네요. -_-
음. 추측컨에 gcc 3.0으로 들어 오면서 무언가 처리가 바뀐것 같군요.
그럼 저걸 gcc 3.0이상에서 컴파일 시킬려면 어떻게 바꿔주면 될까요?
더 궁굼한건..
이런식으로 do while 이 case 문의 scope를 넘어서도 되는 겁니까?
지적 감사합니다.
invalid lvalue in increment 이 에러는 cast-as-lvalue extension때문일것이고요
invalid lvalue in assignment 이것은 compound-expression-as-lvalue extension 때문일까요?
이 부분에서 좀더 설명을 해 주실수 있으신가요?
case 문도 하나의 문장이기 때문에 사용해도 괜찮습니다. 하지만,
바람직하지는 않습니다.
4.8 Generalized Lvalues
disable된 lvalue관련 gcc extension입니다.
http://gcc.gnu.org/onlinedocs/gcc-2.95.3/gcc_4.html#SEC69
___________________________________
Less is More (Robert Browning)
___________________________________
Less is More (Robert Browning)
댓글 달기