草庐IT

Int_Smart_Pointer

全部标签

c++ - GCC 7,aligned_storage 和 "dereferencing type-punned pointer will break strict-aliasing rules"

我编写的代码在GCC4.9、GCC5和GCC6中没有警告。它在一些较旧的GCC7实验快照(例如7-20170409)中也没有警告。但在最近的快照(包括第一个RC)中,它开始产生关于别名的警告。代码基本上可以归结为:#includestd::aligned_storage::typestorage;intmain(){*reinterpret_cast(&storage)=42;}使用最新的GCC7RC编译:$g++-Wall-O2-cmain.cppmain.cpp:Infunction'intmain()':main.cpp:7:34:warning:dereferencingtyp

c++ - 安全地将 int 转换为枚举

我想知道是否有任何巧妙的技巧可以安全地将整数转换为枚举。在您投票认为这是重复之前,我不是在问如何转换(inti;Enume=static_cast(i)很简单)。我问的是如何安全地执行此操作,验证结果值确实在枚举中。代码如下enumclassE{A=1,B=2};intmain(int,char**){inti=3;Ee=static_cast(i);}将编译(AFAIK)但是e将不包含枚举中的有效值。我想到的最好的方法是类似switch(i){case1:returnE::A;case2:returnE::B;default:throwinvalid_argument("");}哪个

c++ - 模板化的 Pointer 类可以有一个虚拟析构函数吗?

在使用自制指针类实现pimpl惯用语时,我遇到了一个令人惊讶的启示(我知道:为什么要自己动手?但请耐心等待)。以下三个文件包含一个最小示例:指针.h:#pragmaoncetemplateclassPointer{public:Pointer(T*p=0):_p(p){}virtual~Pointer(){delete_p;}private:voidoperator=(constPointer&);Pointer(constPointer&);private:T*_p;};Foo.h:#pragmaonce#include"Pointer.h"structFoo{Foo();~Foo(

c++ - 获取 std::set 元素地址时从 ‘const int*’ 到 ‘int*’ 的无效转换

我收到以下错误error:invalidconversionfrom‘constint*’to‘int*’以下是我的程序#includeintmain(intargc,char**argv){std::setintSet;intSet.insert(1);intSet.insert(2);intSet.insert(3);intSet.insert(4);intSet.insert(5);int*pAddress=&(*(intSet.find(4)));}我想要std::set中元素的地址,此代码不会给Microsoft编译器带来任何编译错误,但g++会给出此编译错误。

c++ - 在C++中将int转换为16位 float (半精度 float )

我如何将一个整数转换为一个半精度float(它被存储到一个数组unsignedchar[2]中).输入int的范围是1-65535。精度真的不是问题。我正在做类似的事情,将16bitint转换为unsignedchar[2],但我知道没有halfprecisionfloatC++数据类型。以下示例:int16_tposition16int=(int16_t)data;memcpy(&dataArray,&position16int,2); 最佳答案 这是一件非常简单的事情,您需要的所有信息都在Wikipedia中。.示例实现:#in

c# - 如何将指针编码为指向 int 的指针?

非托管C++:intfoo(int**New_Message_Pointer);我如何将其编码到C#?[DllImport("example.dll")]staticexternintfoo(???); 最佳答案 你可以这样声明函数:[DllImport("example.dll")]staticexternintfoo(IntPtrNew_Message_Pointer)要调用此函数并将指针传递给int数组,例如,您可以使用以下代码:Int32[]intArray=newInt32[5]{0,1,2,3,4,5};//Alloca

c++ - 将 int 值添加到 double 时是否有性能优势/惩罚?

给定vector加法:NPNumberNPNumber::plus(constdoubleo)const{vectorc;for(doublea:values)c.push_back(a+o);returnNPNumber(width,c);}如果NPNumber包含一个doublevector(字段值),当我只添加一个整数而不是另一个NPNumber时,与转换该整数并使用上面的函数相比,是否有性能优势或损失?也就是说,这在任何架构上是更快还是更慢:NPNumberNPNumber::plus(constinti)const{vectorc;for(doublea:values)c.p

c++ - int 参数为 : conditional expressions ignored? 的意外模板行为

以下代码未按预期工作(或至少如我所料)。我尝试的所有g++版本都在模板递归限制下失败。输出似乎表明条件语句被忽略,并且无论P的值如何都使用最后的elseblock。templateinlineREALconst_pow(REALvalue);templateinlineREALconst_pow(REALvalue){return1.0;}templateinlineREALconst_pow(REALvalue){returnvalue;}templateinlineREALconst_pow(REALvalue){returnvalue*value;}templateinlineR

c++ - Clang 提示 : "pointer is initialized by a temporary array"

我有一个不同长度的(指向)数组的数组,我了解到我可以使用复合文字来定义它:constuint8_t*constminutes[]={(constuint8_t[]){END},(constuint8_t[]){1,2,3,4,5END},(constuint8_t[]){8,9,END},(constuint8_t[]){10,11,12,END},...};gcc很好地接受了这一点,但clang说:指针由一个临时数组初始化,它将在完整表达式结束时被销毁。这是什么意思?代码似乎可以正常工作,但话又说回来,许多事情似乎在指向不再分配的内存时可以正常工作。这是我需要担心的事情吗?(最终我真

c++ - 在 C++ 中是否有类似的方法从 stdin 读取整数对到 vector<pair<int,int>>

我想知道有没有像下面这样巧妙的方法copy(istream_iterator(cin),istream_iterator(),back_inserter(v));复制成对的int进入vector>当输入按出现顺序成对给出时?谢谢。 最佳答案 boost::zip_iterator可以使用。copy(boost::make_zip_iterator(boost::make_tuple(istream_iterator(cin),istream_iterator(cin)),boost::make_zip_iterator(boost: