++i 和 i++ 效率分析(C++)

简介: ++i 的效率比 i++ 的高

引言

++i 和 i++ 在多数情况下产生的结果都一样,但是它们的效率如何呢?

在C++中,它俩都用了运算符++的重载,这里执行效率上就有了些区别;


先说结论

++i 的效率比 i++ 的高,尤其在处理大量自定义类型的数据时会更明显;

—————————————————————————————————————


分析

++i 的实现简单说就是加1后返回结果就行了;

++的重载代码:

class Text;  

Text &Text::operator++()  

{  

   *this = *this + 1;  

   return *this;  

}  


i++ 多出来一步,因为它是先使用当前值后加1,所以需要一个临时的变量来存储原来的值;

++的重载代码:

class Text;  

const Text Text::operator ++(int)  

{  

   Text pre = *this;  

   *this = *this + 1;  

   return pre;

}

通过代码可以很轻易看出来i++多了一步,定义了一个新的变量存放原来的值;


总结

在实际编程中,

对于内置数据类型(如int,char,指针等),编译器会有优化,所以 ++i 和 i++没有太大区别;

而对于自定义的数据类型,就会有很大差别,C++中最典型的就是在STL中有关迭代器 iterator 的操作都是 ++i 的;


所以只要没有强制的要求,就使用 ++i,反正效率提一点算一点,就用最好的;

目录
相关文章
|
1月前
|
存储 Java 编译器
java和c++的主要区别、各自的优缺点分析、java跨平台的原理的深度解析
java和c++的主要区别、各自的优缺点分析、java跨平台的原理的深度解析
88 0
|
2月前
|
存储 自然语言处理 算法
【编译原理】LR(1)分析法:C/C++实现
【编译原理】LR(1)分析法:C/C++实现
67 0
|
29天前
|
算法 安全 大数据
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析(二)
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析
48 0
|
28天前
|
算法 Java C++
【C/C++ 内存知识扩展】内存不足的可能性分析
【C/C++ 内存知识扩展】内存不足的可能性分析
12 0
|
28天前
|
存储 监控 Linux
Linux 使用getrusage系统调用获取cpu信息:一个C++实例分析
Linux 使用getrusage系统调用获取cpu信息:一个C++实例分析
48 0
|
28天前
|
存储 算法 C语言
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
【C/C++ 链表结构】探索链表迭代器:C++实现的深入分析与优化策略
36 0
|
29天前
|
算法 安全 数据安全/隐私保护
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析(一)
【C/C++ 随机函数行为】深入探索C++中的随机数:std::random_device与rand的行为分析
46 0
|
1月前
|
存储 编译器 C++
嵌入式中C++ 编程习惯与编程要点分析
嵌入式中C++ 编程习惯与编程要点分析
18 1
|
1月前
|
架构师 数据挖掘 程序员
嵌入式系统中C++ 类的设计和实现分析
嵌入式系统中C++ 类的设计和实现分析
35 1
|
6月前
|
安全 C++ 开发者
C++ const分析
C++ const分析
26 0

热门文章

最新文章