草庐IT

c++ - set::vector 初始化用数字引号

所以我想到了一个关于std::reduce的问题,这让我想到了一个例子。cppreference.com在这个例子中,我看到了以下std::vector声明:std::vectorv(10'000'007,0.5);这些引用在这里做什么?我以前从未在任何地方见过这个。这是我应该了解的一种新型C++功能吗? 最佳答案 这是C++14的新特性。来自cppreference:Optionalsinglequotes(')maybeinsertedbetweenthedigitsasaseparator.Theyareignoredbyth

c++ - list 和 forward_list 性能之间的区别?

与c++11一样,我们有两种类型的列表:std::listlst={1,2,3,4,5};std::forward_listflst={5,4,3,2,1};我们知道list是基于双向链表的,forward_list是基于单向链表的。我们应该如何决定使用哪一个?以上任何列表是否有任何性能优势? 最佳答案 Howshouldwedecidewhichonetoused?决定是否需要双向迭代。如果前向迭代足够好,请使用std::forward_list,除非您需要支持早于C++11的C++版本,后者可能只有std::list。Isthe

c++ - 将从唯一指针移动到共享指针也会初始化 enable_shared_from_this

当我继承std::enable_shared_from_this,但是我创建了一个unique_ptr,std::enable_shared_from_this里面的weak_ptr也会被初始化吗当我通过std::move或移动构造函数“移动”到shared_ptr时?例如下面的代码会发生什么:#include#includeclassA:publicstd::enable_shared_from_this{public:std::shared_ptrgetA(){returnshared_from_this();}};intmain(){std::unique_ptru(newA()

c++ - 填充 unordered_set 的更有效方法?

我有一个连续存储在内存中的整数数组,我想将它们全部添加到unordered_set集合中。现在,我一次添加一个。for(inti=0;i有什么方法可以更有效地做到这一点?我意识到项目在集合中不是连续存储的,所以它不会像将数组交给集合那样简单。但这可以以某种方式优化吗? 最佳答案 unordered_set有一个构造函数,它接受一系列元素来初始添加它们:templateunordered_set(InputItfirst,InputItlast,size_typebucket_count=/*implementation-define

c++ - 这段代码是否滥用了 STL 的 find_if?

假设我有一个存储在vector中的服务器名称列表,我想一次联系一个服务器,直到有人成功响应为止。我正在考虑以下列方式使用STL的find_if算法:find_if(serverNames.begin(),serverNames.end(),ContactServer());其中ContactServer是一个谓词函数对象。一方面,存在一个问题,因为谓词不会总是为相同的服务器名称返回相同的结果(因为服务器停机、网络问题等)。但是,无论使用谓词的哪个拷贝(即谓词没有真实状态),都会返回相同的结果,因此状态保持谓词的原始问题在这种情况下不相关。你说呢? 最佳答案

c++ - std::for_each 中的多态仿函数

我正在尝试使用STL算法for_each而不会在我的代码中激增模板。std::for_each想要按值实例化MyFunctor类,但它不能因为它是抽象的。我创建了一个仿函数适配器类,它传递一个指针,然后在适当的时候取消引用它。我的问题:STL或Boost是否已有这样的适配器类?我不想重新发明轮子!structMyFunctor{virtual~MyFunctor(){}virtualvoidoperator()(inta)=0;}namespace{templatestructFunctorAdapter{FunctorAdapter(FunctorType*functor):mFun

c++ - 在C++中模拟虚拟构造函数

在我的应用程序中,我必须从基类派生一些类,问题是我想强制派生类具有3个特定的构造函数实现。由于c++没有虚拟纯构造函数,这似乎很绝望(我不得不手动检查每个类的实现以确保实现了特定的ctors,这不是很有趣)。昨天我发现了一种模拟虚拟Actor行为的疯狂方法:templateclassAbstractEnforcer{protected:AbstractEnforcer(){}private:staticvoidEnforcer(){deletenewT();deletenewT(*(newunsignedint));deletenewT(*(newunsignedint,*(newQS

c++ - 使用 STL 的列表对象

我想在C++中创建一个队列列表,但编译器给了我一些神秘的信息:#include#includeclassTest{[...]listlist_queue;[...]}输出:errorC2143:syntaxerror:missing';'before'即使我使用int作为模板参数,它也会给我同样的错误。怎么回事?(顺便说一句,我使用的是VC++2008EE) 最佳答案 queue也是一个模板类,因此您需要指定队列中包含的元素类型。此外,-在C++中不是合法的标识符字符;也许你的意思是_?std::list>list_queue;

c++ - 关于STL线程安全和STL调试的问题

我有两个关于STL的问题1)为什么STL不是线程安全的?有没有线程安全的结构?2)如何使用GDB调试STL?在GDB中,如何打印vector? 最佳答案 容器数据结构几乎总是需要同步(例如mutex)以防止raceconditions.由于C++标准(C++0x之前)不支持线程,因此无法将这些添加到STL。此外,在不需要同步的情况下,同步的成本非常高。只要您手动执行此同步,就可以在多线程应用程序中使用STL容器。或者,您可以创建自己的线程安全容器,这些容器与thisthread-safecircularqueue等STL算法兼容。.

c++ - 保留容量会导致两次分配还是一次分配?

std::vectorvec;//line#1vec.reserve(100);//line#2我想知道第1行是否触发了一个小的分配(例如,10Ts的内存),或者第一个分配是否发生在第2行。标准对此有任何说明吗? 最佳答案 它是实现定义的。vector的默认构造函数不需要分配任何东西,但实现这样做是允许的。 关于c++-保留容量会导致两次分配还是一次分配?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co