草庐IT

int_void

全部标签

c++ - `size_t` 总是 `vector<int>::size_type` 或任何其他容器类型的别名吗?

让我们举一个最简单的例子:公式1:std::vectorvec;//add10E11elementsfor(std::size_tn=0;n公式2:std::vectorvec;//add10E11elementsfor(std::vector::size_typen=0;n当然,unsignedint或任何不合适的数据类型在这里都不起作用,我们必须编译x64。我的问题是:在任何情况下,第一个公式是否会导致问题,或者我们是否可以安全地始终以这种更短的表示法来编写它?如果它们很容易覆盖(x86、任何其他容器、size_type的其他应用程序),我也会对类似的设置感兴趣。

c++ - char_traits<char16_t>::int_type 的大小不够大吗?

考虑以下程序:#include#include#includeintmain(int,char**){std::basic_stringstreamstream;stream.put(u'\u0100');std::cout输出是:Bad:0Bad:0Bad:1设置badbit的原因似乎是因为如果字符等于std::char_traits::eof(),'put'设置badbit。我现在不能再投入流中了。在http://en.cppreference.com/w/cpp/string/char_traits它指出:int_type:anintegertypethatcanholdallv

c++ - 为什么我不能使用与 'const int*' 相同的 'const char*' 创建一个 int 数组?

为什么我可以用这种方式创建一个字符串或字符数组:#includeintmain(){constchar*string="Hello,World!";std::cout?并且它正确输出第二个元素,而如果没有数组的下标符号[]我就不能创建整数类型的数组?char的一个和这个有什么区别:constint*intArray={3,54,12,53};。 最佳答案 “为什么”是:“因为字符串文字很特殊”。字符串文字存储在二进制文件中,作为程序本身的常量部分,constchar*string="Hello,World!";只是将文字视为存储在别

c++ - 无法将类型 'int&' 的非常量左值引用绑定(bind)到类型 'int' 的右值

以下代码编译失败:#includeusingnamespacestd;intadd2(constint&x){returnx+2;}templateTadd2T(T&&x){returnadd2(std::forward(x));}intmain(intargc,char**argv){intx=0;cout通过这条消息:main.cpp:Ininstantiationof'Tadd2T(T&&)[withT=int&]':main.cpp:26:20:requiredfromheremain.cpp:12:16:error:cannotbindnon-constlvaluerefer

c++ - 混合 void_t 和可变参数模板?

考虑以下代码:template>structis_invokable:std::false_type{};templatestructis_invokable>>:std::true_type{};目标是拥有一个特征,该特征能够判断类型为F的可调用对象是否可以使用类型为Args...的参数进行调用。但是,编译失败是因为:error:parameterpack'Args'mustbeattheendofthetemplateparameterlist在C++17中执行此操作的(优雅)方法是什么? 最佳答案 namespacedetai

c++ - 调用对象类型 'void (B::*)(int)' 不是函数或函数指针

我正在尝试将方法作为函数参数传递。这是一个简化的示例,它返回一个我不理解的编译错误classB{private:intj;public:voidfoo(inti){std::coutj编译时用g++-std=c++11b.cpp-ob我明白了b.cpp:22:50:error:calledobjecttype'void(B::*)(int)'isnotafunctionorfunctionpointervoidcall(void(B::*fun)(inti),inti){b.*fun(i);}~~~^b.cpp:31:12:error:calltonon-staticmemberfun

c++ - std::less<int> 的正确参数类型是什么?

我正在制作一个类——一个BST——它可以比较模板化节点,这需要一个比较器,例如std::less。树是这样的:templateclasstree{private:comparatorcompare;public:explicittree(comparatorfunctor);};但我似乎找不到应该在我的应用程序中输入哪种模板类型。treemy_bst(std::less);error:wrongnumberoftemplatearguments(1,shouldbe2)bst::treemy_bst(std::less);这是有道理的,因为我的模板类型不完整。我应该如何分析我的构造函数

c++ - char c = 255 的值转换为 int

我的问题是关于Stroustrup的《C++编程语言》第4版一书中的一段话。他举了一个例子charc=255;//255is‘‘allones,’’hexadecimal0xFFinti=c;以及如何在char有符号或无符号的机器上转换它的解释。i的值是多少?不幸的是,答案是不确定的。在8位字节的实现中,答案取决于扩展为int时“全部”char位模式的含义。在char没有符号的机器上,答案是255。在char有符号的机器上,答案是−1。我的问题是为什么它会是-1,这不是取决于机器上使用的二进制数表示形式吗?如果它使用一个补码,它不是0(-0)吗?如果使用二进制补码,它不是-1吗?

c++ - 寻找哈希函数/Ordered Int/to/Shuffled Int/

我正在寻找可以将有序整数索引值更改为随机哈希索引的恒定时间算法。如果它是可逆的就好了。我需要每个索引的哈希键都是唯一的。我知道这可以通过在大文件中查找表格来完成。IE。创建一个有序的所有整数集,然后随机打乱它们并以随机顺序写入文件。然后您可以在需要时读回它们。但这需要搜索一个大文件。我想知道是否有一种简单的方法可以使用伪随机生成器来根据需要创建序列?GeneratingshuffledrangeusingaPRNGratherthanshufflinganswer经过erikkallen的线性反馈移位寄存器看起来是正确的事情。我刚刚试过了,但它会产生重复和孔洞。问候大卫·艾伦·芬奇

c++ - 为什么 numeric_limits<int>::min() 有不同的定义?

要检索最小值,我必须使用numeric_limits::min()我想最小的整数是-2147483648,在我的机器上测试显示了这个结果。但是一些C++引用,如OpenGroupBaseSpecifications和cplusplus.com用值-2147483647定义它。我问这个问题是因为在我实现negaMax框架时(游戏树搜索)值最小整数*(-1)必须明确定义。是的,使用minimalint=(numeric_limits::min()+2)在任何情况下我都是安全的,因此我的问题更具理论性,但我认为还是很有趣。 最佳答案 如果