Re[3]: Правомерно ли такое
От: ollv СССР https://youtu.be/DQDoYs6wHoo
Дата: 18.08.20 07:31
Оценка:
Здравствуйте, B0FEE664, Вы писали:

BFE>Здравствуйте, ollv, Вы писали:


  Скрытый текст
M>>>
M>>>template<typename ItemType>
M>>>inline
M>>>std::vector<ItemType>& push_back_helper( std::vector<ItemType> &v, const ItemType &elem )
M>>>{
M>>>    v.push_back(elem);
M>>>    return v;
M>>>}

M>>>inline
M>>>std::vector<int> makeVec( int i )
M>>>{
M>>>    return push_back_helper( std::vector<int>(), i );
M>>>}

M>>>int main()
M>>>{
M>>>    auto v = makeVec( 3 );
M>>>}
M>>>

BFE>
O>> Под gcc будет сигфолт, после передачи инстанса вектора он умрет при свертке стека (а именно после возврата из push_back_helper(std::vector<int>(), ... ) )У майкрософта была какая-то "оптимизация" по продлению жизни ссылки

BFE>Сигфолта не будет, т.к. не скомпилируется.

Да на gcc compile rvalue не ляжет в ссылку. просто майкрософт ведет себя вероломно. Т/к/ он мало того, что компилирует, так еще и без ворнингов (с настройками по умолчанию). Его конечно можно нагнуть, чтобы такое не компилировалось но это опасности не отменяет.

+ к тому есть продление жизни для ссылок — тоже опасное поведение, с такими трюками можно легко запутаться особенно присутствуют сложные вычисления типов
В общем, я могу сказать одно, я такие практики оч не поддерживаю.

такое скомпилируется и может даже имеет какой-то смысл. Но изначально — r& fun(type& v) { return v; }
я пытаюсь избегать, именно по причине того, что майкрософт ведет себя вероломно.

inline
std::vector<int> makeVec( int i )
{
   std::vector<int> r;
   return push_back_helper(r, i );
}


BFE>Но даже если добавить функцию:

BFE>
BFE>template<typename ItemType>
BFE>inline std::vector<ItemType>& push_back_helper( std::vector<ItemType>&& v, const ItemType &elem )
BFE>{
BFE>    v.push_back(elem);
BFE>    return v;
BFE>}
BFE>

BFE>Даже тогда Сигфолта не будет, т.к. std::vector<int>() должен дожить до конца выполнения выражения push_back_helper( std::vector<int>(), i );, которое включает в себя копирование вектора в возвращаемый результат


BFE>
BFE>inline
BFE>std::vector<int> makeVec( int i )
BFE>{
BFE>   return push_back_helper( std::vector<int>(), i );
BFE>}
BFE>


зачем тут мув семантика вообще непонятно. я вообще не понимаю зачем весь этот сырбор, если РВО помогает мейкать вектора и прочие объекты без потерь
все уже сделано в решениях вида std::make_shared_ptr и прочих bind. Параметры муваются, объекты создаются и возвращаются без потерь.
Compiler can be as trained AI but can't compose music.
Antheil piano jazz sonata. Я болен ПГМ.
Отредактировано 18.08.2020 7:43 Маркуша Шулин . Предыдущая версия . Еще …
Отредактировано 18.08.2020 7:41 Маркуша Шулин . Предыдущая версия .
Отредактировано 18.08.2020 7:40 Маркуша Шулин . Предыдущая версия .
Отредактировано 18.08.2020 7:38 Маркуша Шулин . Предыдущая версия .
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.