c++编译优化,arm优化

本文介绍了C++性能优化的几点建议,包括使用指针数组替代STL vector以提高效率,利用引用减少对象拷贝,以及编译时添加-O3和-DNDEBUG选项。此外,针对ARM处理器,如Cortex-A7,可以使用特定的编译参数如-mcpu=cortex-a7、-mfpu=vfpv4-d16和-ffast-math来提升程序运行速度,其中-ffast-math可带来约10%的性能提升。但需要注意,某些选项如-mfloat-abi=softfp可能导致编译错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1,C++里面STL自带的vector存取效率不高,在可能的情况下用指针数组代替会大幅提高性能。
2,C++中对象的传递,尽可能使用引用,避免无意义的对象拷贝过程。
3,编译的时候加上 -O3, -DNDEBUG 这两个参数优化选项,可以提高编译出来的程序运行速度。
4,针对多核心的处理器,可以加上openMP,进行多线程处理。尤其对于循环的加速效果很明显!

如果是arm,还有下面的参数可以优化:

arm-gcc -O3 -mcpu=cortex-a7 -mfpu=vfpv4-d16 -mfloat-abi=softfp -ffast-math -omyprog2.exe myprog2.c

备注:可以把arm-gcc改为gcc 

-mfloat-abi=softfp可以独立去掉

-mcpu=cortex-a7 -ffast-math 这个性能提升了约10%。

-mfpu=vfpv4-d16这个加上,-mfpu=neon就无效了。

-mfloat-abi=softfp,这个加上后,会报 fatal error: bits/c++config no such file 异常。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

AI算法网奇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值