当前位置: 首页 > article >正文

C++取整函数ceil/floor/round的坑,你踩过几个?附赠一份避坑指南

C取整函数ceil/floor/round的坑你踩过几个附赠一份避坑指南在游戏物理引擎开发中我曾遇到过一个诡异的bug角色在特定角度碰撞墙壁时会被卡住。经过三天逐帧调试最终发现问题竟出在floor()函数对负数的处理上——这个教训让我意识到C取整函数远没有表面看起来那么简单。1. 负数取整的认知陷阱1.1 向上取整的反直觉行为多数开发者认为ceil(2.3)返回3是理所当然的但当参数为负数时cout ceil(-2.3); // 输出-2而非-3这是因为数学上的向上是向数轴正方向取整。在金融计算中这种特性可能导致利息计算错误double debt -1000.7; int rounded ceil(debt); // 得到-1000而非预期的-10011.2 floor()的对称性问题与ceil相反floor向负无穷方向取整cout floor(-3.7); // 正确输出-4 cout floor(3.7); // 输出3但在图形像素坐标计算时这种不对称性会导致坐标偏移vector2d pos {-3.7, 3.7}; int pixelX floor(pos.x); // -4 int pixelY floor(pos.y); // 3 // 实际需要的是对称舍入1.3 round函数的银行家舍入C11的round函数采用银行家舍入规则四舍六入五成双cout round(2.5); // 可能输出2取决于实现 cout round(3.5); // 可能输出4这种IEEE 754标准行为在统计计算中更精确但会令期待传统四舍五入的开发者困惑。2. 浮点数精度引发的幽灵问题2.1 看起来相等的数实际不等由于浮点表示限制理论上应返回整数的计算可能出现意外double d 0.1 0.2; // 实际≈0.30000000000000004 cout floor(d * 10); // 期望3实际可能输出22.2 解决方案epsilon比较法bool nearlyEqual(double a, double b, double epsilon 1e-10) { return abs(a - b) epsilon; } double value 0.1 0.2; if(nearlyEqual(value, 0.3)) { cout floor(value * 10); // 现在安全了 }2.3 平台相关的精度差异不同编译器对80位扩展精度的处理不同编译器默认浮点模型round(2.5)结果GCC80-bit2MSVC64-bit3Clang依架构而定可能为23. 与类型转换的致命混淆3.1 隐式转换的截断行为double d 3.9; int i d; // 截断为3相当于floor正数部分这种静默转换在模板代码中尤为危险templatetypename T T process(T value) { return T(value * 0.5); // 当T为int时丢失小数 }3.2 显式转换的四种方式对比方法示例等价数学运算C风格转换(int)3.7floor(正数)static_caststatic_cast(-2.9)truncC11风格转换int{3.7}编译错误函数式转换int(3.7)trunc提示在需要明确取整行为的场景始终优先使用标准库函数而非类型转换4. 实战避坑指南4.1 游戏开发中的坐标处理正确处理精灵位置到像素坐标的转换struct PixelPos { int x, y; static PixelPos fromWorldPos(double wx, double wy) { return { static_castint(floor(wx 0.5)), // 传统四舍五入 static_castint(floor(wy 0.5)) }; } };4.2 金融计算的精确舍入方案#include cfenv #pragma STDC FENV_ACCESS ON double bankerRound(double value) { int oldMode fegetround(); fesetround(FE_TONEAREST); double result rint(value); fesetround(oldMode); return result; }4.3 跨平台一致性保障// 确保所有平台使用相同浮点模型 #ifdef __GNUC__ #pragma GCC optimize(strict-float) #endif // 使用C17的数学特殊函数 #include cmath constexpr double eps 1e-9; int safeFloor(double x) { return static_castint(floor(x eps)); }5. 保留小数位的正确姿势5.1 printf与iostream对比需求printf方案iostream方案固定2位小数%.2fsetprecision(2) fixed科学计数法3位小数%.3escientific setprecision(3)自适应格式无defaultfloat5.2 精确控制输出流#include iomanip #include sstream string formatCurrency(double value) { stringstream ss; ss fixed setprecision(2); if(value 0) ss $; else ss ($ -value ); return ss.str(); }在实时交易系统中我们最终采用了自定义的Decimal类替代浮点数核心思路是将金额存储为整数分单位。这彻底规避了浮点取整问题但需要重载所有数学运算符——这是另一个值得展开的话题了。

