redis源码笔记-endian

对于目标机是大端字节序的机器,进行字节码的转换,提供了16byte、32byte、64byte字节的转换。在intset\ziplist\zipmap三种数据结构中使用,使得不同字节序机器生成的rdb文件格式都是统一的(小端字节序),便于兼容。

代码实在是太简单了,贴上来,不多说了。

endian.h

 1 #ifndef __ENDIAN_H
 2 #define __ENDIAN_H
 3 
 4 void memrev16(void *p);
 5 void memrev32(void *p);
 6 void memrev64(void *p);
 7 
 8 /* variants of the function doing the actual convertion only if the target
 9  * host is big endian */
10 #if (BYTE_ORDER == LITTLE_ENDIAN)
11 #define memrev16ifbe(p)
12 #define memrev32ifbe(p)
13 #define memrev64ifbe(p)
14 #else
15 #define memrev16ifbe(p) memrev16(p)
16 #define memrev32ifbe(p) memrev32(p)
17 #define memrev64ifbe(p) memrev64(p)
18 #endif
19 
20 #endif

endian.c

 1 /* Toggle the 16 bit unsigned integer pointed by *p from little endian to
 2  * big endian */
 3 void memrev16(void *p) {
 4     unsigned char *x = p, t;
 5 
 6     t = x[0];
 7     x[0] = x[1];
 8     x[1] = t;
 9 }
10 
11 /* Toggle the 32 bit unsigned integer pointed by *p from little endian to
12  * big endian */
13 void memrev32(void *p) {
14     unsigned char *x = p, t;
15 
16     t = x[0];
17     x[0] = x[3];
18     x[3] = t;
19     t = x[1];
20     x[1] = x[2];
21     x[2] = t;
22 }
23 
24 /* Toggle the 64 bit unsigned integer pointed by *p from little endian to
25  * big endian */
26 void memrev64(void *p) {
27     unsigned char *x = p, t;
28 
29     t = x[0];
30     x[0] = x[7];
31     x[7] = t;
32     t = x[1];
33     x[1] = x[6];
34     x[6] = t;
35     t = x[2];
36     x[2] = x[5];
37     x[5] = t;
38     t = x[3];
39     x[3] = x[4];
40     x[4] = t;
41 }
42 
43 #ifdef TESTMAIN
44 #include <stdio.h>
45 
46 int main(void) {
47     char buf[32];
48 
49     sprintf(buf,"ciaoroma");
50     memrev16(buf);
51     printf("%s\n", buf);
52 
53     sprintf(buf,"ciaoroma");
54     memrev32(buf);
55     printf("%s\n", buf);
56 
57     sprintf(buf,"ciaoroma");
58     memrev64(buf);
59     printf("%s\n", buf);
60 
61     return 0;
62 }
63 #endif
posted @ 2012-05-12 22:18  刘浩de技术博客  阅读(1165)  评论(0编辑  收藏  举报