草庐IT

T_Unsigned

全部标签

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++ - "signed char"和 "unsigned char"能否始终相互转换而不丢失数据?

在C++中,我们可以使用signedchar和unsignedchar,它们的大小相同但值的范围不同。在下面的代码中:signedcharsignedChar=-10;unsignedcharunsignedChar=static_cast(signedChar);signedChar=static_cast(unsignedChar);无论其原始值是多少,signedchar都会保留其值吗? 最佳答案 不,没有这样的保证。从signedchar到unsignedchar的转换是明确定义的,就像C++(和C)中的所有有符号到无符号整

c++ - unsigned char ** 到 opencv mat

我快到了,但我不太明白如何转换unsignedchar**toacv::Mat我知道cv::Mat的.data部分是uchar*我正在使用一个以...的形式返回和图像的函数unsignedchar**output;但我的其余代码使用cv::Mat的。我也没有我正在使用的库的源代码,所以我真的不知道它在做什么。编辑谢谢大家的帮助,我已经做到了...cv::MatTempMat=cv::Mat(h,w,CV_8UC1,*output);imshow("thisisatest",TempMat);但是图像是黑色的,所以我现在需要查明那里是否真的有任何东西。很抱歉缺乏研究,我的截止日期很紧,不

c++ - 有效地将 unsigned short 转换为 char*

什么是将unsignedshort转换为char*(即将25转换为'25')的高效、可移植的方法。我想避免涉及(std::string)字符串之类的事情。在这种情况下,性能很重要,因为这种转换需要快速且经常发生。我正在研究诸如使用sprintf之类的事情,但想探索任何和所有想法。 最佳答案 首先,正确地做事,然后快速地做事——只有在您确定某段代码性能不佳时才进行优化。snprintf()放入缓冲区将执行您想要的操作。这是最快的解决方案吗?一点也不。但它是最简单的之一,足以让您的代码进入工作状态。从那里开始,如果您发现对snprint

c++ - 将 char 数组转换为 unsigned char*

有没有办法将char[]转换为unsignedchar*?charbuf[50]="thisisatest";unsignedchar*conbuf=//whatshouldIaddhere 最佳答案 尽管从技术上讲它可能不是100%合法的,但这会起作用reinterpret_cast(buf).这在技术上不是100%合法的原因是第5.2.10节expr.reinterpret.cast项目符号7。Apointertoanobjectcanbeexplicitlyconvertedtoapointertoanobjectofadif

c++ - 为类重载 `unsigned` 说明符

我正在尝试定义我自己的数据类型(称为sfloat),它类似于float,但使用不同数量的尾数位和指数位以更好地适应我的数据范围和精度。目标是定义一种新的数据类型,可以替代现有应用程序中的float。到目前为止一切正常,除了我无法重写或定义unsigned运算符使得unsignedsfloat(3.141527)将返回此类的未签名版本,usfloat(3.141527)。似乎unsigned说明符可能能够被重载,因为VSintellisense没有在头文件中提示:sfloat::sfloat(floatf){m_data=get16bit(f);}operatorunsigned(){/

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++ - unsigned 关键字可以以非显而易见的方式使用吗?

每次我使用unsigned关键字时,它都会出现在int或其他内置类型之前。我想知道是否还有其他方法可以使用unsigned。用户定义的类型(类/结构)可以使用unsigned关键字吗?模板可以与unsigned一起特殊使用吗?如果没有,为什么它有自己的关键字?为什么unsignedint不是uint? 最佳答案 主要问题已经多次回答:unsigned关键字只能用作整数类型的类型说明符。至于为什么unsigned是一个单独的关键字,而不是一个uint关键字,其原因是历史性的。C的最早版本(K&R之前)只有四种基本类型:char(8位,

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

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