Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| 15 | 16 | 17 | 18 | 19 | 20 | 21 |
| 22 | 23 | 24 | 25 | 26 | 27 | 28 |
Tags
- DOCKER-USER
- 풀이
- rfc5508
- C언어
- epoll_wait
- epoll
- architecture
- Compiler
- REDIS
- NAPT
- edge trigger
- mvwin
- .nret core 배포
- wrefresh
- 취약점
- cbpf
- ncurses
- .net core 7
- vtable
- LOB
- BOF
- level trigger
- 어셈블리어
- iptables
- packet filter
- ioctl
- packet flow
- doupdate
- Docker
- wnourefresh
Archives
- Today
- Total
Tuuna Computer Science
[ROTATE SHIFT] C 언어 회전시프트 TIP 본문
// [ROTATE shift]
unsigned int _rotl(unsigned int value, int shift) {
if ((shift &= 31) == 0)
return value;
return (value << shift) | (value >> (32 - shift));}
/* 이때 32는 int형이 32일 때를 가정한 것이다. */
unsigned int _rotr(unsigned int value, int shift) {
if ((shift &= 31) == 0)
return value;
return (value >> shift) | (value << (32 - shift));}
처음에 1바이트를 기준으로 하고 있었는데 int가 32비트라서 생각치 못한 값이 나와서 놀램.
근디 저렇게 구현하는 것보다
gcc inline어셈블리 사용해서 ROL이나 ROR명령어 쓰는게 현실적으로 더 빠를거 같고, stackoverflow에서도 권장하는거 같음.
'C language' 카테고리의 다른 글
| container_of & offsetof 매크로 분석 (0) | 2019.04.03 |
|---|---|
| [C 언어] fgets함수 분석과, stdin 모험 (0) | 2019.03.31 |
| [안드로이드 게임]텐트와 나무 게임 알고리즘 분석해보기(머리로 풀지 말고 컴퓨터로 풀자) (22) | 2018.11.25 |
| 시저암호 암호화 복호화 소스 (0) | 2018.11.02 |
| [C Language] 배열없이 문자열의 빈도수 구하기 (0) | 2018.10.26 |
Comments