인프런 커뮤니티 질문&답변
숙제 마지막 부분
작성
·
25
·
수정됨
1
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
{
// 숙제
unsigned char option_viewed = 0x01;
unsigned char option_edited = 0x02;
unsigned char option_liked = 0x04;
unsigned char option_shared = 0x08;
unsigned char option_deleted = 0x80;
unsigned char my_article_flags = 0;
cout << std::bitset<8>(my_article_flags) << endl;
my_article_flags |= option_viewed;
cout << std::bitset<8>(my_article_flags) << endl;
my_article_flags ^= option_liked;
cout << std::bitset<8>(my_article_flags) << endl;
my_article_flags ^= option_liked;
cout << std::bitset<8>(my_article_flags) << endl;
// 본기사의 좋아요와 공유도 지울려면 deleted기준으로 전체 삭제
// my_article_flags &= option_deleted;
// cout << std::bitset<8>(my_article_flags) << endl;
// 진짜 기사만 삭제
my_article_flags &= ~(option_viewed);
cout << std::bitset<8>(my_article_flags) << endl;
// 문제 2번은 드모르간 법칙이므로 성립
}
기사만 삭제라고 되어있는데
~() 사용한다고 보면될까요?
답변 2
0
안녕하세요? 질문&답변 도우미 durams입니다.
연습 문제의 1번의 마지막 문제는 '본 기사만 삭제하기' 인데요, 열람했는지 여부를 확인해서 봤다면 삭제하시면 될 것 같습니다. option_deleted를 삭제된 경우 참을 나타내는 비트 마스크라고 생각하시면 되겠네요.
my_article_flags &= ~(option_viewed);은 기사의 삭제가 아닌, 기사를 열람 상태에서 미열람 상태로 되돌리는 것을 의미합니다.
0
안녕하세요, 인프런 AI 인턴입니다. 변상윤님, 질문 주셔서 감사합니다.
질문하신 바와 같이 my_article_flags의 특정 비트를 지우기 위해서는 비트 연산을 사용하는 것이 적절합니다. 주어진 코드에서 ~(option_viewed)를 사용하여 특정 비트만을 지우려는 시도를 하고 계신 것 같습니다.
질문에서 언급하신 내용은 “진짜 기사만 삭제” 부분에 대한 것으로 이해됩니다. ~(option_viewed) 연산은 option_viewed 비트가 1인 위치를 0으로 설정하여 그 비트를 삭제하려는 의도입니다. 즉, 특정 비트만을 반대값으로 변경하여 이를 활용해 필요한 비트만 유지하거나 삭제할 수 있습니다.
드모르간의 법칙은 주로 논리 연산의 부정과 관련이 있지만, 비트 연산에서는 비트를 반전시키는 ~ 연산자로 논리적 반전 효과를 얻을 수 있습니다. 따라서, 특정 비트를 삭제하려면 비트셋 전체를 부정한 후 원하는 위치의 비트를 다시 긍정한다던가 하는 방식으로 사용할 수 있겠습니다. 그러므로 my_article_flags &= ~(option_viewed); 는 option_viewed 비트만 제거하고 나머지는 유지하게 됩니다.
관련하여 더 심층적인 설명이 필요한 경우 아래 관련 리소스를 참고하시면 유익할 것입니다:
위의 참고 링크에서 비트 연산에 대한 다양한 예시에 대해서 확인하실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





