草庐IT

int_types

全部标签

c++ - 为什么这个编译: string = int

假设如下代码:#include#includeintfunc(){return2;}intmain(){std::stringstr("str");str=func();std::cout为什么行str=func();编译时没有类型不匹配的警告?我正在使用设置了-std=c++11标志的编译器gccv.4.7.1。输出:获取的值:'' 最佳答案 std::string类包含一个重载的operator=,它接受一个char值。由于char是整数类型,int可以隐式转换为char。分配给str的值不是空字符串;它是一个长度为1的字符串,

c++ - 为什么 uniform_int_distribution 是闭域而 uniform_real_distribution 是半开域?

uniform_int_distribution具有区间[a,b]但uniform_real_distribution具有区间[a,b).一个天真的方法是做类似b+0.1的事情,但是你开始进入无穷小......幸运的是正确的方法很简单:std::uniform_real_distributiondis(start,std::nextafter(stop,DBL_MAX));但为什么这是必要的?更具体地说,这两者不同的基本原理是什么? 最佳答案 [a,b)上的均匀真实分布在统计上几乎无法与分布区分[a,b].statisticaldi

c++ - "Expected ' (' for function-style cast or type construction"错误是什么意思?

我收到错误“Expected'('forfunction-stylecastortypeconstruction”,我已尽力在线研究此错误的含义,但无法找到导致此错误的任何文档错误。我在StackOverflow上发现的所有相关问题都修复了特定的代码片段,并且没有更笼统地解释导致错误的原因。这些包括Expected'('forfunction-stylecastortypeconstruction答案突出了代码的几个问题。究竟是哪个问题导致了错误尚不清楚。c++Xcodeexpected'('forfunction-stylecastortypeconstruction在主函数中定义函

C++14 元编程 : Automagically build a list of types at compile/init time

使用C++14和CuriouslyRecurringTemplatePattern(CRTP)以及可能的Boost.Hana的某种组合(或boost::mpl如果您愿意),我可以在编译时(或静态初始化时)构建一个类型列表而无需显式声明吗?例如,我有这样的东西(在Coliru上查看):#include#include#includenamespace{structD1{staticconstexprautoval=10;};structD2{staticconstexprautoval=20;};structD3{staticconstexprautoval=30;};}intmain(

c++ - std::greater<int>() 和 std::greater<int> 之间的区别?

此代码有效:#include#include#include#includeusingnamespacestd;intmain(){priority_queue,greater>pq;pq.push(1);cout但是,这段代码无法编译:#include#include#include#includeusingnamespacestd;intmain(){priority_queue,greater()>pq;pq.push(1);cout为什么?我只知道greater()是一个函数对象,priority_queue接受二元谓词作为第三个参数,谓词是一种特殊类型的仿函数。但是这对牙套是

c++ - template<class key, class type> 在 C++ 中的方法之前是什么意思?

我有这段代码,我试图理解遵循的约定,.cpp文件中定义的所有方法都有template写在他们面前。这是什么意思?例子://ConstructortemplateMyOperation::MyOperation(){//methodimplementation}//AmethodtemplateMyOperation::otherOperation(){//methodimplementation}谢谢 最佳答案 必须已经有一个很好的答案,但我也会把我的也扔进池中。C++允许程序结构的声明和实现分开进行。它源于C/C++程序员如何相互

c++ - std::multiset<int> 与 std::map<int, std::size_t> 用于保持多个可重复整数值

我想创建一个记录来保存关于的信息a)存在什么样的元素,b)出现的每种元素的数量在树的一个节点中。我会明确地只为叶节点存储这些信息,而父节点的信息可以通过组合它所有子节点的信息来获得(例如,子节点1有3个A对象,1个B对象,子节点2有1个A的对象,C的2个对象--parent有4个A的对象,1个B的对象和2个C的对象)。从父节点请求此信息时,我会小心不要先请求、使用和丢弃子节点的信息,然后再为其父节点请求,但是向上构造将是一个常见的手术。其他两个常见操作直接源self存储的内容:是否存在类型X的对象?和存在多少类型X的对象?还有如何存在多种对象?对象种类以整数表示,对象编号始终为整数值。

c++ - 什么是 typedef int var[1];做?

我遇到过以下代码:typedefintvar[1];//orvar[3]它到底有什么作用?我不明白下标添加了什么,因为现在我可以为int定义“var” 最佳答案 typedef声明使用与普通变量声明相同的语法。不同之处在于,不是声明“一个名为x的y变量”,而是声明“一个名为x的类型,它是输入y。”语法在其他方面相同。那么,让我们从您的示例中删除typedef,看看我们得到了什么:intvar[1];var是一个类型为int[1]的变量,或者说,一个int的数组。如果我们将typedef添加回去:typedefintvar[1];这使

c++ - 函数模板 : Different specializations with type traits

考虑到类模板,可以使用类型特征和虚拟启动器模板参数为某些类型的组提供模板特化。我已经askedthatearlier.现在,对于函数模板,我需要同样的东西:即,我有一个模板函数,并且想要对一组类型进行特化,例如,作为类X的子类型的所有类型>。我可以用这样的类型特征来表达这一点:std::enable_if::value>::type我想过这样做:templatevoidfoo(){//Dosomething}templatevoidfoo::value>::type>(){//Dosomethingdifferent}但是,这不起作用,因为函数模板不允许偏特化。那怎么办呢?也许是类型特

c++ - 将键码的字符串表示形式转换为 Qt::Key(或任何 int)并返回

我想将表示键盘上的键的字符串转换为键码枚举,如Qt::Key(或其他任何东西)。示例转换为:“Ctrl”到Qt::Key_Control“向上”到Qt::Key_Up"a"到Qt::Key_A"5"到Qt::Key_5如您所见,上面不仅包括字母数字键,还包括修饰符和特殊键。我没有附加到Qt键码枚举,但Qt似乎在QKeySequence的fromString静态函数中具有此解析功能(参见thisdirectlink):QKeySequencefromString(constQString&str,SequenceFormatformat);您可能会问我为什么需要这种转换。好吧,我有一个由