非常无语的一个问题,高手进

yndfcd 2007-08-04 05:47:41
float v = V[0].v = 0;
DP( "<%0.2f,%0.2f>, %0.2f\n",
V[0].u, V[0].v, v);
都快无语了。上面的代码打印的结果如下:
<0.00,-92559616635676998000000000000000000000000000000000000000000000.00>, -92559631349317831000000000000000000000000000000000000000000000.00
...全文
251 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
skyscribe 2007-08-04
  • 打赏
  • 举报
回复
hapluo说得很对啊!
还有就是关于浮点数的赋值,不要简单得赋值为0,可参考 林锐博士的《高质量C/C++编程指南》
printf的输出结果取决于程序员准确理解输入的参数含义!
tiantang3gm 2007-08-04
  • 打赏
  • 举报
回复
这个时候还是要看C++的输入输出流了
tiantang3gm 2007-08-04
  • 打赏
  • 举报
回复
Hapluo 很有见解.
学习.
laoluo 2007-08-04
  • 打赏
  • 举报
回复
float ut;
double v;
double w;
printf("%.2f,\n%.2f,\n%.2f\n", ut, v, w );

测试输出正常

int ut;
double v;
double w;
printf("%.2f,\n%.2f,\n%.2f\n", ut, v, w );

结果输出错误

分析原因为:函数参数从右往左压栈,函数处理的时候弹栈
而printf 输出时,根本不检查后面的参数类型和个数,完全按照“”中定义的格式输出,所以
输出第一个%.2f实际上利用了ut和v的一部分内容进行了输出,而后就会一直错



iambic 2007-08-04
  • 打赏
  • 举报
回复
你不是在搞高精度数值吧?怎么这么长。
laoluo 2007-08-04
  • 打赏
  • 举报
回复
你的V[0].u 的类型不是 float或double吧?
注意,类似于printf string.Format 的参数列表是没有强类型检查的,
MPTD_Fire 2007-08-04
  • 打赏
  • 举报
回复
学习下,不懂这些
jixingzhong 2007-08-04
  • 打赏
  • 举报
回复
V[0].v 是double 类型吧 ...

输出中,
类型控制是很严格的,
而且存在连锁反应,
V[0].v 的类型不正确,
会影响到后面的 v 的输出 ...
gfxiang 2007-08-04
  • 打赏
  • 举报
回复
代码不全,没法诊断

64,683

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