草庐IT

int_types

全部标签

C++ 错误 : request for member '...' in 'grmanager' which is of non-class type 'GraphicsManager'

这个问题不太可能帮助任何future的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visitthehelpcenter.关闭10年前。我的类GraphicsManager出现错误。图形管理器.cpp:#include"C:\Users\ChrisUzzolina\Desktop\obj\include\GraphicsManager.h"#include#includeGraphicsManager::GraphicsManager(intSCREEN_WIDTH,intSCREEN_

java - 将原生 uint8_t(Java 字节)转换为 int

我有一个native函数(来自库),它对uint8_t类型(无符号8位数字0-255)执行一些操作。Java最接近的是byte,它必须被签名。如何将此字节转换为正确的正整数以便在Java中使用?我知道我必须将它存储在short或int中才能正确表示0-255之间的数字,但我不知道如何转换byte.我尝试了intintValue=byteValue&0xFF;,但这给了我意想不到的结果,所以我怀疑它不正确。或者这是正确的,我误解了native库函数的预期结果。无论哪种方式,都将不胜感激。 最佳答案 在Java中,您可以使用Guava库

c++ - iterator_traits<InIter>::value_type 的创建是否会在传递时触发遵从? (异常测试)

我在故意为不特别遵守迭代器的函数抛出异常(出于测试目的)时遇到了麻烦。要了解我在做什么,请带上我的decorator_iterator结构:structdecorated_iterator:boost::iterator_adaptor,BaseIterator,boost::use_default,IteratorTag>{//....private:friendclassboost::iterator_core_access;/*usedtothrowanexceptionupondereference*/typenamebase_type::referencedereferenc

c# - 为什么 Array.Length 是一个 int,而不是一个 uint

这个问题在这里已经有了答案:Whydoes.NETuseintinsteadofuintincertainclasses?(7个答案)关闭9年前。为什么Array.Length是int,而不是uint。这让我很困扰(有点),因为长度值永远不会是负数。这也迫使我在自己的类中使用int作为长度属性,因为当你指定一个int值,这需要显式转换...所以最终的问题是:unsignedint(uint)有什么用吗?甚至微软似乎也不使用它们。

c++ - boost::lexical_cast<std::string>(Int_Type) 可以抛出吗?

有没有可能boost::lexical_cast(Int_Type)扔?我唯一能想到的是字符串没有内存的地方,但是还有其他更合理的选择吗? 最佳答案 根据documentation,lexical_cast可以扔bad_lexical_cast.最重要的是,正如您已经提到的,可能存在动态分配,它总是会导致bad_alloc异常。编辑:至于具体情况lexical_cast,除了分配错误之外,链上的任何部分似乎都不太可能失败,但文档并不(据我所知)保证不会出现“错误转换”异常。 关于c++-

c++ - std::atomic 将一对原子 int32 视为一个原子 int64?

我有一对unsignedint32std::atomic_start;std::atomic_end;有时我想通过比较交换来设置开始或结束,所以我不希望在整个64位对上使用CAS可能导致虚假故障。我只想使用32位CAS。_end.compare_exchange_strong(old_end,new_end);现在我可以将开始和结束作为一个64位原子读取来获取。或者两个单独的32位读取。执行一次64位原子提取(编译器添加适当的内存栅栏)而不是使用两个内存栅栏进行两次单独的32原子位读取(或者编译器会优化它吗?)会不会更快?如果是这样,我将如何在C++11中做到这一点?

c++ - C++ 中将默认变量类型设置为 int 的任何选项

在c++代码中是否有任何选项省略变量类型或将变量类型设置为int以使用g++编译器编译Linux.constbufLen=2000;在solaris中编译顺利(因为我正在从solaris移植到linux)。还有一件事,我无法控制文件,因为它是由某些解析器生成的(由某些第三方以二进制形式提供)由于我无法更改c++文件(因为它每次在编译前生成),我需要一些选项(g++)以便我可以在编译期间包含以抑制/解决错误:error:ISOC++forbidsdeclarationof`bufLen`withnotype编辑:INFO:目前我正在使用的选项-c-fPIC-Wno-deprecated-

c++ - 在 C/C++ 中将非常大的 int(写为字符串)转换为二进制字符串

我有一个基数为10的数字,大约有10k位。我想将它转换成基数2(1010101001...)。我能想到的就是原始算法:取最后一位mod2->记下位数字除以2;在字符串上实现小学分部应该不难,但我认为它非常低效。如果我是对的,它将是O(l^2),其中l表示以10为基数的数字长度。可以更快地完成吗? 最佳答案 据我了解,您的大数字表示为十进制数字序列。如果是这样,您可以使用乘法和加法计算“二进制”表示:value=sum(iin0...n-1)10i*digiti此计算可以分而治之的方式拆分成多个部分,但我不确定您是否可以得出O(nlo

C++11 : unique_ptr complains about incomplete type, 但是当我包装它时不是

SO上已经有很多关于unique_ptr和不完整类型的问题,但没有一个能给我一个概念来理解为什么以下内容不起作用://error:...std::pair::secondhasincompletetypetemplatestructImpl{typedeftypenamestd::unordered_map>::iteratoriter_type;std::unique_ptrptr;Impl():ptr(newiter_type()){}};intmain(){Impl();return0;}而以下是:templatestructImpl{structWrapper{typedeft

c++ - Type t = Type() 是否调用复制构造函数?

我真的很困惑....Typet=Type()是否调用复制构造函数?我问是因为当我尝试时:#includeclassTest{public:Test(Testconst&){std::cout什么都没有输出,但是当我把它改成#includeclassTest{Test(Testconst&){std::cout我得到:errorC2248:'Test::Test':cannotaccessprivatememberdeclaredinclass'Test'这没有意义(特别是因为这是一个调试版本)。更新:即使这样也可以编译!structTest{Test(Test&&)=delete;Te