草庐IT

标准图

全部标签

c++ - 如果新大小小于或等于旧大小,标准是否保证 std::string::resize 不会重新分配内存?

我需要经常将字符串设为空,然后在其中添加一些字符。std::string::clear()可能重新分配std::string::resize(0)是否重新分配?标准的话并没有引起任何注意。 最佳答案 我认为最好的答案是http://en.cppreference.com/w/cpp/string/basic_string/clear的“注释”部分.Unlikeforstd::vector::clear,theC++standarddoesnotexplicitlyrequirethatcapacityisunchangedbythi

c++ - 是否发布了新版本的 C++ 标准?

Thefollowingarticlecontainsalinktoallcurrentanddraftversionsofthestandard.See:https://stackoverflow.com/a/4653479/14065我刚刚检查了ISOsite查看最新版本的标准草案是什么。我想到了两个以前从未见过的版本:N3690N3691这里有几个奇怪的地方。N3691发布于2013-05-16这是在N36902013-05-15BUTNS3690似乎是较新的版本(N3691是之前的版本N3690)。当您打开N3690时,它没有表明它是草稿的措辞。这是否意味着我们现在正在使用C+

c++ - C++11标准中实例化单元的含义是什么?

C++11§2.2翻译阶段,第8个短语。翻译后的翻译单元和实例化单元组合如下。“实例化单元”的确切含义是什么? 最佳答案 实例化单元是模板实例化(隐式和显式)。例如,对于这个模板:templatestructA{};这个:templateclassA;加上上面的模板声明和定义,就是一个实例化单元。 关于c++-C++11标准中实例化单元的含义是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/q

c++ - 来自 exception::what() 的异常描述是否标准化为标准异常?

对于像std::bad_alloc这样的标准化异常,exception::what()返回的字符串在不同的编译器中是否应该相同?例如,我使用过的几个编译器都会为bad_alloc::what()返回badallocation。是否有某种原因没有返回更具描述性的字符串,例如Memoryallocationfailure? 最佳答案 Isthestringreturnedbyexception::what()expectedtobethesameacrosscompilers?不,这不是标准化的。以你的bad_alloc为例:[C++1

c++ - 如何调用 clang++ 或 g++ 来准确复制两个不同标准版本中的需求

我试图确定N3337§8.5p7(C++11)和N3797§8.5p8(后C++11)之间处理值初始化的差异。N3337§8.5p7:Tovalue-initializeanobjectoftypeTmeans:ifTisa(possiblycv-qualified)classtype(Clause9)withauser-providedconstructor(12.1),thenthedefaultconstructorforTiscalled(andtheinitializationisill-formedifThasnoaccessibledefaultconstructor);

c++ - 在 C++ 中,如何重用已完成执行的标准线程?

我的C++方法的main()方法中有这行代码:std::threadfoo(bar);这很好用。但是,我想根据外部输入随时运行同一个线程。我怎样才能重新使用这个线程来再次运行线程?我这样做的原因是我有两个函数需要同时运行:一个是阻塞函数,接受输入x,并按设定的时间间隔将数据输出到输出。另一个是阻塞并根据外部输入产生输出y。这基本上应该是这样的:intshared_x=0;intproducer_x=0;intconsumer_x=0;std::threadproducer(foo);//Modifiesfoo_xstd::threadconsumer(bar);//Outputsbas

c++ - 不透明和匿名枚举声明如何符合标准要求?

我在N3936(条款7.2.2)中读到“在范围枚举的声明中不应省略可选标识符”,所以我尝试了以下代码(嵌入的评论试图解释我的解释)GNU-g++4.8.3和clang3.4.2#includeenumany:int;//unscopedopaquedeclaration:intrequiredbythestandardenum:int{a}t;//unscopedanonymousdeclarationoft(:intnotrequired)enumany:int{b}u;//redlecarationoftype"any"withoneenumeratorenumclassfoo:c

C++:打印或计算一个标准库容器到控制台

打印或cout的C++方式是什么?一个C++标准库容器到控制台,查看它的内容?另外,为什么C++库实际上没有重载接线员给你?它背后有什么历史吗? 最佳答案 重载operator对于ostream是要走的路。这是一种可能性:templatestd::ostream&operator(os,""));returnos;}然后你可以简单地写:std::cout这里还有其他一些非常好的解决方案:Pretty-printC++STLcontainers 关于C++:打印或计算一个标准库容器到控制台

C++ 单例 — 不是完整的 C++ 11 标准

我正在努力用C++设计一个线程安全的单例实现,但它主要针对VisualStudio2012环境。我知道C++11标准保证了这一点Foo&Instance(){staticFooinstance;returninstance;}是线程安全的。但是VisualStudio2012中使用的编译器还没有完全符合C++11标准(至少在静态变量初始化的线程安全方面)。所以我想到了这个:#include#include#includeclassFoo{public:staticFoo&Instance();private:Foo(){init();}Foo(Fooconst&);voidoperat

c++ - 标准中哪里说 `new` 返回的每个分配都与 `std::max_align_t` 对齐?

Inthisvideo,在大约6.39处,演示者似乎在说new总是返回与std::max_align_t对齐的内存,这是有道理的,因为operatornew对分配的变量类型一无所知。也就是说,编译器必须选择最严格的对齐方式。但我在标准中找不到这个。演示者还说,当new用于分配char或unsignedchar数组时,此规则不适用。在这种情况下,对齐取决于大小。但这对我来说也不清楚。 最佳答案 这是在[basic.stc.dynamic.allocation]/2中:Theallocationfunctionattemptstoall