整型定义,实型输出,运行错误!
- C/C++ code
#include <stdio.h>int main(void){ int a=5; printf("%f",a); return 0;}
WHY?
[解决办法]
gcc 运行结果
-0.000000
[解决办法]
崩溃的时候在弹出的对话框按相应按钮进入调试,按Alt+7键查看Call Stack里面从上到下列出的对应从里层到外层的函数调用历史。双击某一行可将光标定位到此次调用的源代码或汇编指令处。
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
提醒:
“学习用汇编语言写程序”
和
“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
不要写连自己也预测不了结果的代码!
[解决办法]
根据a的格式准备加载浮点处理函数库,但是不能判断a的浮点格式。
楼主为什么要这么用呢?
[解决办法]
"%f" 输出浮点数是 8 个字节的吧, 一个整数只有 4 个字节, printf 函数去读后面的 4 个字节的时候访问就越界了.
[解决办法]
我运行出R6002错误
MSDN上有:A format string for a printf or scanf function contained a floating-point format specification and the program did not contain any floating-point values or variables.
所以把代码改一下:
- C/C++ code
#include <stdio.h>int main(void){ int a=5; float b = a; printf("%f",a); return 0;}
[解决办法]
我运行出R6002错误
MSDN上有:A format string for a printf or scanf function contained a floating-point format specification and the program did not contain any floating-point values or variables.
所以把代码改一下:
- C/C++ code
#include <stdio.h>int main(void){ int a=5; float b = a; printf("%f",a); return 0;}
[解决办法]
float 不是4个字节吗? %lf double才是8个。
[解决办法]
[解决办法]
我二了,一直以为%f是float %lf是double
才发现在printf中%lf根本就是未定义的,亏我一直在用...
在printf中%f->double %Lf->long double