작성
·
403
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
이므로, 결과는 0100
items_flag
^= opt1
: 0100
^= 0010
이므로, 결과는 0110
따라서, 최종적인 연산 결과는 0110
이 되네요.
이 때, 질문자님께서 말씀해주신 방법으로 연산해보면,
(opt1 | opt2)
: 0010
| 0100
이므로, 결과는 0110
0000
^ 0110
의 결과는 0110
즉, 한 줄로 줄이신 코드의 결과와 줄이기 전의 코드의 결과가 같네요!
반면, 다른 방법들도 있습니다.
예를 들자면 items_flag
^= (opt1 ^ opt2)
도 같은 결과를 얻을 수 있습니다.
(opt1 ^ opt2)
: 0010
^ 0100
이므로, 결과는 0110
0000
^ 0110
의 결과는 0110
또한, + 연산자를 사용해도 같은 결과를 얻을 수 있는데, 이 경우들에 대해서는 오버플로우 문제가 생길 수 있고, 강의의 주된 주제와 조금 벗어난다고 생각하여 그냥 다양한 방법들이 가능하구나 정도로만 이해해주시면 감사하겠습니다.
items_flag
^= (opt1 + opt2)
: (opt1 + opt2)
-> 0010
+ 0100
이므로, 결과는 0110
이어서, 0000
^ 0110
의 결과는 0110
items_flag
+= (opt1 ^ opt2)
: (opt1 ^ opt2)
-> 0010
^ 0100
이므로, 결과는 0110
이어서, 0000
+ 0110
의 결과는 0110
다시한번 말씀드리지만, 이와 같은 방법을 사용할 때 만약 items_flag
의 값 혹은 (opt1 + opt2)
의 값 등이 unsigned char
자료형의 범위를 벗어난다면 오버플로우가 발생하게 되므로 조심해야합니다.
또 궁금하신 점 있으시면 편하게 질문 남겨주세요. 감사합니다. 👍