- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在下面的代码中,初始化列表用 B 和 C 对象初始化,其 ctors 分别传入值“bbb”和 333。由于这些对象派生自 A,因此列表正确地创建了两个 A 元素。
#include <string>
#include <vector>
#include <iostream>
struct A
{
char ch;
};
struct B : A
{
B( std::string str ) : str( str ) {}
std::string str;
};
struct C : A
{
C( int num ) : num( num ) {}
int num;
};
struct D
{
D( std::initializer_list< A* > initializerList )
: variadicVect( initializerList )
{}
std::vector< A* > variadicVect;
};
int main()
{
D d { new B { "bbb" }, new C { 333 } };
d.variadicVect[ 0 ]->ch = 'm'; // ok, but accesses base member
//std::cout << d.variadicVect[ 0 ]->str << std::endl; // error C2039: 'str': is not a member of 'A'
//std::cout << d.variadicVect[ 1 ]->num << std::endl; // error C2039: 'num': is not a member of 'A'
return 0;
}
link 中报告了类似的问题由@Jarod42 解决。他确定对象切片是问题所在。为了避免这种按值赋值的问题,我新建了初始化列表对象,但仍然无法访问派生类。
我尝试的另一个尝试是模板化 initializer_list 类型(代码未显示),但我收到此错误:“D::variadicVect”:仅允许静态数据成员模板”
我的目标是能够使用在编译时选择派生类型的各种派生对象来初始化列表,并且能够在运行时正确访问它们。这可能吗?
最佳答案
要使您的代码编译通过,您必须将 vector 元素转换为适当的类型:
std::cout << static_cast<B*>(d.variadicVect[ 0 ])->str << std::endl;
std::cout << static_cast<C*>(d.variadicVect[ 1 ])->num << std::endl;
否则 C++ 将它们视为类型 A,并且只有来自 A 的接口(interface)可用。
其他解决方案是添加虚函数(virtual std::string Str(){return "";}
和 virtual int Num(){return 0;}
) 到 A 并在需要时在基类中覆盖它们。那么你就不必施法了。示例如下:
http://coliru.stacked-crooked.com/a/ed7c73a5d8afa5e9
#include <string>
#include <vector>
#include <iostream>
struct A
{
char ch;
virtual std::string Str() { return ""; }
virtual int Num() { return 0; }
};
struct B : A
{
B( std::string str ) : str( str ) {}
std::string str;
std::string Str() override { return str; }
};
struct C : A
{
C( int num ) : num( num ) {}
int num;
int Num() override { return num; }
};
struct D
{
D( std::initializer_list< A* > initializerList )
: variadicVect( initializerList )
{}
std::vector< A* > variadicVect;
};
int main()
{
D d { new B { "bbb" }, new C { 333 } };
d.variadicVect[ 0 ]->ch = 'm'; // ok, but accesses base member
std::cout << d.variadicVect[ 0 ]->Str() << std::endl;
std::cout << d.variadicVect[ 1 ]->Num() << std::endl;
return 0;
}
关于c++ - 编译时初始化和运行时访问包含派生元素的 initializer_list vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37599782/
我需要使用 initializer_list 来初始化编译时大小的类数组。我已经知道我可以使用参数包构造函数并当场初始化它,但在这种情况下我需要使用 initializer_list。如果可能,我还想
我有一个类构造函数接受一个 initializer_list 这个构造函数必须运行接受一个的父类构造函数 initializer_list>. 所以我必须将初始化列表转换为二维初始化列表。 {1, 2
这个问题在这里已经有了答案: 关闭10 年前。 Possible Duplicate: initializer_list and move semantics 环境:Linux,g++-4.7 我使
以下代码编译并运行: #include #include #include #include void ext( std::initializer_list >> myList ) {
std::vector的初始化列表构造函数具有以下形式 vector( std::initializer_list init, const Allocator& alloc = Allocator()
考虑以下代码片段... void boo(std::initializer_list l) { } template void foo(std::initializer_list l) {
我的问题是关于 std::initializer_list 之间缺乏转换当这些转换看起来很容易实现时,包含的类型或多或少是 cv 限定的类型。 考虑以下无效代码: std::initializer_l
我的图表构造函数: Graph(std::initializer_list list); 我的边缘构造函数: Edge(int out, int in); 我想通过以下方式创建我的图表: Graph
我有一些我想在编译时由需要某种程度验证的初始化列表初始化的类。 我首先尝试使用static_assert,但不会与错误“静态声明的非恒定条件”一起编译 造成此错误的最佳方法是什么? class foo
//parameter pack sum example constexpr int sum(int N= 0) { return N; } template constexpr int su
我是新来的,这是我的第一个问题。 所以,我有这个功能: std::string join(string_initializer_list p_input) const { std::strin
想问一下有没有机会补上引用功能。假设我有功能: double refce( double (&f1)(double), double in ){ return f1(in); } 而不是这样调
所以我昨天尝试开始使用 std::initializer_list 但这并不是一个巨大的成功。这是我最后的尝试之一: #include #include struct XmlState
考虑函数: template void printme(T&& t) { for (auto i : t) std::cout ({'a', 'b', 'c'})); printme(st
考虑函数: template void printme(T&& t) { for (auto i : t) std::cout ({'a', 'b', 'c'})); printme(st
我想用 std::initializer_list 初始化基类。 struct A : public std::array { // This constructor works fine A
基于这段代码 struct Foo { Foo() { cout ilist) { cout 构造函数的大括号初始化中。 相反,复制构造函数带头。 你
尝试为 Node 安装 phash-image 但出现此错误: > phash-image@3.1.0 install /Users/jong/Workspace/mgmtio/phash-image
下面对 foo 的调用是否有效? GCC 似乎对此很满意,而 Clang 为 foo 给出了“无匹配函数”错误;以及无法推断出 N 的注释。 template void foo(const int
我正在尝试使用函数模板 foo 将参数转换为 initializer_list。但是,它转换的 initializer_list 具有与输入参数不同的奇怪值。 #include #include
我是一名优秀的程序员,十分优秀!