草庐IT

-std=gnu99

全部标签

c++ - 将 std::ios_base::trunc 标志与 std::ios_base::out 一起使用的目的是什么

在std::ios_base::out中使用std::ios_base::trunc标志的目的是什么?我在很多例子中都看到了这一点。我认为标准保证std::ios_base::out也会截断文件(我知道的所有STL实现都这样做)。我错了吗,应该明确通知我要截断文件吗? 最佳答案 是的,std::ios_base::out等同于fopen中的"w"。std::ios_base::trunc的重点是std::ios_base::in和std::ios_base::out同时使用。在|out等同于"r+"在|出来|trunc等同于"w+"

c++ - 使用 std::unique_ptr 的具有私有(private)析构函数的单例

我在我的程序中创建了所有单例,并牢记该文档:http://erdani.com/publications/DDJ_Jul_Aug_2004_revised.pdf(如果有人想知道为什么单例,它们都是工厂,其中一些存储一些关于它们应该如何创建实例的全局设置)。他们每个人看起来都像这样:声明:classSingletonAndFactory{staticSingletonAndFactory*volatileinstance;public:staticSingletonAndFactory&getInstance();private:SingletonAndFactory();Single

C++11 auto、std::function 和对重载函数的模糊调用

我想知道是否有人知道为什么以下示例无法编译并给出对重载函数错误的模糊调用。如果我用强类型仿函数签名替换auto,它就能够正确区分两个方法重载。我注意到当不使用std::function作为我的重载参数时,不会发生同样的问题。如果我的重载只接受一个简单的float和int,即使使用auto关键字定义我的输入参数,编译器也可以正确区分这两个重载。我正在VisualStudio2012中编译它。这可能只是VS编译器中的错误吗?我现在无法访问装有GCC或Clang的机器,但有人知道这是否可以在那里编译吗?编译错误:对重载函数的调用不明确classAmbiguousOverload{public

c++ - 按类型对 std::vector 进行排序

我在看http://channel9.msdn.com/Events/GoingNative/2013/Writing-Quick-Code-in-Cpp-Quickly在第36分钟左右,他们讨论了如果您要对集合调用虚拟方法,则按元素类型对集合进行排序的好处。如此给定classBase{};classDer1:publicBase{};classDer2:publicBase{};classDer3:publicBase{};vectormyVector;如何对myVector进行排序,使每种类型的元素都是相邻的?有没有办法不使用虚函数来识别每个派生类型?(也许使用typeid?)

c++ - 在 C++11 中,是否有 std::lock_guard 的变体在构造时解锁并在销毁时锁定?

有好几次我写了一些代码,可以从“反向”lock_guard中获益,就像在这个简短的例子中一样。std::lock_guardlg(_eventQueueMutex);while(!_eventQueue.empty()){Evente=_eventQueue.top();_eventQueue.pop();_eventQueueMutex.unlock();//ManualunlockdispatchEvent(e);_eventQueueMutex.lock();//Manuallock}有没有办法用C++11中的自动lock_guard替换内部解锁/锁定?

c++ - strcmp 无法将 ‘std::string {aka std::basic_string<char>}’ 转换为‘const char*

这个问题在这里已经有了答案:strcmporstring::compare?(6个答案)关闭8年前。提前为问题的基本性质道歉。我正在尝试使用strcmp函数来测试两个字符串的匹配字符。我将问题简化为下面的简单代码:#include#includeusingnamespacestd;voidcompareStrings(string,string);intmain(){stringstring1="testString",string2="testString";compareStrings(string1,string2);return0;}voidcompareStrings(str

c++ - 从 std::ostream_iterator 调用时未找到运算符 << 的重载?

这个程序//main.cpp#include#include#include#include#includetemplatestd::ostream&operator&pair){returnos";}intmain(){std::mapmap={{1,2},{2,3}};std::cout>(std::cout,""));//thisdoesn'twork}产生错误nomatchfor‘operator>::ostream_type{akastd::basic_ostream}’and‘conststd::pair’)我猜这是行不通的,因为我的重载在std::copy中不可用,但这是

c++ - C++14 是否要求删除表达式必须调用 `void operator::delete(void*, std::size_t)` 而不是 `void::operator delete(void*)` ?

根据thisvoidoperatordelete(void*);(1)voidoperatordelete[](void*);(2)voidoperatordelete(void*,conststd::nothrow_t&);(3)voidoperatordelete[](void*,conststd::nothrow_t&);(4)voidoperatordelete(void*,std::size_t)(5)voidoperatordelete[](void*,std::size_t)(6)voidoperatordelete(void*,std::size_t,conststd:

c++ - 如何初始化 std::array<std::array<T, 2>, 2> 的对象?

我正在尝试初始化thing类型的对象:templatestructthing:std::array,2>{};thingt1{{{1,2},{3,4}}};我得到:error:nomatchingfunctionforcallto‘thing::thing()’thingt1{{{1,2},{3,4}}};同上thingt0{{1,2,3,4}};还有其他一些东西。 最佳答案 如果您使用的是C++17编译器,您只是少了一组额外的大括号。以下compiles:thingt1{{{{1,2},{3,4}}}};//||||-braces

c++ - 为什么这个使用 std::rotate 的简单程序无法编译?

这不工作:#includeintmain(){inta[]={1,2,3};autoit=std::rotate(std::begin(a),std::begin(a)+1,std::end(a));}我得到的错误是:main.cpp:6:10:error:variablehasincompletetype'void'autoit=std::rotate(std::begin(a),std::begin(a)+1,std::end(a));这显然是不正确的行为,因为rotate的声明是:templateForwardIteratorrotate(ForwardIteratorfirst