我知道hash_set是非标准的,而unordered_set是标准的。但是,我想知道,性能方面,两者之间有什么区别?为什么要分开存在? 最佳答案 C++标准规定的unordered_容器的复杂性要求基本上没有为实现留下太多空间,它必须是某种哈希表。该标准是在充分意识到大多数供应商已经将这些数据结构作为扩展部署的情况下编写的。编译器供应商通常将这些容器称为“HashMap”或“哈希集”,这可能是您所指的(标准中没有文字std::hash_set,但是我认为GCC在单独的命名空间中有一个,对于其他编译器也是如此)。编写新标准时,作者希
我知道hash_set是非标准的,而unordered_set是标准的。但是,我想知道,性能方面,两者之间有什么区别?为什么要分开存在? 最佳答案 C++标准规定的unordered_容器的复杂性要求基本上没有为实现留下太多空间,它必须是某种哈希表。该标准是在充分意识到大多数供应商已经将这些数据结构作为扩展部署的情况下编写的。编译器供应商通常将这些容器称为“HashMap”或“哈希集”,这可能是您所指的(标准中没有文字std::hash_set,但是我认为GCC在单独的命名空间中有一个,对于其他编译器也是如此)。编写新标准时,作者希
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter寻求指导。关闭10年前.我愿意从并发中学习更多,我发现这本书有很多好评。但是看了前言,怕是很关注C++11才有的STD函数。由于C++11还不是很常用,而且在我的工作场所根本没有,我需要知道在我应该阅读另一本书时阅读这本书是否会浪费时间。我专注于Windows开发,但我喜欢在UNIX和Windows中使用标准库。对这本书有什么建议或说明吗? 最佳
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter寻求指导。关闭10年前.我愿意从并发中学习更多,我发现这本书有很多好评。但是看了前言,怕是很关注C++11才有的STD函数。由于C++11还不是很常用,而且在我的工作场所根本没有,我需要知道在我应该阅读另一本书时阅读这本书是否会浪费时间。我专注于Windows开发,但我喜欢在UNIX和Windows中使用标准库。对这本书有什么建议或说明吗? 最佳
这个问题在这里已经有了答案:Deletingelementsfromstd::setwhileiterating(8个回答)关闭3年前。有人可以帮我吗?编译这段代码:voidtest(){std::settest;test.insert(42);test.erase(std::remove(test.begin(),test.end(),30),test.end());//编译时出现如下错误:$makeg++-c-Wall-pedantic-errors-Wextra-Wunused-Werrora_star.cpp/usr/lib/gcc/i686-pc-cygwin/4.3.4/i
这个问题在这里已经有了答案:Deletingelementsfromstd::setwhileiterating(8个回答)关闭3年前。有人可以帮我吗?编译这段代码:voidtest(){std::settest;test.insert(42);test.erase(std::remove(test.begin(),test.end(),30),test.end());//编译时出现如下错误:$makeg++-c-Wall-pedantic-errors-Wextra-Wunused-Werrora_star.cpp/usr/lib/gcc/i686-pc-cygwin/4.3.4/i
我对std::promise::set_value()上的线程安全要求有点困惑。standardsays:Effects:Atomicallystoresthevaluerinthesharedstateandmakesthatstateready但是,它也说promise::set_value()只能用于设置一次值。如果多次调用,则会抛出std::future_error。所以你只能设置一次Promise的值。事实上,std::promise的几乎每个教程、在线代码示例或实际用例都涉及2个线程之间的通信channel,其中一个线程调用std::future::get(),其他线程调用
我对std::promise::set_value()上的线程安全要求有点困惑。standardsays:Effects:Atomicallystoresthevaluerinthesharedstateandmakesthatstateready但是,它也说promise::set_value()只能用于设置一次值。如果多次调用,则会抛出std::future_error。所以你只能设置一次Promise的值。事实上,std::promise的几乎每个教程、在线代码示例或实际用例都涉及2个线程之间的通信channel,其中一个线程调用std::future::get(),其他线程调用
我们将很快升级到VS2015,我在重大更改列表中找到了这个:constelementsTheC++standardhasalwaysforbiddencontainersofconstelements(suchasvectororset).VisualC++2013andearlieracceptedsuchcontainers.Inthecurrentversion,suchcontainersfailtocompile.source我想知道是否有人知道这是否也适用于集合。我知道映射仍然可以包含const指针作为键,因为它们无论如何都是const。一个例子:std::set我还能这样
我们将很快升级到VS2015,我在重大更改列表中找到了这个:constelementsTheC++standardhasalwaysforbiddencontainersofconstelements(suchasvectororset).VisualC++2013andearlieracceptedsuchcontainers.Inthecurrentversion,suchcontainersfailtocompile.source我想知道是否有人知道这是否也适用于集合。我知道映射仍然可以包含const指针作为键,因为它们无论如何都是const。一个例子:std::set我还能这样