草庐IT

create_pointer_down

全部标签

c++ - 错误 C4703 : potentially uninitialized local pointer variable 'pNamesPtr' used

我正在做一个加密项目,在尝试编译程序时遇到了以下错误。main.cpp(520):errorC4703:potentiallyuninitializedlocalpointervariable'pNamesPtr'used==========Build:0succeeded,1failed,0up-to-date,0skipped==========DLLNAMES[i].UsedAlready=0;}*dwOutSize=(DWORD)pNamesPtr-(DWORD)pBuffer;//*有人可以帮我解决这个错误吗?您是否需要更多代码才能得到好的答案?

c++ - 哪个 Clang 警告等同于 GCC 的 Wzero-as-null-pointer-constant?

我们的项目使用C++11/14,我们希望使用nullptr而不是0或NULL指针,即使0(作为整数文字)是允许的。我有以下代码:intmain(){int*ptr1=nullptr;//#1int*ptr2=0;//#2}如果我使用GCC(5.3.0)和标记-Wzero-as-null-pointer-constant进行编译,它会在#2中发出警告,但我可以'在Clang中找不到类似的标志。如果我使用Clang(3.7.1)和标志-Weverything编译代码,我不会收到任何关于#2的警告。那么,有什么办法可以在Clang中得到类似的警告吗? 最佳答案

c++ - "The World' s Dumbest Smart Pointer 有什么意义?”

这个问题在这里已经有了答案:Useofobserver_ptr(9个回答)关闭6年前。提案N4282提倡一种称为observer_ptr的新型非拥有智能指针。它的工作名称是exempt_ptr,旨在替代“原始指针”。但我不明白它的目的,尤其是对于它旨在实现的目标的这个假设代码:structdo_nothing{templatevoidoperator()(T*){};//donothing};templateusingnon_owning_ptr=unique_ptr;即使看了文章,我也不明白什么都不做的智能指针的用途。与非拥有的shared_ptr或原始指针相比,它有什么优势?

c++ - X11/Xlib : Create "GlassPane"-Window

我尝试使用C++和X11创建一个完全透明的窗口。它不应消耗任何事件,而只是将它们转发到下面的窗口。某种以Java-Windows闻名的GlassPane,但它是全屏的。然后我想在这个窗口上画画。X11是否有可能做到这一点?我的第一次尝试是忽略所有事件,只需使用XGetImage()从根窗口复制图像...但首先,这非常慢,因为窗口需要填满屏幕。不幸的是,XShmGetImage不是这里的一个选项。当然,这个窗口不需要任何装饰,但这不是什么大问题。仅使用X11/Xlib如何做到这一点?如果不可能,我还需要什么?感谢任何帮助!PS:Xinerama和Compiz都已激活,如果这带来问题,我可

c++ - 练习 : pointers and references in C++

这是正确的吗:a)指向一个字符的指针p1:char*p1;b)指向char的常量指针p2:char*constp2;c)指向常量char的指针p3:constchar*p3;d)指向常量char的常量指针p4:constchar*constp4;e)对char的引用r1:char&r1;f)对常量char的引用r2:constchar&r2;如果有任何错误,请告知我好吗? 最佳答案 他们都是对的。我看不到任何错误:-) 关于c++-练习:pointersandreferencesinC+

c++ - 为什么隐含的 "lambda to function pointer conversion"禁止静态成员的 "by reference"捕获?

C++11标准说(或者至少,我拥有的版本——不是最终版本):Theclosuretypeforalambda-expressionwithnolambda-capturehasapublicnon-virtualnon-explicitconstconversionfunctiontopointertofunctionhavingthesameparameterandreturntypesastheclosuretype’sfunctioncalloperator.我理解为什么无法从有状态lambda中获取函数指针,因为函数指针本身不能保存任何数据。但是当捕获的对象只是一个静态成员/静

c++ - 编译错误 : base operand of ‘->’ has non-pointer type ‘Token’

我在尝试编译我的C++代码时遇到标题中提到的错误。我无法理解我在这里做错了什么。编译器在我执行booloperator==(Token)函数时出现问题。我认为这是使运算符(operator)重载的方法。关于为什么编译器不喜欢我提到的任何线索this->terminal还是this->lexeme?classToken{public:tokenTypeterminal;std::stringlexeme;Token*next;Token();booloperator==(Token&t);private:intlexemelength,line,column;};boolToken::o

docker: Error response from daemon: failed to create shim task: OCI runtime create failed: unable to

1.先下载runc源码:https://github.com/opencontainers/runc/releases/tag/v1.0.32.我的是centos8 运行以下代码yuminstall-ylibseccomp-devel3.安装go环境 wgethttps://studygolang.com/dl/golang/go1.16.linux-amd64.tar.gz tar-C/usr/local-xzfgo1.16.linux-amd64.tar.gz4.添加配置:进去到vi/etc/profileexportGOROOT=/usr/local/goexportGOPATH=/ho

c++ - "*(pointer + integer)"在 C++ 中有什么作用?

我对这个程序中一行代码的作用感到困惑:int*temp=newint[cap];intnum=0;for(inti=name;iname、number和foo是全局变量(foo是指针),cap是一个参数。具体来说,我不明白这一行:*(temp+count)=*(foo+i);为什么会有指向括号的指针,这有什么作用? 最佳答案 *(temp+count)=*(foo+i);+运算符执行指针运算。将一个整数添加到一个指针值会产生一个新指针,该指针在原始指针之后递增了指定数量的对象。例如,如果p是指向arr[0]的指针,则p+2指向arr

c++ - C & C++ : What is the difference between pointer-to and address-of array?

C++11代码:inta[3];autob=a;//bisoftypeint*autoc=&a;//cisoftypeint(*)[1]C代码:inta[3];int*b=a;int(*c)[3]=&a;b和c的值相同。b和c有什么区别?为什么它们不是同一类型?更新:我将数组大小从1更改为3。 最佳答案 sizeof运算符的行为应该有所不同,其中之一,尤其是当您将a的声明更改为不同数量的整数时,例如inta[7]:intmain(){inta[7];autob=a;autoc=&a;std::cout对我来说,这会打印:428那是因