选择性地禁用选中的迭代器
Selectively disabling checked iterators
我正在编写一个相当复杂的应用程序,它大量使用STL容器。该应用程序有一个相对简单、对性能敏感的单独部分,它在多个std::map
上迭代,并被执行数千次。测试表明,在禁用检查迭代器(_SECURE_SCL
设置为0)的情况下进行编译会使整个程序的速度提高近2倍,这完全集中在本节中。
但是,我无法在_SECURE_SCL
设置为0的情况下编译应用程序,因为需要与启用_SECURE_SCL
的库链接,并且混合使用_SECURE_SCL
设置会导致问题。此外,我发现在整个应用程序中使用未检查的迭代器是相当愚蠢的,因为所有性能敏感的位都发生在一个满屏幕的代码中。这无异于把婴儿连同洗澡水一起倒掉。
对于性能敏感的代码/容器,在保持与使用已检查迭代器编译的库的兼容性的同时,我有哪些选项可以选择性地使用未检查的迭代器?
正如您已经发现的,您不能混合使用已检查/未检查迭代器的代码,因此为了在代码的一部分中使用它,您需要为该部分提供一个不需要传递任何容器和迭代程序的接口。(请注意,这扩展到std::string
。)
当然,您必须将该代码放入自己的可执行文件(DLL)中。当然,这需要在API上没有太多的来回调用。
为了安全起见,我甚至会考虑将该部分放入带有C接口的DLL中。
这对我有效:
vector<BYTE> v;
vector<BYTE>::iterator i;
vector<BYTE>::iterator::_Unchecked_type ui;
i = v.end();
ui = i._Unchecked();
ui++;
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 如何在c++迭代器类型中包装std::chrono
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 对于set上的循环-获取next元素迭代器
- 为什么output_editor Concept不需要output_e迭代器标记
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器
- 不明白迭代器,引用和指针失效,一个例子
- 我可以使用反向迭代器作为ForwardIt吗
- ESP8266单片机矢量迭代器的C++问题
- 如何在C++中将迭代器作为函数参数传递
- 是否应避免从非常量迭代器转换为常量迭代器?
- 如何在 c++ 中将字符串迭代器变量传递给函数?
- 为什么 vector 的随机访问迭代器给出与指针不同的内存地址?
- 选择性地禁用选中的迭代器