비트 필드를 이용한 10 진수를 2 진수로 출력하는 프로그램인데
글쓴이: yangam / 작성시간: 금, 2004/09/17 - 1:56오전
// 10 진수를 2 진수로 출력하는 프로그램 (비트필드 이용) #include <stdio.h> union bit_field1 { int n; unsigned bit1 : 1; unsigned bit2 : 1; unsigned bit3 : 1; unsigned bit4 : 1; unsigned bit5 : 1; unsigned bit6 : 1; unsigned bit7 : 1; unsigned bit8 : 1; unsigned bit9 : 1; unsigned bit10 : 1; unsigned bit11 : 1; unsigned bit12 : 1; unsigned bit13 : 1; unsigned bit14 : 1; unsigned bit15 : 1; unsigned bit16 : 1; unsigned bit17 : 1; unsigned bit18 : 1; unsigned bit19 : 1; unsigned bit20 : 1; unsigned bit21 : 1; unsigned bit22 : 1; unsigned bit23 : 1; unsigned bit24 : 1; unsigned bit25 : 1; unsigned bit26 : 1; unsigned bit27 : 1; unsigned bit28 : 1; unsigned bit29 : 1; unsigned bit30 : 1; unsigned bit31 : 1; unsigned bit32 : 1; } num; int main() { printf("\n아무 숫자나 입력하세요: "); scanf("%d", &num.n); printf("\n10 진수 %d 를 2 진수로 표현하면.... %d%d%d%d%d%d%d%d %d%d%d%d%d%d%d%d %d%d%d%d%d%d%d%d %d%d%d%d%d%d%d%d\n\n", num.n, num.bit32, num.bit31, num.bit30, num.bit29, num.bit28, num.bit27, num.bit26, num.bit25, num.bit24, num.bit23, num.bit22, num.bit21, num.bit20, num.bit19, num.bit18, num.bit17, num.bit16, num.bit15, num.bit14, num.bit13, num.bit12, num.bit11, num.bit10, num.bit9, num.bit8, num.bit7, num.bit6, num.bit5, num.bit4, num.bit3, num.bit2, num.bit1); return 0; }
이 프로그램이 제대로 작동하지 않는 이유가 뭔가요?
위에 처럼 정의하면, int 형 변수 n 이 32 비트를 차지..
그리고 그 32 비트를 1 비트씩 bit1 - bit32 변수가 공유하는 것으로 배웠는데..
ㅇㅖ전에 됐던 것 같은데 이상하네요.
참고로.. union 안에 struct 로 비트 필드를 넣었을 때는 됩니다.
즉....
union b { int n; struct bit { unsigned bit1 : 1; unsigned bit2 : 1; . . (생략) . . unsigned bit32 : 1; } bit; } num;
Forums:
첫번째 예는 모든 비트가 같은 값을 갖죠.. int의 첫번째 비트를 모두
첫번째 예는 모든 비트가 같은 값을 갖죠.. int의 첫번째 비트를 모두 공유하는 것 같습니다.
이렇게요..
그러니 4를 입력하면 100 이므로 0번째 비트가 0이니까.. 모두 0이 출력되고 .. 3을 입력하면 11 이므로 0번째 비트가 1이기때문에 모두 1이 출력됩니다..반면에 두번째예에서는
이 되어 예상 한 결과가 나오고요..
Re: 비트 필드를 이용한 10 진수를 2 진수로 출력하는 프로그램
문제 안에 답이 있네요. 이게 정답입니다.
union만 쓰고 struct 썼을 때 원하는 대로 안 나오는 이유는...
union의 정의를 잘 보시면 알 수 있겠죠?
세벌 https://sebuls.blogspot.kr/
댓글 달기