草庐IT

long-integer

全部标签

c++ - (long long)x 与 C++ 中的 (long long)floor(x) 相同吗?

假设我有一个double数据类型,名为“x”的变量。是否有必要将double转换为longlong数据类型与转换为longlongfloor(x)得到相同的结果。 最佳答案 不,这不一样。强制转换截断(向零舍入),floor函数向下舍入。演示:http://ideone.com/k8JuA9#include#includeintmain(){doublex=-1.4;std::cout 关于c++-(longlong)x与C++中的(longlong)floor(x)相同吗?,我们在St

c++ - 有什么方法可以设置 8 字节 (x64) 的 C++ 长类型大小?

GCC使用sizeof(long)=8编译程序,而VisualStudio使用sizeof(long)=4。如何在Windowsx64上将sizeof(long)设置为8字节? 最佳答案 long的实际大小isn'tspecifiedtobeanexactnumberofbytes,只有它必须能够表示的值范围。但是,您可以使用固定宽度的整数std::int64_t这与其他固定宽度整数类型一起在中可用。 关于c++-有什么方法可以设置8字节(x64)的C++长类型大小?,我们在StackO

c++ - 使用 Int 的初始化列表初始化 Long Double 的 vector

假设我有一个简单的类:classPvector{private:std::vectorpoint_list;public:Pvector(std::initializer_listcoords):point_list(coords){}Pvector(std::initializer_listcoords):point_list(coords){}};这将无法编译,因为longdouble模板化的std::vector无法从int类型模板化的初始化列表中初始化自身.然而,这很不方便,因为删除了第二个构造函数后,我无法在我的代码中执行以下操作:Pvectorpiece_movement(

c++ - "integer constant is too large for ‘long’ 求最大质因数时键入"

我正在解决Euler项目3:Description:Theprimefactorsof13195are5,7,13and29.Whatisthelargestprimefactorofthenumber600851475143?这是我生成答案的代码。但是我需要一个整数类型来保存600851475143。当我在Mac上的GCC上编译它时,我得到:integerconstantistoolargefor‘long’type".我预计longlong可以轻松持有这个数字。我也试过让它未签名。为什么我的代码不能保存这么小的数字?我该怎么做才能让它发挥作用?#include#includeusi

c++ - `intmax_t` 在具有 64 位 `long int` 和 `long long int` 的平台上应该是什么?

在C++标准18.4中它指定:typedef'signedintegertype'intmax_t;根据具有64位longint和64位longlongint的平台标准,这个“有符号整数类型”应该是?请注意,longint和longlongint是不同的基本类型。C++标准说:Theheaderdefinesallfunctions,types,andmacrosthesameas7.18intheCstandard.在C标准(N1548)的7.18中,它说:Thefollowingtypedesignatesasignedintegertypecapableofrepresentin

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++ - scanf 与 cin : string as integer processing

我有一个输入字符串“0100”为什么scanf("%i",&n);返回64而cin>>n;给我100?为什么cin以十进制值思考,而scanf以八进制值思考? 最佳答案 Fortheispecifier:  Anynumberofdigits,optionallyprecededbyasign(+or-).Decimaldigitsassumedbydefault(0-9),buta0prefixintroducesoctaldigits(0-7),and0xintroduceshexadecimaldigits(0-f).-sca

c++ - 将 long int* 转换为 long long int*

在我的平台上,longint和longlongint是相同的(64位)。我有一个指向longint的指针,我想将它转换为指向longlongint的指针。以下代码static_cast(pointer);是不允许的。在C++11中执行此操作的正确方法是什么? 最佳答案 你必须强制“重新解释”指针:reinterpret_cast(pointer);这样的转换意味着编译器“停止检查,我知道如何更好地解释该表达式中的二进制数据”。因此,无论何时制作reinterpret_cast-检查您对平台、内存对齐等的了解。编写一些简单的单元测试等

记一次Spring for Kotlin中JacksonConfig配置Long转String失败

目录起因真相解决方案起因众所周知,浏览器在处理Long类型(比如雪花算法生成的id)时,往往会出大事情。浏览器在处理长整型(Long)类型时可能会遇到问题,主要原因是浏览器在处理数字时有限制。一般来说,浏览器的JavaScript引擎使用64位浮点数来表示数字。然而,JavaScript的Number类型只能安全地表示-253到253之间的整数。当超过这个范围时,会有精度丢失的问题。例如,如果使用雪花算法生成的长整型id超过了JavaScriptNumber类型的范围,就会出现问题。雪花算法生成的id是一个非常大的数字,如果直接在浏览器中处理,可能会导致精度丢失或溢出。此外,浏览器在处理长整型

c++ - 缩写类型名称 long long 与 long long int,是否符合标准?

我看到的大多数代码都使用缩写类型来声明变量,例如longlongx;//longlongintxshorty;//shortinty我浏览了C++11标准(第3.9.1节),类型总是完整声明的,如longlongint。我找不到任何关于缩写类型的提及。我很确定这些缩写符合标准,但想确定是否确实如此。所以我的问题是上面的代码是否完全符合标准。 最佳答案 是的,这是有效的,它包含在draftC++11standard中7.1.6.2简单类型说明符部分说:Table10summarizesthevalidcombinationsofsim