std::tuple и переместить семантику
Интересно о двух вещах.
1. движется std::tuple
стоит реализовать? Например для std::tuple<int, int, int>
мы что-нибудь получим? Будет ли это быстрее, чем копирование или передача по ссылке?
2. В приведенном ниже примере, есть ли реальная разница между этими двумя?
void print_tuple(const std::tuple<int&&, int&&, int&&> position)
{
int x = std::get<0>(position);
int y = std::get<1>(position);
int z = std::get<2>(position);
std::cout << "x: " << x << " y: " << y << " z: " << z << std::endl;
}
void print_tuple(const std::tuple<int, int, int>&& position)
{
int x = std::get<0>(position);
int y = std::get<1>(position);
int z = std::get<2>(position);
std::cout << "x: " << x << " y: " << y << " z: " << z << std::endl;
}
int main()
{
print_tuple(std::forward_as_tuple(1, 2, 3));
print_tuple(std::move(std::tuple<int, int, int>(4, 5, 6)));
//...
}
2 ответа
Видимо, движется
std::tuple
может дать огромное ускорение. Представьте себе, копированиеstd::make_tuple(std::vector<int>(1000000, 0)¸ std::string(23456, 'H'))
, Заstd::tuple<int, int, int>
перемещение не будет отличаться от копирования. Так,Для кортежа, такого же простого, как у трех целых, вы можете передать его через constref; или по значению вообще, особенно когда фактический аргумент является временным.
std::tuple
уже поддерживает семантику перемещения, поэтому передача данных уже обработана. Если вы хотите хранить свои собственные типы классов, вам необходимо реализовать семантику перемещения для вашего класса, в противном случае вы столкнетесь с операцией копирования для любого типа в вашем кортеже.
Компилятор может оптимизировать перемещение для примитивных типов, таких как целые числа, хотя я не знаком с деталями низкого уровня.
Вы можете посмотреть на реализацию следующего, если хотите поддерживать свои собственные типы классов:
class MyClass
{
MyClass(MyClass&& m);
MyClass& operator =(MyClass&& m);
};