Конструктор объекта C++ с временным объектом в качестве аргумента

Я написал некоторый код, и мне вдруг пришло в голову, что то, что я делаю, может быть действительно плохой идеей. Вот своего рода абстрактный пример. Ключевым моментом является передача по ссылке вектора.

// vector.hpp
class vector {
    vector(double x, double y, double z);
}

// particle.hpp
class particle {
    particle(const vector& _init_position);
    vector m_position;
}

Итак, я написал код для представления class vector, который содержит 3D векторные вещи, а также записал класс частиц, вектор положения которого можно инициализировать с помощью конструктора и экземпляра вектора.

В моем main() Функция, я использовал временный объект для инициализации объектов частиц, например, так:

int main() {

    particle my_particle(vector(0.0, 1.0, 2.0)); // Temp vector instance - problem?
}

Здесь вы можете видеть, что создается временный экземпляр вектора, я предполагаю, что он где-то помещается в стек, а затем вызывается конструктор частицы.

Это нормально или это пример очень плохого кода? Я подозреваю, что последнее, так как я передаю по ссылке, и, следовательно, экземпляр временного вектора может быть недействительным?

Надеюсь, кто-нибудь сможет уточнить это?

2 ответа

Решение

Вам разрешено передавать временный объект в функцию либо в качестве значения, либо в качестве ссылочного параметра const. Это хорошо, так как вы можете сохранять копии при передаче по константной ссылке.

Вы не показываете реализацию векторного конструктора, но член является значением, поэтому я предполагаю, что конструктор копирует свой аргумент в член. Если это так, то передача const ref - это именно то, что вы хотите сделать, чтобы избежать ненужных копий.

То, что вы не хотите делать, это удерживать ссылку (или адрес) этого аргумента.

Другие вопросы по тегам