相关文章:

C++取整函数ceil/floor/round的坑,你踩过几个?附赠一份避坑指南

C取整函数ceil/floor/round的坑,你踩过几个?附赠一份避坑指南 在游戏物理引擎开发中,我曾遇到过一个诡异的bug:角色在特定角度碰撞墙壁时会被卡住。经过三天逐帧调试,最终发现问题竟出在floor()函数对负数的处理上——…...

告别鼠标手!用你的旧Android手机做个无线触控板(Android 9+ BluetoothHidDevice实战)

旧手机秒变无线触控板:Android蓝牙HID开发实战指南 你是否经常因为长时间使用鼠标而感到手腕酸痛?办公室里那台老旧的触控板反应迟钝得让人抓狂?或许你从未想过,抽屉里那台闲置的Android手机,只需几行代码就能变身为精…...

一键下载30+文档平台!最强免费文档下载工具完全指南

一键下载30文档平台!最强免费文档下载工具完全指南 【免费下载链接】kill-doc 看到经常有小伙伴们需要下载一些免费文档,但是相关网站浏览体验不好各种广告,各种登录验证,需要很多步骤才能下载文档,该脚本就是为了解决…...

FLIP DOP —— 从粒子到体积的流体动力学解算核心

1. FLIP流体模拟的核心原理 FLIP(Fluid Implicit Particle)是一种混合粒子与网格的流体模拟方法,它结合了粒子法和欧拉法的优势。我最早接触FLIP是在制作影视级流体特效时,当时被它既能处理剧烈飞溅又能保持稳定性的特点所吸引。 …...

全志 D1s/F133 移植 LVGL 实战:从 T113 源码到 RISC-V 平台的驱动适配与部署

1. 从ARM到RISC-V:为什么要移植LVGL? 最近在折腾全志D1s/F133开发板的朋友可能都遇到过这个问题:网上大部分LVGL例程都是基于ARM架构的T113平台写的,但D1s搭载的是RISC-V内核。这就好比你想在MacBook上运行Windows软件&#xff0c…...

3大核心技巧解锁Office生产力:用Custom UI Editor重塑你的工作界面

3大核心技巧解锁Office生产力:用Custom UI Editor重塑你的工作界面 【免费下载链接】office-custom-ui-editor Standalone tool to edit custom UI part of Office open document file format 项目地址: https://gitcode.com/gh_mirrors/of/office-custom-ui-edit…...

“农机云”平台Docker安全加固白皮书:通过CIS Docker Benchmark 1.4.0认证的11项强制配置(附自动化check脚本)

第一章:农机云平台Docker安全加固白皮书概述农机云平台作为面向农业智能化的核心基础设施,其容器化部署广泛依赖 Docker 引擎承载边缘计算节点、农机调度服务、遥感数据处理微服务等关键组件。本白皮书聚焦于生产环境中 Docker 运行时与镜像生命周期的安…...

百度网盘解析工具完整实战教程:告别限速困扰的终极解决方案

百度网盘解析工具完整实战教程:告别限速困扰的终极解决方案 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的下载地址 项目地址: https://gitcode.com/gh_mirrors/ba/baidu-wangpan-parse 还在为百度网盘那蜗牛般的下载速度而烦恼吗&#xff1f…...

终极免费方案:PotPlayer智能字幕翻译插件完整使用指南

