草庐IT

c++ - 我可以依赖 sizeof(uint32_t) == 4 吗?

我知道我可以依赖sizeof(char)==1,但是sizeof(uint32_t)和sizeof(uint8_t)呢??从名字猜大小不应该是32bit(8bit)吗?谢谢! 最佳答案 固定大小的类型总是恰好是那个大小。如果你在一些没有那种大小的整数类型的奇怪平台上,那么它们将是未定义的。请注意,如果CHAR_BIT!=8,则不一定遵循sizeof(uint32_t)==4;同样,这只发生在奇怪的平台上。 关于c++-我可以依赖sizeof(uint32_t)==4吗?,我们在Stack

c++ - 传递右值作为引用

我有一些从svn存储库下载的Qt代码。我已经有一段时间没研究它了,但我确信它曾经可以编译。我有一个新版本的Qt和编译器(我上次使用的)。我当前的编译器是:mingw4.9.232位。所以这是我的问题代码:QByteArraydataBlock=audioTestFile.read(PACKET_SIZE_TO_ENCODE);//Thislineistheissueuint8Vect_ttestVect=encodeData(uint8Vect_t(dataBlock.begin(),dataBlock.end()));地点:typedefstd::vectoruint8Vect_t;

c++ - 从 0 到最大值的 uint64_t 键的最佳哈希函数是什么?

假设我们有一组元素并希望将它们存储在HashMap中(例如std::unordered_set),并且每个元素都有一个uint64_t类型的键其值可以从0到其最大可能值变化,使用普通散列函数是否是最佳选择,其中键的散列值是键本身?它是否取决于使用的容器(即Google的稀疏哈希与来自STL的std::unordered_map)?键值出现的概率未知。 最佳答案 如果您需要散列的只是具有未知概率的任何可能值的uint64_t,并且您的输出必须是uint64_t,那么您不会通过更改该值获得任何优势。只需使用key本身。如果您对值的分布有

c++ - 无法从 uint32_t* 转换为 LPDWORD

我正在尝试调用WindowsAPI函数GetExitCodeProcess,它以LPDWORD作为第二个参数。根据MSDN,LPDWORD是指向无符号32位值的指针。所以我尝试传递uint32_t*,但编译器(MSVC11.0)对此不满意:errorC2664:'GetExitCodeProcess':cannotconvertparameter2from'uint32_t*'to'LPDWORD'static_cast也无济于事。这是为什么?在这种情况下使用reinterpret_cast是否安全? 最佳答案 来自document

C++ 为什么按位运算符 ~ 在 uint64_t 和 uint8_t 上返回不同的类型?

#include#includeintmain(){usingnamespacestd;uint64_ta=3;if(uint64_t(~a)==(~a))cout~uint8_t返回int值,但~uint64_t返回uint64_t。这是未定义的行为吗? 最佳答案 发布自en.cppreferenceTheresultofoperator~isthebitwiseNOT(one'scomplement)valueoftheargument(afterpromotion).Integralpromotion适用于char,short

c++ - 从 std::stringstream 读取 uint8_t 作为数字类型

我的理解是,从stringstream读取uint8_t是一个问题,因为stringstream将解释uint8_t作为char。我想知道如何从stringstream中读取uint8_t作为数字类型。比如下面的代码:#include#includeusingnamespacestd;intmain(){uint8_tui;std::stringstreamss("46");ss>>ui;cout打印出52。我希望它打印出46。编辑:另一种方法是从stringstream中读取一个string,然后将解决方案转换为uint8_t,但这破坏了nice链接属性。比如在我实际要写的代码中,经

c++ - Solaris 9 上的 printf + uint64?

我有一些使用sprintf将uint_64转换为字符串的c(++)代码。这需要可移植到linux和Solaris。在Linux上我们使用%ju,但在Solaris上似乎没有任何等效项。我能找到的最接近的是%lu,但这会产生不正确的输出。一些示例代码:#include#include#ifdefSunOStypedefuint64_tu_int64_t;#endifintmain(intargc,char**argv){u_int64_tval=123456789123L;#ifdefSunOSprintf("%lu\n",val);#elseprintf("%ju\n",val);#e

c++ - unsigned long long 与 uint64_t 冲突?

这个问题在这里已经有了答案:longlongintvs.longintvs.int64_tinC++(3个答案)关闭7年前。我们对某些类型参数使用模板特化classmy_template_class:publicmy_template_class_base{....}classmy_template_class:publicmy_template_class_base{....}这与gcc的64位编译完美配合。而当我们尝试32位模式时,它会报告上述两个类的“先前定义”。所以unsignedlonglong在32位编译中与uint64_t相同,但在64位编译中则不同?编译区别是CXX标志

c# - 在 C# 中将单引号字符串转为 uint

这个问题在这里已经有了答案:WhatdosinglequotesdoinC++whenusedonmultiplecharacters?(5个答案)Singlequotesvs.doublequotesinCorC++(14个答案)关闭9年前。我正在将一些C++代码转换为C#代码,我看到了以下定义:#definex'liaM'首先,这个单引号常量是什么意思?在C#中是否将其设为字符串常量?其次,此常量作为值分配给C++中的uint变量。它是如何工作的?uintm=x;

c++ - 将 uint64_t 转换为 std::string

如何将uint64_t值传输到std::string?我需要构造包含此值的std::string例如这样的事情:voidgenString(uint64_tval){std::stringstr;//.....somecodeforstrstr+=(unsignedint)val;//????}谢谢 最佳答案 在C++11中你可以只使用:std::to_string()它在标题中定义http://www.cplusplus.com/reference/string/to_string/