【C/C++】long long 类型传参推荐方式

在 C++ 中,对于 long long 类型的函数入参,选择 long long val 还是 const long long& val,主要取决于参数的大小是否需要避免复制开销

一句话总结:

对于内置类型如 long long直接传值(long long val)效率通常更高或至少一样好,推荐使用传值方式。


原因分析:

参数类型 开销 说明
long long val 直接值传递,拷贝 8 字节 编译器会将其压入寄存器(如 x64 架构中使用寄存器传参),效率高,调用代码清晰。
const long long& val 传递引用(实际上是一个指针),加一次间接访问 虽然避免了拷贝,但增加了一次指针解引用操作,可能会引起缓存命中率下降。

什么时候使用 const long long&

  • 当参数是大型对象 (例如:std::string, std::vector, 自定义类等),为了避免拷贝开销。
  • 当你希望保持函数签名一致性(例如模板中统一使用引用传递)。
  • 当你明确要保持引用语义时(例如用于调试、或借助引用避免拷贝构造/移动构造等情况)。

实际建议:

参数类型 推荐传参方式
内置类型(如 int, long long, double 等) 传值
大型对象或资源类(如 std::string, std::vector, 自定义类) const T&

举例:

cpp 复制代码
// 推荐写法:
void process(long long val); // ✅

void process(const long long& val); // ⛔️ 通常没必要

编译器优化提示:

现代编译器(如 GCC、Clang、MSVC)会对小对象传值做大量优化,例如传寄存器而不是内存指针,避免不必要的间接访问。对于 64-bit 架构,long long 正好是 8 字节,不会有性能瓶颈。


总结:

✅ 对于 long long,使用 long long val 是更自然、高效的选择。使用 const long long& 没有性能优势,反而可能引入微小的间接访问开销。

相关推荐
隐退山林21 小时前
JavaEE:多线程初阶(一)
java·开发语言·jvm
C_心欲无痕21 小时前
ts - 模板字面量类型与 `keyof` 的魔法组合:`keyof T & `on${string}`使用
linux·运维·开发语言·前端·ubuntu·typescript
fy zs21 小时前
网络编程套接字
linux·服务器·网络·c++
最贪吃的虎21 小时前
Redis其实并不是线程安全的
java·开发语言·数据库·redis·后端·缓存·lua
fpcc21 小时前
模板编程—模板和元编程中的错误输出
c++·模板编程
乾元21 小时前
无线定位与链路质量预测——从“知道你在哪”,到“提前知道你会不会掉线”的网络服务化实践
运维·开发语言·人工智能·网络协议·重构·信息与通信
xie_pin_an21 小时前
C++ 类和对象全解析:从基础语法到高级特性
java·jvm·c++
AC赳赳老秦21 小时前
Unity游戏开发实战指南:核心逻辑与场景构建详解
开发语言·spring boot·爬虫·搜索引擎·全文检索·lucene·deepseek
小温冲冲21 小时前
C++与QML信号绑定完全指南:实现跨语言无缝通信
c++
SunnyDays101121 小时前
如何使用 JAVA 将 PDF 转换为 PPT:完整指南
java·开发语言·pdf转ppt