Friday, September 29, 2006
C언어,비트연산] unsigned short의 좌측, 우측 바이트만 얻기 - Left Byte, Right Byte
부호 없는 16비트 정수인 "unsigned short" 에서, 어느 한쪽의 바이트 값만을 알아내야 할 때가 있습니다. 특히 유니코드나, 완성형 한글 음절을 처리할 때 그렇습니다.
비트연산으로 바이트 추출 작업을 할 수 있는, getLeftByte(), getRightByte() 함수를 만들었습니다.
unsigned short 은 2개의 바이트(byte)로 이루어져 있습니다.
1번째 바이트(Lead Byte)를 좌측 바이트,
2번째 바이트(Trail Byte)를 우측 바이트로 표현했습니다.
파일명: 0.cpp
※ 아래 박스 클릭 후, 키보드 화살표 키로 좌우 스크롤 가능함
출력 결과:
(좌측 바이트) = 0xA1, (우측 바이트) = 0xB0
▶▶ C언어,비트연산] 바이트 순서 바꾸기 함수, short의 byte 위치를 Byte Swap
비트연산으로 바이트 추출 작업을 할 수 있는, getLeftByte(), getRightByte() 함수를 만들었습니다.
unsigned short 은 2개의 바이트(byte)로 이루어져 있습니다.
1번째 바이트(Lead Byte)를 좌측 바이트,
2번째 바이트(Trail Byte)를 우측 바이트로 표현했습니다.
unsigned short에서, 특정 바이트 읽기 예제
파일명: 0.cpp
※ 아래 박스 클릭 후, 키보드 화살표 키로 좌우 스크롤 가능함
#include <stdio.h>
unsigned char getLeftByte(unsigned short n);
unsigned char getRightByte(unsigned short n);
void main(void) {
char s[] = "가"; // 한글 완성형 "가"는, 메모리에는 0xA1B0 로 저장됨
unsigned short char16 = *((unsigned short *)s);
printf("(좌측 바이트) = 0x%02X, (우측 바이트) = 0x%02X\n", getLeftByte(char16), getRightByte(char16));
}
/*
1번째 바이트를 2번째 바이트 자리로 밀어버리면
2번째 바이트는 사라지고, 원래 1번째 바이트가 있던 자리는
0으로 채워짐. 따라서 1번째 바이트인 A1만 남음
10100001 10110000 (= 0xA1B0)
-----------------
00000000 10100001
*/
unsigned char getLeftByte(unsigned short n) {
return (unsigned char) (n >> 8);
}
/*
0과 & 되면 0,
1과 & 되면 원래 값 유지되기에,
0xFF (00000000 11111111) 로 & 하면,
10100001 10110000 (= 0xA1B0)
00000000 11111111
-----------------
00000000 10110000
1번째 바이트는 모두 0이 되고
2번째 바이트는 그대로 존재함. 따라서 2번째 바이트인 B0만 얻을 수 있음
*/
unsigned char getRightByte(unsigned short n) {
return (unsigned char) (n & 0xFF);
}
unsigned char getLeftByte(unsigned short n);
unsigned char getRightByte(unsigned short n);
void main(void) {
char s[] = "가"; // 한글 완성형 "가"는, 메모리에는 0xA1B0 로 저장됨
unsigned short char16 = *((unsigned short *)s);
printf("(좌측 바이트) = 0x%02X, (우측 바이트) = 0x%02X\n", getLeftByte(char16), getRightByte(char16));
}
/*
1번째 바이트를 2번째 바이트 자리로 밀어버리면
2번째 바이트는 사라지고, 원래 1번째 바이트가 있던 자리는
0으로 채워짐. 따라서 1번째 바이트인 A1만 남음
10100001 10110000 (= 0xA1B0)
-----------------
00000000 10100001
*/
unsigned char getLeftByte(unsigned short n) {
return (unsigned char) (n >> 8);
}
/*
0과 & 되면 0,
1과 & 되면 원래 값 유지되기에,
0xFF (00000000 11111111) 로 & 하면,
10100001 10110000 (= 0xA1B0)
00000000 11111111
-----------------
00000000 10110000
1번째 바이트는 모두 0이 되고
2번째 바이트는 그대로 존재함. 따라서 2번째 바이트인 B0만 얻을 수 있음
*/
unsigned char getRightByte(unsigned short n) {
return (unsigned char) (n & 0xFF);
}
출력 결과:
(좌측 바이트) = 0xA1, (우측 바이트) = 0xB0
▶▶ C언어,비트연산] 바이트 순서 바꾸기 함수, short의 byte 위치를 Byte Swap
tag: cpp
C언어 | C/C++ (Visual C++)
<< Home