重新定义数据区域以便更快地访问
Redefine data area for faster access
c++新功能。我搜索过,但可能用错了词。
我想找到在许多槽的数组中哪个槽存储了几个字节长的文字值。当前按顺序检查每个槽位
如果我可以使用一个内部函数来扫描整个数组,就好像它是一个大字符串一样,我觉得这会快得多。(老COBOL程序员).
我能帮你吗?
我想找到在许多槽的数组中哪个槽存储了几个字节长的文字值。当前按顺序检查每个槽位
好的,我要赌一把,推断出:
-
你想在某种容器中存储任意长度的字符串。
-
容器必须是可变的(即你可以随意添加字面量)
-
你想知道一个字符串字量之前是否存储在容器中,以及它在什么"位置",以便你可以在必要时删除它。
-
字符串字面值将按随机字典顺序插入,不需要排序。
首先想到的容器是std::unordered_set
#include <unordered_set>
std::unordered_set<std::string> tokens;
int main()
{
tokens.emplace("foo");
tokens.emplace("bar");
auto it = tokens.find("baz");
assert(it == tokens.end()); // not found
it = tokens.find("bar"); // will be found
assert(it != tokens.end());
tokens.erase(it); // remove the token
}
该容器的搜索时间复杂度为0(1)。
正如你已经从注释中发现的那样,"作为一个大字符串扫描"不是c++的方式。
当使用C风格的数组时,c++中典型的
对于线性搜索来说通常足够快auto myStr = "result";
auto it = std::find_if(std::begin(arr), std::end(arr),
[myStr](const char* const str) { return std::strcmp(mystr,str) == 0; });
请记住,字符串比较函数在第一个错误字符处停止。
更多c++风格:
std::vector<std::string> vec = { "res1", "res2", "res3" };
std::string myStr = "res2";
auto it = std::find(vec.begin(), vec.end(), myStr);
如果您对大型容器的快速查找感兴趣,那么std::unordered_set
是可行的,但是"槽"已经失去了它的意义,但也许在这种情况下可以使用std::unordered_map
。
std::unordered_set<std::string> s= { "res1", "res2", "res3" };
std::string myStr = "res2";
auto it = s.find(myStr);
所有代码都是作为示例编写的,没有编译/测试
相关文章:
- 通过方法访问结构
- 使用不带参数的函数访问结构元素
- 如果我只是不访问queue_front节点的子节点,而是将它们推到队列中呢?还是BFS吗
- 用于访问容器<T>数据成员的正确 API
- 访问者访问变体并返回不同类型时出错
- 尝试通过多个向量访问变量时,向量下标超出范围
- 无法访问嵌套类.类的使用无效
- 写入位置0x0000000C时发生访问冲突
- 我们可以访问一个不存在的联盟的成员吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 我的简单if-else语句是如何无法访问的代码
- 从C++dll访问C#中的一行主要参数
- 概念TS检查忽略私有访问修饰符
- 访问被拒绝后,c++中的故障保护代码
- 在c++中访问int到类对象的映射时出错
- 创建一个类来访问和指定向量类型,并构建一个获取位置并为其分配区域的类
- 指针可以用于访问内存中的任何任意区域吗?
- 无法正确访问在另一个类的私人区域内声明的类
- 重新定义数据区域以便更快地访问
- 如何在c++中访问区域设置和全局设置