簡體   English   中英

用 std::move 分配一個 unique_ptr 不起作用

[英]assigning an unique_ptr with std::move not working

我對 c++ 和智能指針很陌生,但我的理解是我可以用 std::move(another unique_ptr) 分配一個 unique_ptr。 當我嘗試使用 std::move(..) 分配 unique_ptr 時,它會引發以下錯誤:

二進制“=”:未找到采用“std::unique_ptr<T [],std::default_delete<_Ty>>”類型的右側操作數的運算符

以下代碼塊是在倒數第二行引發錯誤的地方。

template<typename T>
void wave::WaveReader::readSamples(std::istream& input, int nr_of_bytes)
{
    std::unique_ptr<T[]> a = std::make_unique<T[]>(this->data_chunk.subChunk2Size);
    input.read(reinterpret_cast<char*>(this->data.data.get()), this->data_chunk.subChunk2Size);
    this->data.length = (this->fmt.bitsPerSample / (nr_of_bytes * 8));
    this->data.width = this->data_chunk.subChunk2Size / (this->fmt.bitsPerSample / 8);
    this->data.data = std::move(a);
    std::cout << sizeof(T) << std::endl;
}

一些額外的代碼:

class WaveReader
{
private:
    RIFFCHUNK riff;
    FMTCHUNK fmt;
    DATACHUNK data_chunk;
    Array<int8_t> data;
    std::variant<Array<int8_t>,Array<uint16_t>,Array<uint32_t>> samples;
public:
    void read(std::string filepath);
private:
    void readSamples(std::istream& input);
    template<typename T>
    void readSamples(std::istream& input,int nr_of_bytes);
    std::string getDataChunkID(DATACHUNK& data);
    void read_RIFFCHUNK(std::istream& input, RIFFCHUNK& riff);
    void read_FMTCHUNK(std::istream& input, FMTCHUNK& fmt);
    void read_DATACHUNK(std::istream& input, DATACHUNK& data, FMTCHUNK& fmt);
};

數組 class 與我試圖分配給 unique_ptr

template <typename T>
struct Array
{
    std::unique_ptr<T[]> data;
    uint32_t length;
    uint32_t width;
    Array(int width, int length) : width(width), length(length)
    {
        data = std::make_unique<T[]>(width);
    }
    Array() : width(0), length(0)
    {
        data = std::make_unique<T[]>(0);
    }
    T operator[](const Position& pos) { return data[(pos.x * length) + pos.y]; }
};

額外代碼:此代碼讀取文件

void wave::WaveReader::read(std::string filename)
{
    std::ifstream file(filename, std::ios::binary);
    //read riff chunk
    read_RIFFCHUNK(file, this->riff);
    //read fmt chunk
    read_FMTCHUNK(file, this->fmt);
    //read data chunk, fills data object
    read_DATACHUNK(file, this->data_chunk, fmt);
    this->readSamples(file);
}

我使用此代碼來確定樣本存儲在什么類型

void wave::WaveReader::readSamples(std::istream& input)
{
    //get Type
    switch (fmt.bitsPerSample)
    {
    case 8:
        readSamples<uint8_t>(input,1);
        break;
    case 16:
        readSamples<int16_t>(input, 2);
        break;
    case 24:
        readSamples<int32_t>(input, 3);
        break;
    case 32:
        readSamples<int32_t>(input, 4);
        break;
    default:
        abort(); // need to change this probably
    }
}

當我將數組結構中的 std::unique_ptr 更改為正常的 int 時,它確實可以正常工作。 當我將其更改為 T 時,它不起作用。

當您執行x = std::move(y)並且y屬於std::unique_ptr<T>類型時,則x也必須屬於std::unique_ptr<T>類型(或指針可隱式轉換的兩種類型)或任務不會工作。 如圖所示,您的代碼只有在Tint8_t時才能工作,因為這就是左邊的內容。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM