草庐IT

standards

全部标签

c++ - C++中一个变量定义列表中的常量和非常量

为什么不能在一个定义列表中定义const和non-const变量?例如,在使用for循环时:for(size_ti=0,constiCount=data.size();i我想从const-correctness的角度来看会更好。附言我第一次问错了这个问题。它更多的是针对语言设计者而不是“为什么它可以在我的机器上编译?”。我想说的是,如果在下一个C++标准中将其作为语法糖来实现,那就更好了。这也将防止在每次循环迭代中调用data.size()。我的意思是,为什么不扩展当前的C++变量定义列表以支持单个定义列表中的const和non-const? 最佳答案

c++ - 将功能应用于参数包的每个元素的语言功能

有谁知道,如果存在允许我替换它的c++语言功能的标准提案(感谢Yakk):templatevoidbar(constARGS&...args){autot={(foo(args),0)...};(void)t;//像这样更自然的东西:templatevoidbar(constARGS&...args){foo(args)...;}foo例如一个函数,一个函数模板和/或一组重载的函数,其返回类型可能为void(或者通常我不关心)。顺便说一句,如果有人知道用c++14编写这个的更简洁的方法,请随时分享,但我认为,这已经在thisquestion中处理了。 最佳答

C++:计算给定范围内可能的浮点值的数量

我正在开发一个加密应用程序,使用Crypto++作为此应用程序的一个晦涩部分,我需要确定在特定数值范围内可以存在的唯一浮点值的最大数量。显然在现实中0和1之间存在无穷多个数字-但并非所有数字都可以用唯一的浮点值表示。我有一个最小浮点值和一个最大浮点值。我需要确定此范围内可能的浮点值的数量。这很棘手,因为浮点值间隔得越远,离0越远。例如,0和1之间的可能浮点值的数量与100,000和100,001出于我的目的,我希望计数也包括最小值和最大值。但是生成独占计数的算法同样有用,因为我可以根据需要简单地添加1或2。其他问题:如果0在范围内怎么办?例如,如果最小值为-2.0,最大值为正2.0,我

c++ - 为什么 `std::is_function_v` 没有按预期工作?

#include#include#includeusingnamespacestd;templateboolf(T&&v){returnis_function_v(v))>;}intmain(){cout输出是:(clang6.0&gcc8.0)>truefalse但我期望的结果应该是:>truetrue为什么std::is_function_v没有按预期工作? 最佳答案 您需要删除对T的引用。templateboolf(T&&v){returnis_function_v(v))>>;//~~~~~~~~~~~~~~~~~~}当se

c++ - 为什么 const_cast 需要说明你要转换到什么?

根据标准(§5.2.11),const_cast会丢弃cv限定符(const或volatile)。这是一个简单的例子。首先你声明两个函数接受一个指针和一个引用:classBar{...};voidfoo_ptr(Bar*);voidfoo_ref(Bar&);然后你创建一个常量引用:Barb;constBar&cb=b;然后您可以使用适当的const_cast调用任一函数:foo_ptr(const_cast(&cb));foo_ref(const_cast(cb));这是我的问题:既然const_cast不能做其他类型转换的设计目的,那么您要转换成什么不是很明显吗?换句话说,为什么语

c++ - 谁能解释一下当前C++0x标准草案的这一段?

很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visitthehelpcenter.关闭11年前。谁能解释ISON3242§3.2第4点中的这个陈述与ISO标准2003相比,n3242的新增部分:4Exactlyonedefinitionofaclassisrequiredinatranslationunitiftheclassisusedinawaythatrequirestheclasstypetobecomplete.AclasstypeTmustbecompleteif:anon-s

c++11 standard-layout - 使用相同的访问控制

我认为POD(c++11,琐碎+标准布局)的全部意义在于确保类型与C兼容。给定以下代码://thatoneisastandardlayout,andtrivialwhichmakesitac++11PODstructBar{public:intx;public:inty;};AFAIU,编译器可能会重新排序x和y。这不会破坏与C的兼容性吗?为什么c++11中的98/03POD定义放宽被认为是个好主意? 最佳答案 AFAIU,compilermightreorderxandy.Wouldn'tthatbreakcompatibilit

c++ - "see below"用作类型或异常规范时意味着什么?

查看C++标准(currentdrafthttp://isocpp.org/files/papers/N3690.pdf,sec20.8.3就是这样一个地方)和LLVM的libc++头文件,我发现“见下文”被用作一种类型和异常规范。它似乎在不存在类型时使用,但使用2个单词的短语而不是某种有效标识符似乎很奇怪。它是在标准中还是在其他地方讨论过?为什么/如何使用它? 最佳答案 seebelow只是几个可能类型之一的占位符,这些类型总是在以下文本中描述。例如这里:typedefseebelowelement_type;1Type:Ptr:

c++ - C++ new 运算符能保证返回的指针不会改变它的值吗?

在C++中:constsize_tN=1000;int*p=newint[N];//time=t0我的程序只有一个线程,在为p分配内存后,我的程序将只读取p指向的内存。标准对p的值有何规定?p是否会保留它在time=t0时获得的值,直到p被删除?或者,操作系统能否自行决定重新分配p指向的内存?是否取决于N的值? 最佳答案 p的值在创建后不能移动。该标准使这样做毫无用处:3.7.4.1分配函数...如果请求成功,则返回值应为非空指针值(4.10)p0,不同于任何先前返回的值p1,除非该值p1随后被传递给操作符delete。(引用标准结

c++ - char[](c-string) 的初始化标准

考虑以下代码:intmain(){charhi[5]="Hi!";printf("%d",hi[4]);}将打印什么?更重要的是,在最新C++标准中,标准中是否提及将打印的内容?如果有提及,它在哪里?由于某种原因,很难找到关于此的最新信息,而且各种来源的信息相互矛盾。我试过en.cppreference.com和cplusplus.com,前者没有任何信息,后者声称值未确定。然而,usingnamespacestd;intmain(){charmySt[1000000]="Hi!";for(inti=0;i这在我的系统上只打印0、1和2,所以我希望“rest”被初始化为“\0”。另外据