有一个地方不明白

dragonor 2005-02-23 04:48:09
#include<iostream>
void output(int x);
void output(float x);
void output(int x)
{
cout<<"output int "<<x<<endl;
}
void output(float x)
{
cout<<"output float"<<x<<endl;
}
void main(void)
{
int x=1;
int y=1.0;
output(x);
output(y);
output(1);
output(0.5);//这一句为什么会错呢?
output(int(0.5));
output(float (0.5));
}
...全文
124 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
yuzl32 2005-02-23
  • 打赏
  • 举报
回复
up
zengcity 2005-02-23
  • 打赏
  • 举报
回复
原来这样
dragonor 2005-02-23
  • 打赏
  • 举报
回复
I SEE.
io(王飞) 2005-02-23
  • 打赏
  • 举报
回复
0.5默认为double,不会向下转为float的
kobefly 2005-02-23
  • 打赏
  • 举报
回复
c++对类型的检查要求很严格

不像c那样

这样才能实现重载等等
寻开心 2005-02-23
  • 打赏
  • 举报
回复
output(0.5f )

缺省情况吓 0.5 这个常数,不是一个float类型,应该是double类型
可以转换成为int或者float类型
对程序来说,就存在二义性了。

64,643

社区成员

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

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