终极免费方案:PotPlayer智能字幕翻译插件完整使用指南 【免费下载链接】PotPlayer_Subtitle_Translate_Baidu PotPlayer 字幕在线翻译插件 - 百度平台 项目地址: https://gitcode.com/gh_mirrors/po/PotPlayer_Subtitle_Translate_Baidu 想要在看外语电影、纪…...

YOLOv5 训练后模型调优与性能提升实战:从TensorBoard分析到超参数调整

YOLOv5模型调优实战:从TensorBoard诊断到超参数优化 当你的YOLOv5模型完成初步训练后,真正的挑战才刚刚开始。面对TensorBoard中错综复杂的曲线,很多开发者往往陷入困惑——这些波动意味着什么?为什么验证集mAP突然下降&#xff1…...

每天30块,国家给兜底———一个关于“饿不死”的制度设想

这个想法很简单国家每天给每个中国人发30块钱。不是现金。是手机里的一种“数字券”。只能买四样东西:吃的、穿的、基础药、便宜手机。今天不用,今晚12点清零。明天醒来,新的30块自动到账。但是——如果他今天打工挣的钱超过了全国平均数&…...

别再死记公式了!用Python手把手带你算卷积层参数量和计算量(附代码)

用Python动态计算卷积层参数量与计算量的工程实践 在深度学习模型设计与调优过程中,准确估算卷积层的参数量和计算量是每个工程师必备的核心技能。传统教学往往停留在公式记忆层面,导致许多开发者在面对实际工程问题时仍感到无从下手。本文将彻底改变这…...

MySQL中如何利用SIGN函数判断符号_MySQL符号函数用法

...

LM惊艳效果展示:LM_20.safetensors生成的写实人像与未来感服装作品

LM惊艳效果展示:LM_20.safetensors生成的写实人像与未来感服装作品 1. 效果概览 LM_20.safetensors作为LM系列的最新checkpoint,在写实人像和未来感服装生成方面展现出惊人的表现力。这个基于Tongyi-MAI/Z-Image底座的文生图模型,能够将简单…...

ComfyUI Manager完全指南:5个步骤轻松管理你的AI绘画插件

ComfyUI Manager完全指南:5个步骤轻松管理你的AI绘画插件 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various cu…...

5分钟掌握QMC音乐解密:终极跨平台音频格式转换指南

5分钟掌握QMC音乐解密:终极跨平台音频格式转换指南 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾为QQ音乐下载的加密格式无法在其他播放器中使用而烦…...

【C++Debug日记】VS Code SSH连接失败:Resolver error深度排查与修复实录

1. 当VS Code遇上SSH连接故障:从报错到解决的全过程 那天早上我像往常一样打开VS Code,准备通过Remote-SSH连接到远程服务器继续我的C项目开发。但这次迎接我的不是熟悉的远程环境,而是一个刺眼的错误提示:"Resolver error: …...

用STM32的3个GPIO口扩展8路ADC输入?试试74HC4051模拟开关的实战配置

用STM32的3个GPIO口扩展8路ADC输入?74HC4051模拟开关实战指南 在嵌入式开发中,ADC通道不足是个常见痛点。想象一下这样的场景:你的STM32项目需要同时采集8路温度传感器数据,但手头的MCU只有1-2个ADC通道。直接换芯片成本高&#…...

【Apache Doris】Java UDF 实战:从开发到部署的性能调优指南

1. Java UDF在Apache Doris中的核心价值 第一次接触Apache Doris的Java UDF功能时,我正面临一个典型的生产难题:需要将Hive中的几十个业务关键UDF迁移到Doris环境。传统C UDF的编译部署过程让我头疼不已,直到发现Java UDF这个"救星"…...

告别手动protoc!用Maven插件一键编译.proto文件到Java代码(附gRPC配置)

告别手动protoc!用Maven插件一键编译.proto文件到Java代码(附gRPC配置) 在微服务架构盛行的今天,Protocol Buffers(Protobuf)因其高效的序列化性能和跨语言支持,已成为接口定义的事实标准。然而…...

