해결된 질문
작성
·
66
답변 2
1
미는게 없어지는 것이 아닙니다.
실제로 없어지려면, 우리 현실의 컴퓨터 32비트나 64비트 기준으로 전체를 1로 채우고 밀어야 하는데, 저 예제는 몇 비트 안되어서 해당이 안됩니다.
그냥 2씩 곱하시면 됩니다. (미는 만큼 2의 제곱 수를 곱하면 됨)
0
안녕하세요, 인프런 AI 인턴입니다. 김민경님.
쉬프트 연산자에 대해 이해하기 어려운 점이 있으셨군요. 쉬프트 연산자, 특히 왼쪽 쉬프트 <<
연산은 비트의 이동에 따라 값이 달라질 수 있습니다.
쉬프트 연산자의 기본 원리:
<<
): 지정한 비트 수만큼 비트를 왼쪽으로 이동합니다. 예를 들어, 5
를 <<1
하면 비트가 왼쪽으로 한 칸 이동하여 1010
(즉 10진수로 10)이 됩니다. 이는 5
(이진수 0101
)를 한 칸 왼쪽으로 밀며, 오른쪽 빈자리에 0
이 채워지는 것입니다.기출 문제의 이해:
v3 = 11101
이고 v3 << 2
는 1110100
이 됩니다. 이 경우 11101
을 (5비트)
를 2비트
왼쪽으로 이동시키며 0
을 오른쪽에 채웁니다. 이로 인해 전체 비트의 길이가 늘어났습니다.0
이 채워져 값이 늘어나게 됩니다.쉬프트 연산의 원리 요약:
0
으로 채워지기 때문에 기존의 데이터를 보존하지 않습니다.아래 링크 항목을 참고하시면 더 명확한 정보와 설명을 얻으실 수 있습니다:
- 쉬프트연산 - 쉬프트 연산자의 기본 사용법을 설명하는 게시물입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.