草庐IT

dollar-sign

全部标签

c++ - boost::lexical_cast<signed char> 无法处理负数?

这个简短的C++程序的行为方式让我感到困惑:#include#include#include#includeintmain(void){signedcharc=-2;assert(c==-2);c=boost::lexical_cast(std::string("-2"));std::cout使用g++5.2.1和boost-1.58.0,我得到:terminatecalledafterthrowinganinstanceof'boost::exception_detail::clone_impl>'what():badlexicalcast:sourcetypevaluecouldn

c++ - 将 unsigned long long 与 signed long long 结果相减?

假设我有这两种类型:typedefunsignedlonglonguint64;typedefsignedlonglongsint64;我有这些变量:uint64a=...;uint64b=...;sint64c;我想从a中减去b并将结果赋给c,很明显,如果差值的绝对值大于2^63,那么它将换行(或未定义),这是可以的。但是对于绝对差小于2^63的情况,我希望结果是正确的。以下三种方式:c=a-b;//signconversionwarningignoredc=sint64(a-b);c=sint64(a)-sint64(b);其中哪些可以保证按标准工作?(以及为什么/如何?)

c++ - int8_t 和 char : converts between pointers to integer types with different sign - but it doesn't

我正在处理一些嵌入式代码,并且正在从头开始编写一些新东西,因此我更愿意坚持使用uint8_t、int8_t等类型。然而,当移植一个函数时:voidfunctionName(char*data)到:voidfunctionName(int8_t*data)在将文字字符串传递给函数时,我收到编译器警告“在指向具有不同符号的整数类型的指针之间转换”。(即调用functionName("putthistextin");时)。现在,我明白了为什么会发生这种情况,并且这些行只是调试,但我想知道人们认为什么是最合适的处理方式,而不是对每个文字字符串进行类型转换。在实践中,我不认为一揽子类型转换比使用

c++ - unsigned-signed 下溢机制

我知道以下内容unsignedshortb=-5u;由于下溢,评估为b为65531,但我不明白5u在转换为-5之前是否转换为带符号的int,然后重新转换回无符号以存储在b中,或者-5u是等于0-5u(不应该这样,-x是一元运算符) 最佳答案 5u是一个文字无符号整数,-5u是它的否定。无符号整数的否定定义为从2**n中减去,得到相同的结果包装从零减去的结果。 关于c++-unsigned-signed下溢机制,我们在StackOverflow上找到一个类似的问题:

c++ - 警告 : Comparison between signed and unsigned integer expression

我在codepad.org上运行以下代码时出现此错误。“在成员函数‘doubleXchange::getprice(std::string)’中:第87行:警告:有符号和无符号整数表达式之间的比较”这是我的代码:#include#include#includeusingnamespacestd;classXchange{public:Xchange();//doesnothing(?)doublegetprice(stringsymbol);private:vectorstocks;};doubleXchange::getprice(stringsymbol){for(inti=0;i

c++ - Signed Char的目的是什么

如果char和signedchar的范围都是-127-127,那么signedchar的用途是什么?我们在什么地方使用signedchar而不是仅使用char? 最佳答案 unsignedchar是无符号的。signedchar已签名。char可能是未签名的或已签名的,具体取决于您的平台。当您确实需要签名时,请使用signedchar。可能相关:Whatdoesitmeanforachartobesigned? 关于c++-SignedChar的目的是什么,我们在StackOverflo

c++ - 测试 std::is_integral 和 std::is_signed?

我有一个函数,但我想将它分成两个函数,一个用于返回有符号整数,一个用于返回无符号整数。看起来像std::is_signed不是严格意义上的整数,所以我想我是否可以对类似std::is_integral::value&&std::is_signed::value的东西进行模板测试但这是行不通的。现在我将签名测试作为if语句:templatetypenamestd::enable_if::value,T>::typefoo(){if(std::is_signed::value){//signed}else{//unsigned}}编辑。我使用的是VisualStudio2010。实际上,看

c++ - std::make_signed 接受浮点类型

我有一个只能为标量类型(整数、float等)实例化的模板类,我希望成员typedef始终是该类型的已签名变体。即:unsignedint->signedintsignedlonglong->signedlonglong(已签名)unsignedchar->signedcharfloat->floatlongdouble->longdouble等等……不幸的是,std::make_signed仅适用于整数类型,不适用于浮点类型。最简单的方法是什么?我正在寻找usingSignedT=...;形式的东西,作为我的模板类的一部分,模板参数T已经保证是标量。 最佳答

不允许使用$的UPSERT:Dollar($)前缀字段对于存储无效

此流星服务器端(Mongo1.1.18)尝试根据选择器来升级文档,但给出以下错误:myCol.upsert({name:'sam',job:{$exists:false}},{$set:{parents:['jack','jacky']}});MongoError:“Job”中的美元($)前缀字段“存在”。$存在。我该如何提高此选定的文档?还是创建它,如果它不存在?谢谢看答案原因是因为有一个"upsert"MongoDB试图分配新创建的对象中提供的任何“QUERY”参数。由于您无法用$由于试图创建字段“作业”为{"job":{"$exists":true}},就像您在查询论点中提供的一样。为避

.net - 警告 C4341 - 'XX' : signed value is out of range for enum constant

在编译我的C++.Net应用程序时,我收到104条警告类型:WarningC4341-'XX':signedvalueisoutofrangeforenumconstantXX可以在哪里字符长位二进制GUID...无论我做什么,我似乎都无法删除这些警告。当我双击它们时,它会将我带到使用OdbcParameters的代码的一部分-当我尝试使用我的所有其他东西但没有OdbcParameters的测试项目时,它不会发出警告。知道如何摆脱这些警告吗?他们从我实际上很难看到的代码中发出真正的警告-知道我的应用程序有104个警告让我感觉很糟糕! 最佳答案