Problem22拷貝移動(dòng)構(gòu)造、數(shù)組下標(biāo)重載

2020-08-19

知識(shí)點(diǎn)

調(diào)用拷貝、移動(dòng)構(gòu)造函數(shù)

這里是調(diào)用了Node類型的拷貝構(gòu)造函數(shù)。

void Array::update(int &q, int &r) {
    assert(size>q && size>r);
    Array::nodes[q] = Array::nodes[r];
}

這里調(diào)用了Node類型的移動(dòng)構(gòu)造函數(shù)。
?。?!適當(dāng)使用std::move()

    Node tmp = std::move(nodes[q]);
    nodes[q] = std::move(nodes[r]);
    nodes[r] = std::move(tmp);
}

void Array::insert(int &q, int &r) {
    for(int i = size -1;i>q;i--){
        nodes[i] = std::move(nodes[i-1]);
    }
    nodes[q] = r;
}

實(shí)現(xiàn)拷貝、移動(dòng)構(gòu)造函數(shù)

雖然并不要求對(duì)Array實(shí)現(xiàn)···但是還是應(yīng)該復(fù)習(xí)一下寫(xiě)法······

Array::Array(const Array &y){
    length=y.length;
    data=new Node[length];
    for (int i=0; i<length; i++) {
        data[i]=y.data[i];
    }
}

Array::Array(Array &&y){
    length=y.length;
    data=y.data;
}

數(shù)組下標(biāo)運(yùn)算符重載

這里實(shí)現(xiàn)了一個(gè)數(shù)組下標(biāo)運(yùn)算符的重載。

Node& Array::operator[](int index) {
    assert(size > index);
    return nodes[index];
}

思路&&總結(jié)

先讀題!??!先確定Array類型里面的變量類型、函數(shù)、實(shí)現(xiàn)。再上手寫(xiě)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容