草庐IT

Pointers

全部标签

c++ - 在以抽象基类为参数的函数中将指针和赋值运算符与派生类一起使用

我有一个函数(modShape),它接受一个抽象基类(Shape)作为参数;在函数中,我想制作输入对象的拷贝,修改拷贝,然后将拷贝重新分配给输入对象,以便修改保留在modShape的范围之上。我已经设置了一个clone()成员函数来制作初始拷贝,它似乎运行良好。接下来,我使用doubleArea()成员函数修改拷贝,并尝试将其复制回输入对象。基类和派生类在header.h中定义:#ifndefHEADER_H_#defineHEADER_H_#include#includeusingnamespacestd;//Abstractbaseclass.classShape{public:/

c++ - 这种多重间接是如何工作的?

#include#includeusingnamespacestd;intmain(){inti=10,j=20,k=30;int*ip1,*ip2,**ipp;ip1=&i;ip2=&j;ipp=&ip1;*ipp=ip2;*ipp=&k;cout行cout打印30到控制台,任何人都可以解释如何?输出是-302030我在期待-102030我不知道在这种情况下多重间接寻址是如何工作的。 最佳答案 Thelinecout因为你通过ipp(指针的指针)改变了ip1的值,从指向i,变成指向j,最后指向k。ipp=&ip1;//makeip

c++ - 在 C++ 中将 char* 转换为 const char*

C++中如何将char*转换为constchar*?为什么程序1可以运行而程序2不能运行?程序1(工作):char*s="teststring";constchar*tmp=s;printMe(tmp);voidprintMe(constchar*&buf){printf("GivenStr=%s",buf);}程序2(不工作)char*s="teststring";printMe((constchar*)s);//typecastingnotworkingvoidprintMe(constchar*&buf){printf("GivenStr=%s",buf);}我收到的错误:x.c

c++ - 在析构函数 C++ 中删除指针

我正在使用图书馆的类(class)。设A,它有一个字符指针“token”我的代码:voidsomeFunction(){Aa;cout[1]为什么会失效:A类如下:classA{char*token;public:A(){token=GetRandomToken();//GetRandomTokenwillreturna'newChar'array}~A(){if(token!=NULL){delete[]token;//itisA'sresponsibilitytodeletethememoryitcreatedtoken=NULL;}}};在anotherFunction中调用co

C++ 适当的指针成员初始化

我是C++新手,有Java背景。我有一个类原型(prototype),它设置了两个私有(private)指针对象成员。classDriveController:Controller{public:DriveController(int8_tportTL_,int8_tportTR_,int8_tportBL_,int8_tportBR_,doublewheelSize_,doublebaseSize_);private://Internalchassiscontrollerokapi::ChassisControllerIntegrated*chassisController;okap

c++ - 在数组 dna 中的每个对象中获取相同的字符串(基因数组)(动态分配)

我创建了一个名为DNA的类,它有一个无参数构造函数和两个成员函数,即initialize()和show()。问题是当我创建一个使用new运算符的数组并使用for循环调用每个对象的初始化函数,而不是在成员变量“genes”中获取不同的字符串,我在每个对象的基因中获取完全相同的字符集(数组)阵列。尽管我在字符串初始化之前对srand()函数进行了播种,但没有看到任何效果。下面的代码。#include#include#include#includeusingnamespacestd;stringsampleSpace("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghij

c++ - gcc 相对于在新表达式中解析 type-id 发出错误

这个程序#includeintmain(){conststd::size_tN1=2;conststd::size_tN2=3;int(**p)[N1]=new(int(*[N2])[N1]);}doesnotcompile使用编译器C++gccHEAD10.0.020190。编译器报错prog.cc:Inlambdafunction:prog.cc:8:40:error:expected'{'before')'token8|int(**p)[N1]=new(int(*[N2])[N1]);|^prog.cc:Infunction'intmain()':prog.cc:8:34:err

c++ - 基本问题 : Pointers to objects in unordered_maps (C++)

我是C++编程的新手,非常感谢没有假定太多先验知识的回复。感谢这里的建议,我创建了一个无序map:typedefstd::tr1::unordered_maphmap;此映射中的数据是指向Strain类实例的指针。一旦创建了这些实例,我就创建了指向它们的指针,然后将这些指针添加到我的哈希表(hmapstrainTable)和另一个vector(vectorliveStrains),例如,stringMRCA;for(intb=0;bStrain类的实例永远不会被删除,指向它们的指针也不会从strainTable中删除。指针偶尔会在vectorliveStrains和vectordead

c++ - 取消引用指针(并返回它)的问题

这里我有一个函数,它创建一个字符串,将它分配给一个字符串指针,然后返回它。我尝试返回一个常规字符串,但效果很好。但是当我整合指针并取消引用它们时,我的程序崩溃了。当我尝试调试它时,这是我收到的消息:Assignment2.exe中0x00024cbf处的未处理异常:0xC0000005:读取位置0xcccccce4的访问冲突。这是我的代码:string*Recipe::getCookingTime()//@intput:none//@output:cookingtimeasastring{stringtemp;stringdisplayHrs;stringdisplayMins;if(

c++ - 肯定是无效的指针范围

我看过一些像http://boost.2283326.n4.nabble.com/shared-ptr-segfaults-on-64bit-AMD-td2560441.html这样的帖子专家可以在其中查看指针地址并立即说它无效。我猜想这些指针位于进程虚拟内存的一些已知保留位置。上面链接中的示例是0x90。这里有人知道linux上gcc/g++肯定无效的指针范围吗?0xd8怎么样? 最佳答案 虽然您不应该编写依赖于此的代码,但0x1000以下的指针几乎总是无效的。熟悉操作系统的默认内存映射将解释原因,并让您更深入地了解“正常”指针的