草庐IT

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++ - C++ 中的有符号类型表示

在我正在阅读的书中说:Thestandarddoesnotdefinehowsignedtypesarerepresented,butdoesspecifythatrangeshouldbeevenlydividedbetweenpositiveandnegativevalues.Hence,an8-bitsignedcharisguaranteedtobeabletoholdvaluesfrom-127through127;mostmodernmachinesuserepresentationsthatallowvaluesfrom-128through127.我假设[-128;12

c++ - gcc 4.6 编译器的奇怪行为

这段代码:templateclassInt_Core{static_assert(Check_Range::check(Min,std::numeric_limits::min()),"INCORRECTMinrange.");static_assert(Check_Range::check(Max,std::numeric_limits::max()),"INCORRECTMaxrange.");}我得到的错误是在第二个static_assert上告诉我使用了非常量表达式。但是如果我在第二个断言中将“Max”更改为“Min”,它确实可以毫无问题地编译。怎么回事?错误:错误:静态断言的

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++ - 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++ - 什么时候右移操作>>移位符号位,什么时候不移位?

我的问题是为什么a>>1移动符号位,而不是(a&0xaaaaaaaa)>>1?代码片段inta=0xaaaaaaaa;std::cout>1)>1);std::cout>1)>1);结果410101010101010101010101010101010411010101010101010101010101010101410101010101010101010101010101010401010101010101010101010101010101 最佳答案 a>>1很无聊。它只是为负a的signed类型定义的实现。(a&0xaaaa

c++ - unsigned-signed 下溢机制

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

c++ - 使用无符号数据类型来强制执行非负值和/或有效值是最佳做法吗?

最近,在重构session期间,我正在查看我编写的一些代码并注意到几件事:我的函数使用unsignedchar强制值在[0-255]区间内。其他函数使用int或long数据类型以及函数内部的if语句来静默限制值到有效范围。类中包含的值和/或声明为具有未知上限但已知且确定的非负下限的函数的参数被声明为unsigned数据类型(int或long取决于upperbound的可能性超过4,000,000,000)。这种不一致令人不安。这是我应该继续的好做法吗?我是否应该重新考虑逻辑并坚持使用int或long以及适当的非通知钳位?关于使用“适当”的注意事项:在某些情况下,我使用signed数据类

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