在很多时候,有人会有这样的疑问
——为什么要用C++?C++相对于C优势是什么?
最近两年一直在做Linux应用,能明显的感受到C++带来到帮助以及快感
之前,我在文章里面提到环形队列
C语言,环形队列
环形队列到底是怎么回事?
用C实现到环形队列,是考验一个工程师的能力,但是到实际项目后,你还需要花时间在设计这些基础的东西,就会显得时间非常紧张。
在C++里面,很容易就可以给你搞一个Queue给你使用
如下
当然,除了使用Queue,你还有很多存储数据的数据结构选择
——使用std::list:
如果你需要在队列中间插入或删除元素,那么可以考虑使用std::list。std::list是一个双向链表,它可以方便地在任意位置插入或删除元素。然而,它的内存开销较大,且不支持随机访问。
——使用数组或std::vector:
如果你需要一个固定大小的队列,那么可以考虑使用数组或std::vector实现。这种实现方式具有较好的内存连续性,有助于提高缓存命中率。然而,如果队列需要动态调整大小,这种实现方式可能会导致额外的内存复制开销。
——使用环形缓冲区:
环形缓冲区是一种特殊类型的队列,它的头部和尾部是相互连接的。这种实现方式适用于数据流的读写操作,因为它可以无缝地处理缓冲区的溢出情况。实现环形缓冲区可以使用数组或std::vector作为底层存储结构。
——使用并发队列:
如果你需要在多线程环境中使用队列,那么可以考虑使用并发队列。C++标准库中的std::queue并不是线程安全的,但你可以使用第三方库,如Intel TBB或Microsoft PPL,或者使用C++11的std::mutex(锁)和std::condition_variable来实现自己的线程安全队列。
——
做项目和研究东西是两回事,就好比开车,短距离开车没有自动驾驶感觉没问题,很多时候还觉得挺爽,但是如果把距离拉长,项目复杂度提高,没有自动驾驶能把人搞废掉。
而C++就好比一辆有ACC功能的汽车,他能满足你的大项目复杂度需求,不需要再去造一些重复的轮子。
并且,你可以大胆的相信std给你提供的东西。
当然了,至于那些遇到的很难解决解释的bug问题,我们这里就不讨论了,只能说明自动驾驶存在的某些bug。