以下是c primer plus 5th 中的一个例子
#include <stdio.h>
int main(void)
{
float n1 = 3.0;
double n2 = 3.0;
long n3 = 2000000000;
long n4 = 1234567890;
printf("%ld %ld %ld %ld\n", n1, n2, n3, n4);
return 0;
}
输出结果:0 1074266112 0 1074266112
书上给出的分析是“printf()在堆栈中读取前4个字节作为它的第一个值。这就是n1的前半部分,下一个%ld读取n1的后半部分..”
而书上的另一个例子如下
#include <stdio.h>
#define PAGES 336
#define WORDS 65618
int main(void)
{
short num = PAGES;
short mnum = -PAGES;
printf("WORDS as int, short, and char: %d %hd %c\n", WORDS, WORDS, WORDS);
return 0;
}
输出结果:WORDS as int, short, and char: 65618 82 R
书上说“系统将65618存储为4字节的整数...”
对于值“82”书上解释说“当我们用%hd打印WORDS时,printf()只是用最后两个字节”
不解的是,printf()为什么一会取“前”一会取“后”?
谁能帮忙解释下!
----------------解决方案--------------------------------------------------------
这个就要涉及到微机原理(好像叫这个)了
所谓的前后就是地址的高位低位
你第二个例子里的最后2个字节,指的是低位2字节,应该和上面例子的“前”是相似的
----------------解决方案--------------------------------------------------------
这个东西麻烦,不要搞了,我想了好久,最后觉得没必要想了,只要不乱用输入输出类型就是了
这涉及在内存中的储存(不同的类型还有不同的字节数,储存的方式也不同)和转换(直接传送,从最低位开始)
----------------解决方案--------------------------------------------------------
printf() 函数从栈中取值时是依赖类型的尺寸,
收缩转换过程非常容易导致这样的结果,
拓宽转换(如 char 转 int)应该不会有样这问题。
printf() 所接受到的参数(可以多个)是以流方式存放,
它是尚未确定那几个字节应该分配给第一个参数的,
printf() 从字符串中获得控制字符,
当第一个读取到 %ld,便认为是以长整形输出,
是以从流中读取4字节,其后该参数流指针移动到4字节之后的位置。
在使用C的过程中你应该还会遇到一些情况体现出C这种以简单方式读取值的方式的例子,然而简单的好处是读取机制是单纯的。
[此贴子已经被作者于2007-3-13 23:08:45编辑过]
----------------解决方案--------------------------------------------------------