使函数参数默认为周围范围
make function argument default to surrounding scope
考虑到下面提供的以下代码/方案,是否可以以某种方式省略指定this
的必要性?
有没有办法更改代码,以便函数/构造函数自动获取周围的范围,甚至可能作为模板参数?
#include <iostream>
class AttrBase{
public:
virtual int g()const = 0;
};
class ABase{
public:
void reg(const char* name, AttrBase* att){
std::cout << name << ": " << att->g()<< std::endl;
}
};
class Attr : public AttrBase{
public:
Attr(const char* name, int val, ABase* parent /* = this */) // something like this
:v(val)
{
parent->reg(name, this);
};
int g()const override{return v;};
int v;
};
class D:public ABase{
Attr a{"a", 1, this};
Attr b{"b", 2, this};
Attr c{"c", 3}; //< is this somehow possible
};
int main(){
D d;
}
您可以向ABase
添加一个成员函数,以便为您创建Attr
。
class ABase{
public:
void reg(const char* name, AttrBase* att) {
std::cout << name << ": " << att->g()<< std::endl;
}
protected:
template <typename AttrType, typename... Args>
AttrType make(Args&&... args) {
return AttrType{std::forward<Args>(args)..., this};
}
};
然后我们可以将其用作
class D:public ABase {
Attr a = make<Attr>("a", 1);
auto b = make<Attr>("b", 2); // works with auto to avoid specifying the type twice
};
相关文章:
- 为什么在全局范围内使用"extern int a"似乎不行?
- 尝试通过多个向量访问变量时,向量下标超出范围
- 错误:未在此范围内声明'reverse'
- 正在将指针转换为范围
- 使用std::transform将一个范围的元素添加到另一个范围中
- 在基于范围的for循环中使用结构化绑定声明
- 如何计算数据类型的范围,例如int
- 为什么 const std::p air<K,V>& 在 std::map 上基于范围的 for 循环不起作用?
- 在C++中查找范围的长度
- 如何设置一个范围来提取我想要获得的信息
- 并行用于C++17中数组索引范围内的循环
- 为左值和右值的包装器实现C++范围
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 关于:C++中异常对象的范围:为什么我没有得到副本?
- 超出范围时使用对象
- 不计算一个范围内的完美数
- ";结果类型必须是可从输入范围的值类型""构造的;创建std::vector时
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 使函数参数默认为周围范围
- 将无符号整数加法/减法括在一个范围周围