草庐IT

Long-Horizon

全部标签

c++ - make_signed<unsigned long>::type 是 int?

我使用的是VisualStudio2010,下面的代码让我有些困惑:#includeautox=std::make_signed::type();x将是int类型,但我预计会很长。我知道VS10中的int和long都是4字节整数。但是即使一个signedlong装进一个int,int对我来说也不是unsignedlong对应的signedinteger类型。所以我的问题是:这是错误/技术错误还是标准规范允许这种结果? 最佳答案 C++1120.9.7.3[meta.trans.sign]描述了make_signed:IfTnames

C++ signed 和 unsigned int 与 long long 速度

今天,我注意到几个简单的按位和算术运算的速度在int之间有显着差异。,unsigned,longlong和unsignedlonglong在我的64位电脑上。特别是,对于unsigned,以下循环的速度大约是其两倍至于longlong,这是我没想到的。intk=15;intN=30;intmask=(1(完整代码here)以下是计时(以秒为单位)(对于g++-O、-O2和-O3):1.834207723(int)3.054731598(longlong)1.584846237(unsigned)2.201142018(unsignedlonglong)这些时间非常一致(即1%的差值)。

c++ - std::streampos 是否保证为 unsigned long long?

std::streampos是否保证为unsignedlonglong?如果不是这样,std::istream::seekg如何在大于4G的文件上正常工作? 最佳答案 来自http://en.cppreference.com/w/cpp/io/fpos:std::streampos是类模板的特化templateclassfpos;std::streampos类型定义为std::fpos::state_type>类型为fpos的每个对象保存流中的字节位置(通常作为std::streamoff类型的私有(private)成员)。来自ht

c++ - gcc编译C++代码: undefined reference to `operator new[](unsigned long long)'

有一段C++代码:#includeintmain(){intb=sizeof('a');if(b==4)printf("I'maCprogram!\n");elseprintf("I'maC++program!\n");}像这样编译:gccmain.cpp-omain它成功并给出:I'maC++program!然后在函数main的某处添加一行int*p1=newint[1000];它失败了:C:\Users\...\AppData\Local\Temp\cccJZ8kN.o:main1.cpp:(.text+0x1f):undefinedreferencetooperatornew[]

c++ - (signed) long long 的真正下限是多少?

使用longlong检查类型的限制std::cout::min();我得到-9223372036854775808但是在编译以下代码时:intmain(){longlongl;l=-9223372036854775808LL;}我收到警告:test.cpp:3:7:warning:integerconstantissolargethatitisunsigned.test.cpp:3:warning:thisdecimalconstantisunsignedonlyinISOC90我错过了什么?非常感谢您的帮助。乔治 最佳答案 这个9

C++ double 到 long long

如果我用c++写代码:longlongd=999999998.9999999994;cout我得到输出:999999999(四舍五入)但是这段代码的输出:longlongd=999999998.9999994994;cout是999999998(向下舍入)跟精度有关系吗?有什么办法可以改变精度。floor()函数也给出相同的输出。我还注意到,如果我将值8.9999994994或8.9999999994分配给d(上述变量)。输出为8。 最佳答案 999999998.9999999994不能用double精确表示,因此实际值是99999

c++ - std::abs 为 "unsigned long long int"数据类型

为什么会出现这个错误C2668:'abs':ambiguouscalltooverloadedfunction像这样简单的代码#include#includeintmain(){unsignedlonglonginta=10000000000000;unsignedlonglongintb=20000000000000;std::cout删除std::后错误仍然存​​在。但是,如果我使用int数据类型(具有较小的值),则没有问题。传统的解决方案是手动检查std::cout这是唯一的解决方案吗? 最佳答案 检查似乎是唯一真正好的解决方

c++ - 使用 GCC 和 C++11 实现类型 "long double"

我尝试搜索有关longdouble的信息,到目前为止,我了解到编译器对它的实现有所不同。在Ubuntu(XUbuntu)Linux12.10上使用GCC时,我得到了这个:doublePId=acos(-1);longdoublePIl=acos(-1);std::cout.precision(100);std::cout输出:PId8:3.141592653589793115997963468544185161590576171875PIl16:3.141592653589793115997963468544185161590576171875有人明白为什么他们输出(几乎)相同的东西吗

c++ - 如何安全地将 `unsigned long int` 转换为 `int` ?

我有一个应用程序以unsignedlongint的形式创建唯一的id。该应用程序需要这种精度。但是,我必须在只允许int的协议(protocol)中发送这些id。协议(protocol)的接收应用程序不需要这种精度。所以我的问题是:如何将unsignedlongint转换为int,尤其是当unsignedlongint大于时>整数?编辑:协议(protocol)只支持int。我很想知道如何避免“翻车问题”发送消息的应用程序需要知道很长一段时间内的唯一性,而接收者只需要知道短时间内的唯一性。 最佳答案 这是一种可能的方法:#inclu

c++ - C++ 中的 LONG float 和 double 有什么区别?

所以我知道float和double的精度有很大的不同。我明白了。promise。但是,在C++中,当调用scanf和printf时,用于指定double的符号是“%lf”,它代表longfloat,对吗?因此,虽然float不如double精确,但LONGfloat(可能称为longfloat,因为它可以通过具有更多项而“更长”)具有相同的精度,因此本质上是相同的东西?澄清一下,我的意思是:doublenumber=3.14159;printf("Thenumberis%lf",number);所以我的问题的根源是:longfloat是double的另一个名称吗?