質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

2回答

3339閲覧

【C++】 vector<unique_ptr<int>>にpush_backしたい

torimingo

総合スコア122

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2019/04/13 01:49

編集2019/04/13 01:49

vector<unique_ptr<int>>に、push_backしたいのですができません。
以下のコードで、intsにiをpush_backしたいです。

c++

1#include<memory> 2#include<vector> 3 4int main() 5{ 6 std::vector<std::unique_ptr<int>> ints; 7 8 std::unique_ptr<int> i; 9 i.reset(new int); 10 11 // コンパイルエラーになってしまう 12 ints.push_back(i); 13 14 return 0; 15}

以下は、コンパイルエラーの抜粋です。(全くわかりません・・・)

c++

1/usr/include/c++/7/ext/new_allocator.h:136:4: error: use of deleted function ‘std::unique_ptr<_Tp, _Dp>::unique_ptr(const std::unique_ptr<_Tp, _Dp>&) [with _Tp = int; _Dp = std::default_delete<int>]2 { ::new((void *)__p) _Up(std::forward<_Args>(__args)...); }

どうしたらいいのでしょうか・・・。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

push_back+std::moveでもいいのですがもっとシンプルに効率的にするには

cpp

1#include<memory> 2#include<vector> 3 4int main() 5{ 6 std::vector<std::unique_ptr<int>> ints; 7 ints.emplace_back(std::make_unique<int>()); 8}

投稿2019/04/13 02:44

yumetodo

総合スコア5850

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

torimingo

2019/04/13 03:38

ご回答ありがとうございました。 make_uniqueを使うという方法もあるのですね。 勉強させて頂きました。
yumetodo

2019/04/13 04:13

むしろnewすらも書くべきではないですね
torimingo

2019/04/13 04:26

なるほど、make_uniqueはunique_ptr用のnewってことですね
guest

0

ベストアンサー

unique_ptr はコピーできんからフツーにpush_backできない。

C++

1#include <memory> 2#include <vector> 3#include <utility> 4#include <iostream> 5 6int main() { 7 std::vector<std::unique_ptr<int>> ints; 8 9 // do this 10 for ( int i = 0; i < 10; ++i ) { 11 ints.push_back(std::make_unique<int>(i)); 12 } 13 14 // or this 15 for ( int i = 0; i < 10; ++i ) { 16 ints.emplace_back(new int(i)); 17 } 18 19 // かくにん 20 for ( auto& item : ints ) { 21 std::cout << *item.get() << ' '; 22 } 23 return 0; 24}

呈示された元コードを活かすなら:

C++

1#include<memory> 2#include<vector> 3#include <iostream> 4 5int main() { 6 std::vector<std::unique_ptr<int>> ints; 7 8 for ( int i = 0; i < 10; ++i ) { 9 std::unique_ptr<int> up; 10 up.reset(new int(i)); 11 ints.push_back(std::move(up)); // std::moveせよ 12 } 13 14 // かくにん 15 for ( auto& item : ints ) { 16 std::cout << *item.get() << ' '; 17 } 18 19 return 0; 20}

vector<int*> を使っても構わんけど、リークの要因になるからオススメしない。

C++

1#include<memory> 2#include<vector> 3#include <iostream> 4 5int main() { 6 std::vector<int*> ints; 7 8 for ( int i = 0; i < 10; ++i ) { 9 ints.push_back(new int(i)); 10 } 11 12 // かくにん(と解放) 13 for ( int* item : ints ) { 14 std::cout << *item << ' '; 15 // これ↓を忘れがちだからポインタの集合はお薦めしかねる 16 delete item; 17 } 18 19 return 0; 20}

投稿2019/04/13 02:28

編集2019/04/13 02:42
episteme

総合スコア16614

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

torimingo

2019/04/13 03:37

ご回答ありがとうございました。 move()が必要なのですね。勉強になります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問