인프런 커뮤니티 질문&답변
22:15 두줄을 한줄로 할수 있다고 한 부분 답 질문!
작성
·
406
1
비트 플래그 강의 중 22:15초 에
두 줄에서 한 줄로 줄여 사용할 수 있다고 한 부분이 있는 데,
items_flag ^= opt2 | opt1;
이거 맞나요???
답변 1
1
안녕하세요, 답변 도우미 Soobak 입니다.
네 맞습니다. 😁👍
unsigned char items_flag = 0;
const unsigned char opt1 = 1 << 1;
const unsigned char opt2 = 1 << 2;위와 같이 선언된 변수들을 비트 단위로 표현해보면 다음과 같습니다.
items_flag : 0000
opt1 : 0010
opt2 : 0100우선, 강의에서의 두 줄 코드의 연산 결과는 다음과 같습니다.
items_flag^=opt2
:0000^=0100이므로, 결과는0100items_flag^=opt1
:0100^=0010이므로, 결과는0110
따라서, 최종적인 연산 결과는 0110 이 되네요.
이 때, 질문자님께서 말씀해주신 방법으로 연산해보면,
(opt1 | opt2)
:0010|0100이므로, 결과는01100000^0110의 결과는0110
즉, 한 줄로 줄이신 코드의 결과와 줄이기 전의 코드의 결과가 같네요!
반면, 다른 방법들도 있습니다.
예를 들자면 items_flag ^= (opt1 ^ opt2) 도 같은 결과를 얻을 수 있습니다.
(opt1 ^ opt2)
:0010^0100이므로, 결과는01100000^0110의 결과는0110
또한, + 연산자를 사용해도 같은 결과를 얻을 수 있는데, 이 경우들에 대해서는 오버플로우 문제가 생길 수 있고, 강의의 주된 주제와 조금 벗어난다고 생각하여 그냥 다양한 방법들이 가능하구나 정도로만 이해해주시면 감사하겠습니다.
items_flag^=(opt1 + opt2)
:(opt1 + opt2)
->0010+0100이므로, 결과는0110
이어서,0000^0110의 결과는0110items_flag+=(opt1 ^ opt2)
:(opt1 ^ opt2)
->0010^0100이므로, 결과는0110
이어서,0000+0110의 결과는0110
다시한번 말씀드리지만, 이와 같은 방법을 사용할 때 만약 items_flag 의 값 혹은 (opt1 + opt2) 의 값 등이 unsigned char 자료형의 범위를 벗어난다면 오버플로우가 발생하게 되므로 조심해야합니다.
또 궁금하신 점 있으시면 편하게 질문 남겨주세요. 감사합니다. 👍





