如图,不管char还是int还是其他数组或者string等等的,它们的值在内存中都是由
一个个bit组成的
假如char ch = “a”;然后我要读取它的内存由101010形式输出,
可能有人会说int i =ch;然后转成二进制就行了,但是我现在不要用这种方式,因为有时候char的范围在-128~127有时候在0~256,所以我想直接读取内存更加准确直观。
然后另外一个问题是怎么获取char的ANSI码 和 wchar_t 的Unicode码
如图,不管char还是int还是其他数组或者string等等的,它们的值在内存中都是由
一个个bit组成的
假如char ch = “a”;然后我要读取它的内存由101010形式输出,
可能有人会说int i =ch;然后转成二进制就行了,但是我现在不要用这种方式,因为有时候char的范围在-128~127有时候在0~256,所以我想直接读取内存更加准确直观。
然后另外一个问题是怎么获取char的ANSI码 和 wchar_t 的Unicode码
目的就是为了获得内存地址,然后通过内存地址获得数据,对吗?
首先:你的做法需要计算机位宽问题.
int i = ch是错误的。
我提供Linux X64的例子供参考:
#include
int
main(void)
{
char ch = 'a';
long addr = (long)&ch;
printf("ch addr == %ld\n",addr);
printf("addr's data == %c\n",(char)*(long*)addr);
return 0;
}
结果:
ch addr == 140734165139623
addr's data == a
另外:
char本来就是ANSI码,如果说是字符显示,则参考ANSI表。
Unicode编码,印象中wchar_t默认的,如果是转utf-8什么的,就要参考一下转换规则。