草庐IT

c++11 decltype 返回引用类型

我有点困惑为什么在某些情况下使用逗号运算符的decltype会返回引用类型。例如,在这段代码中:inti=101;decltype(1,i)var=i;var=20;printf("%d\n",i);//willprint20在这里,var是int&而不是int,但是如果我将第二行替换为:decltype(i)var=i;它将返回int!谁能解释一下? 最佳答案 decltype是特殊情况,用于未加括号的id-expression以给出实体的类型,没有引用限定[dcl.type.simple]:4-Thetypedenotedbyd

c++ - 在 C++11 中,引用在运行时明显发生变化

考虑以下C++11中的简单代码,摘自C++Primer,5thEdition:#include#includeusingstd::cout;usingstd::string;usingstd::endl;intmain(){strings("HelloWorld!!!");for(auto&c:s)//foreverycharins(note:cisareference)c=toupper(c);//cisareference,sotheassignmentchangesthecharcout该代码使用rangefor循环遍历string中的每个字符并将其更改为大写,这非常简单。令我困

c++ - 正在为 C++11 之前的编译器返回线程安全的本地静态对象

对于C++11之前的编译器来说,这个单例线程安全吗?正如我们所知,对于C++11,它是线程安全的。classSingleton{private:Singleton(){};public:staticSingleton&instance(){staticSingletonINSTANCE;returnINSTANCE;}}; 最佳答案 在C++11中,使该线程安全的是来自draftC++11standard的以下内容6.7部分声明语句说(强调我的):Thezero-initialization(8.5)ofallblock-scope

c++ 11通过constexpr在编译时获取字符串长度

#includeconstexprsize_tconstLength(constchar*str){return(*str==0)?0:constLength(str+1)+1;}int_tmain(intargc,_TCHAR*argv[]){constchar*p="1234567";size_ti=constLength(p);printf(p);printf("%d",i);return0;}大家好我想在编译时获取字符串的长度。所以我写了上面的代码。但是在反汇编代码中,我发现下面名为sub_401000的“constLength”函数将导致计算字符串长度的运行时开销。是否有有问

c++ - 在没有 C++ 11 的情况下使用 char16_t、char32_t 等?

我想要固定宽度的类型,包括字符类型。提供整数类型,但不提供字符类型,除非在使用C++11时,这是我做不到的。是否有一种干净的方法来定义这些类型(char16_t、char32_t等)而不与C++11定义的类型发生冲突,以防源代码与C++11混合?谢谢你:) 最佳答案 我认为,检查是否支持这种类型是平台相关的事情。例如,GCC定义:__CHAR16_TYPE__和__CHAR32_TYPE__如果提供了这些类型(需要ISOC11或C++11支持)。但是,您不能直接检查它们的存在,因为它们是基本类型,而不是宏:InC++,char16_

c++ - 有效的 C++03 模板代码无法在 C++11 中编译

我在编写有效的C++03模板代码时遇到了一个小问题(虽然很容易解决),该代码可以正常编译,但在使用C++11方言时无法编译。问题出现在模板参数解析处。以这段代码为例:templatestructnumber_of_bits{enum{value=1+number_of_bits>1>::value};};templatestructnumber_of_bits{enum{value=0};};由于C++11现在允许“>>”完成将模板化参数作为最后一个参数的模板参数列表,因此在解析此代码时会产生问题。我使用GCC(版本4.8.1)作为我的编译器,它使用命令行正常编译:g++test.cc

算法------(11)并查集

例题:(1)Acwing836.合并集合    并查集就是把每一个集合看成一棵树,记录每个节点的父节点。合并集合就是把一棵树变成另一棵树的子树,即把一棵树的父节点变为另一棵树的父节点的儿子。查询是否在同一集合就是看他们的根节点是否相同。在查找过程中可以路径加速,把每个点直接连到根节点。#include#include#includeusingnamespacestd;constintN=1e5+10;intp[N];intfind(intx){if(p[x]!=x)p[x]=find(p[x]);returnp[x];}intmain(){intn,m;scanf("%d%d",&n,&m);

c++ - 如何检查线程是否已在 C++11 及更高版本中完成工作?

如何在C++11及更高版本中检查线程是否已完成工作?我一直在阅读文档并编写了以下代码:#include#includevoidmythread(){//dosomestuff}intmain(){std::threadfoo(mythread);if(foo.joinable()){foo.join();//dosomenextstuff}}joinable只告诉线程已经开始工作,但我想知道如何编写代码来检查线程是否完成工作。例如:#include#includevoidmythread(){//dosomestuff}intmain(){std::threadfoo(mythread

c++ - 编译 nana 库时不能包含 <X11/Xft/Xft.h>,没有那个文件或目录

我正在尝试安装nanaC++library在Ubuntu16.04中。我下载并解压到我的helloworld文件所在的目录,然后进入makefile所在的目录;nana/build/makefile,输入make却报错X11/Xft/Xft.h:nosuchfileordirectory我检查了/usr/include/X11是的,它不在那里。谷歌搜索并没有帮助找出安装Xft的热点。我该怎么做?还是我做错了什么? 最佳答案 这个header似乎在libxft-dev包中。用你的包管理器安装它。如果合适,请尝试:sudoaptinst

c++ - 如何在 C++11 中初始化未在其构造函数中初始化其所有成员的类

代码是这样的classC{public:intm1;intm2;C(intm);}C::C(intm):m1(m){};intmain(){C*c=newC(1);coutm2我想知道要初始化的值m2是什么。我认为c是值初始化的,而m2是默认初始化的。我用C++11和g++4.8.4测试,m2好像一直是0。我以为0是默认初始化,但默认初始化不是0。所以初始化为0就可以保证了? 最佳答案 c是copyinitialized,而不是值初始化。m2实际上是默认初始化的,是的,但这并不意味着它的值总是0(这将由值和聚合初始化保证)。int(