1
#include <iostream>
#include <any>

using namespace std;

class c {
public:
    c() :a{ 0 } { cout << "constructor\n"; }
    c(int aa) :a{ aa } { cout << "Constructor\n"; }
    ~c() { cout << "destructor\n"; }
    int get() { return a; }
private:
    int a;
};

auto main()->int
{
    any a{ 5 };
    cout << any_cast<int>(a) << '\n';
    
    a.emplace<c>(3);
    cout << '!' << any_cast<c>(a).get() << '\n';
    //des
    cout << '\n';
    
    a.emplace<c>(9);
    cout << '!' << any_cast<c>(a).get() << '\n';
    //des
}

在每个 any_cast 之后调用的析构函数。并且,下面的代码会导致运行时错误。我认为原因是 any_cast(C) 的工作管道可能就像 ~C() then X(C) ERROR!!C doesn't exist any_cast 真的那样工作吗?

我添加了打击代码并产生了运行时错误。

class X {
public:
    X() :a{ 0 } { cout << "xonstructor\n"; }
    X(c& aa) :a{ aa.get() } { cout << "Xonstructor\n"; }
    ~X() { cout << "Xdestructor\n"; }
    int get() { return a; }
private:
    int a;
};

auto main()->int
{
    any a{ 5 };
    cout << any_cast<int>(a) << '\n';
    
    a.emplace<c>(3);
    cout << '!' << any_cast<X>(a).get() << '\n';
//runtime error after '!'
    cout << '\n';
    
    a.emplace<c>(9);
    cout << '!' << any_cast<X>(a).get() << '\n';
}
4

1 回答 1

2

正在从. _ c_ 该副本在流式传输后在表达式的末尾被销毁。Xstd::any

any_cast不做任何转换。如果您要求它提供与它存储的类型不同的类型,它会抛出。当您放置 ac并要求 a时X,它会抛出std::bad_any_cast,因为Xis not c

于 2021-03-16T09:02:10.690 回答