使用成员函数来处理堆中的对象(c++)
Using member functions to deal with objects in the heap (c++)
我是C++的初学者,这是一个非常基本的语法问题,但我似乎在其他地方找不到答案。欢迎任何意见。这是问题的简化版本。
假设我有一对
class pair
{
int a;
int b;
public:
pair(int x,int y)
{
a=x;
b=y;
}
int lookup()
{
return this->a+b;
}
};
然后我将该实例实例化并复制到堆上的某个位置。
int func()
{
...
pair test(1,2);
pair *ptr=new pair;
*ptr=test;
}
现在是关键。函数结束后,我不会破坏此内存分配。我想稍后在其他函数中使用它。问题是,我宁愿把它放在堆里,而不必把它复制到堆栈中(在实际的程序中,它非常大)。因此,我想做这样的事情:
int otherfunc()
{
...
int sum=*ptr.lookup;
}
但是我得到了一个编译器错误。我最终不得不做这样的事情:
int otherfunc()
{
...
point temp=*ptr;
int sum=temp.lookup;
}
虽然这是有效的,但它是多余的,当处理真正大的事情时,它甚至可能导致溢出。有人知道在将指针保留在堆中的同时使用指针调用方法的语法吗?谢谢
我相信这就是你想要做的:
int sum = ptr->lookup();
顺便说一句,这个:
return this->a+b;
这可能会更好:
return a+b;
表达式*ptr.lookup
将被解释为*(ptr.lookup)
,这就是为什么会出现语法错误,因为ptr.lookup
没有意义。您需要首先使用括号告诉编译器取消引用ptr
:(*ptr).lookup
。
因为指针在C(和C++)中很常见,所以(*a).b
可以用更简单的形式编写:a->b
。
此外,即使lookup
不采用任何参数,它也是一个函数。你需要用()
:来称呼它
int sum=ptr->lookup();
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- CMake-按正确顺序将项目与C运行时对象文件链接
- 空基优化子对象的地址
- 将对象数组的引用传递给函数
- 你能重载对象变量名本身返回的内容吗
- C++使用整数的压缩数组初始化对象
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 将对象移动到std::shared_ptr
- 代理对象的常量正确性
- 提升 ASIO 无法识别计时器对象
- 将Ref对象作为类成员
- 将包含C样式数组的对象初始化为成员变量(C++)
- 如何返回一个类的两个对象相加的结果
- 使用std::函数映射对象方法
- 是否需要删除包含对象的"pair"?
- 如何在自删除后将对象设置为nullptr
- 迭代时从向量和内存中删除对象
- 构造对象的歧义
- 使用"std::unordereded_map"映射到"std::list"对象