Y形动态Transformer:解码红外与可见光图像融合的全局与局部协同之道

1. 当红外遇见可见光:为什么我们需要图像融合? 想象一下,你正在夜间驾驶,车载摄像头捕捉到的红外图像能清晰显示行人轮廓却丢失了环境细节,而可见光图像恰好相反——这就是多模态图像融合要解决的核心问题。在安防监控…...

国产车灯改装品牌排行榜,我用了半年很满意

很多车主问我:“国产车灯改装品牌到底怎么选?”、“车灯不够亮怎么升级才不踩坑?”、“激光大灯什么牌子好,LED大灯和激光大灯怎么选?”——这些问题背后,折射出一个现实:市面上品牌太多&#x…...

每日热门skill:让你的AI告别被动等待:AgentAutonomyKit实现智能体自主工作

当Claude Max每月给你几十万token额度,你的AI却每天只用了不到20%——不是它不够聪明,是它一直在等你"喂饭"。 这个Skill,让你的AI从"等指令"变成"自己找事干"。 文末有下载链接。 一、问题:你的AI正在大规模浪费资源 先问自己一个问题: …...

从0到1构建Multi-Agent客服系统:LangGraph完整指南

从0到1构建Multi-Agent智能客服系统:LangGraph完整指南 副标题:多轮对话/工具调用/状态管理/性能优化一站式实战教程,附百万级语料向量检索与微调小助手方案 第一部分:引言与基础 (Introduction & Foundation) 1.1 引人注目的标题拆解与价值锚定 各位前端、后端、AI…...

英文降AI工具测评:实测解决Turnitin 99%高AI率

为什么同样写出来的英文长文初稿,有的人扔进 Turnitin 检测后 AI 率高达 98%,有的人经过润色后却能稳定保持在 15% 以下? 大家第一反应可能是模型抽风了,或者提示词没写好。其实吧,说到底还是底层逻辑没对齐。 很多小…...

终极RDP Wrapper完整指南:免费解锁Windows远程桌面多用户连接

终极RDP Wrapper完整指南:免费解锁Windows远程桌面多用户连接 【免费下载链接】rdpwrap RDP Wrapper Library 项目地址: https://gitcode.com/gh_mirrors/rd/rdpwrap RDP Wrapper Library是一个革命性的开源解决方案,让你能够在任意Windows版本上…...

nli-MiniLM2-L6-H768开发者案例:为LangChain添加NLI验证节点

nli-MiniLM2-L6-H768开发者案例:为LangChain添加NLI验证节点 1. 项目概述 nli-MiniLM2-L6-H768是一个基于自然语言推理(NLI)的轻量级模型,专门用于判断两个句子之间的逻辑关系。这个630MB的精简模型在保持较高准确率的同时,特别适合需要快速…...

CAN总线调试太头疼?试试用MCP2515的环回模式与监听模式(实战技巧)

CAN总线调试实战:MCP2515环回与监听模式的高级应用技巧 调试CAN总线通信就像在嘈杂的派对中试图听清某个人的对话——背景噪音、多人同时说话、信号干扰等问题让整个过程充满挑战。MCP2515作为独立CAN控制器,其环回模式和监听模式就像给工程师装上了&quo…...

3大系统平台实战:跨平台工具部署完全指南

3大系统平台实战:跨平台工具部署完全指南 【免费下载链接】AssetRipper GUI Application to work with engine assets, asset bundles, and serialized files 项目地址: https://gitcode.com/GitHub_Trending/as/AssetRipper 让我们探索一个技术开发者和系统…...

RTS必备系统!Unity高性能战争迷雾技术揭秘(Compute Shader版)

在实时战略(RTS)游戏中,“战争迷雾”(Fog of War)几乎是标配机制。从《星际争霸》到《魔兽争霸》,这一系统不仅增强了策略深度,还极大提升了游戏的探索性与信息博弈体验。本文将围绕 Fog Of War…...