인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

이원진님의 프로필 이미지

작성한 질문수

개발자를 위한 컴퓨터공학 1: 혼자 공부하는 컴퓨터구조 + 운영체제

명령어의 구조

마무리 - 확인 문제에 대해 질문있습니다.

작성

·

48

0

안녕하세요. 03-2 마무리 확인 문제 1번에서 ④번 선지도 틀린 것 아닌가요?
"명령어에 연산에 사용할 데이터를 직접 명시할 경우(= 즉시 주소 지정 방식) 표현할 수 있는 데이터의 크기는 연산코드의 크기만큼 작아집니다."
라고 되어 있는데, 책의 예시로 연산 코드가 4비트여도 오퍼랜드 크기는 12가 될 수 있으므로, 표현할 수 있는 데이터의 크기(12비트)는 연산코드의 크기(4비트)만큼 작아지지 않습니다.
따라서 표현할 수 있는 데이터의 크기는 연산코드의 크기에 따라 달라진다고 하는 게 맞지 않나요?

답변 1

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다.

이원진님, 말씀하신 부분에 대해 이해를 돕기 위해 설명드리겠습니다. 즉시 주소 지정 방식에서는 연산에 사용할 데이터가 명령어 내에 직접 포함되어 있습니다. 이는 즉시 값(Immediate Value)이 명령어 내의 오퍼랜드 부분에 저장된다는 것을 의미합니다.

명령어의 전체 크기는 고정된 값으로, 이 안에 연산 코드와 오퍼랜드가 포함되어야 합니다. 따라서 연산 코드가 커질수록 오퍼랜드에 할당할 수 있는 비트 수는 줄어들게 됩니다. 이는 결과적으로 명령어 내에서 실제로 표현 가능한 즉시 값의 크기가 제한된다는 뜻입니다.

하지만, 구체적인 오퍼랜드 크기는 CPU의 설계와 명령어 셋 아키텍처에 따라 달라질 수 있습니다. 즉, 연산 코드가 4비트여도 오퍼랜드가 12비트로 설계될 수 있는 방식을 지원하는 CPU도 존재할 수 있습니다. 여기서 즉시 주소 지정에서의 ‘표현할 수 있는 데이터 크기’라는 것은 명령어 길이와 시스템의 CPU 설계에 영향을 받는 부분이므로, 모든 경우에 연산코드의 크기만큼 작아진다는 설명보다는, 시스템 설계에 따라 다를 수 있다는 설명이 보다 맞습니다.

이와 관련해서 더 깊이 있게 학습을 원하시면 이 링크를 참고하시길 바랍니다: 주소 지정 방식을 알아야 하는 이유가 궁금합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.