c++中,超过31bit位的小数转换成int出现错误怎么解决,求大神解决

哈哈leilei 2018-09-17 02:35:43
double aa = (210554060.75-0)/0.05;
qDebug()<<"aa:"<<aa<<endl;
int bb = round(aa);//四舍五入小数部分
qDebug()<<"bb:"<<bb<<endl;
QString key = QString::number(a, 16).toUpper();//变成16进制字符串
qDebug()<<key<<endl;

1.这里第一行表示double aa = (a-b)/c,这是一个固定的计算公式;
2.第二行int bb = round(aa)出现错误,当整数bb是超过31bit位的数字时,所有的数字bb都变成了负数-2147483648 ,转换成16进制字符串都是FFFFFFFF80000000;31位bit位及以下的数字时并不会发生错误;
3.如何解决错误,上述代码正确答案应该是FAFFFFFF
...全文
972 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
哈哈leilei 2018-09-17
  • 打赏
  • 举报
回复
哇,太感谢了
kbasm 2018-09-17
  • 打赏
  • 举报
回复
用int64_t

64,662

社区成员

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

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