无法手动调用std :: string的析构函数

时间:2019-04-28 16:35:28

标签: c++

我正在尝试使用工会,并使用匿名工会成员将此示例类设置为A。由于联合包含一个std::string和一个std::vector,因此我需要为该类定义一个析构函数。但是,当我尝试手动致电~string()时,我得到了

union.cpp: In destructor 'A::~A()':
union.cpp:14:14: error: expected class-name before '(' token
    s_.~string();

我不了解这个问题。如果我删除对s._~string();的调用,它将编译正常。这是编译器错误吗?我正在使用MinGW64。

#include <string>
#include <vector>

class A
{
    public:
    explicit A(const std::string &s) : s_ {s}, is_string {true} {}
    explicit A(const std::vector<int> &v) : v_ {v}, is_string {false} {}

    ~A()
    {
        if (is_string)
            s_.~string();
        else
            v_.~vector();
    }

    private:
    union
    {
        std::string s_;
        std::vector<int> v_;
    };
    bool is_string;

};

int main()
{
    A a("Hello, World!");
    return 0;
}

使用std::delete_at(std::addressof(s_))可以与-std=c++17一起使用。这是怎么回事?

1 个答案:

答案 0 :(得分:7)

std :: string不是实类型,而是typedef。

using std::string = std::basic_string<char>;

因此,您需要调用basic_string析构函数。

~A()
{
    if (is_string)
        s_.~basic_string();
    else
        v_.~vector();
}