인프런 커뮤니티 질문&답변
쉬프트연산자 관련 질문입니다
해결된 질문
작성
·
159
답변 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이 채워져 값이 늘어나게 됩니다.
- 주신 예제에서
쉬프트 연산의 원리 요약:
- 왼쪽으로 비트를 이동할 때마다 비트 크기는 늘어날 수 있으며, 이 경우 10진수 값도 증가합니다. 오른쪽 빈자리는 항상
0으로 채워지기 때문에 기존의 데이터를 보존하지 않습니다.
- 왼쪽으로 비트를 이동할 때마다 비트 크기는 늘어날 수 있으며, 이 경우 10진수 값도 증가합니다. 오른쪽 빈자리는 항상
아래 링크 항목을 참고하시면 더 명확한 정보와 설명을 얻으실 수 있습니다:
- 쉬프트연산 - 쉬프트 연산자의 기본 사용법을 설명하는 게시물입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





