打印有符号和无符号char的区别

写了这样一段代码,想要将数据按字节打印。(小端机器)

 #include <stdio.h>

typedef char * byte_pointer;

void show_bytes(byte_pointer data, int len)
{
    int i = 0;
    for (i=0; i<len; ++i)
    {
        printf("0x%.2x ", data[i]);
    }
    printf("\n");
}

void main()
{
    int x = -2;
    show_bytes((byte_pointer)&x, sizeof(int));
    int xx = x>>2;
    show_bytes((byte_pointer)&xx, sizeof(int));
    return;
}

打印结果为:
luocanwei@luocanwei-Aspire-5750G:~/computer systems$ ./test
0xfffffffe 0xffffffff 0xffffffff 0xffffffff
0xffffffff 0xffffffff 0xffffffff 0xffffffff

这不是我想要的,改为

typedef unsigned char * byte_pointer;

才是我要的结果:
luocanwei@luocanwei-Aspire-5750G:~/computer systems$ ./test
0xfe 0xff 0xff 0xff
0xff 0xff 0xff 0xff

到底打印单字节有符号的char时,为什么会出现打印成32位数据;而如果是无符号则不会?难道声明为无符号打印,打印“%x”也是无符号?求指导,谢谢。

%x 其实接收的是 unsigned int,4字节。所以用 char/unsigned char 会有类型提升的问题,有符号的 0xff 提升为 0xffffffff、0xfe 提升为 0xfffffffe,无符号的 0xff 提升为 0x000000ff、0xfe 提升为 0x000000fe。

有符号数右移,高位补1,无符号数补0。
关键是>>2