次スレを立てる時は本文の1行目に以下を追加して下さい
!extend:on:vvvvv:1000:512
C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレにお願いします。
前スレ
C++相談室 part130
http://mevius.2ch.net/test/read.cgi/tech/1490917669/
このスレもよろしくね。
【初心者歓迎】C/C++室 Ver.100【環境依存OK】
http://echo.2ch.net/test/read.cgi/tech/1478440682/
■長いソースを貼るときはここへ。■
http://codepad.org/
https://ideone.com/
[C++ FAQ]
https://isocpp.org/wiki/faq/
http://www.bohyoh.com/CandCPP/FAQ/ (日本語)
-
VIPQ2_EXTDAT: default:vvvvv:1000:512:----: EXT was configured
VIPQ2_EXTDAT: default:vvvvv:1000:512:----: EXT was configured
探検
C++相談室 part131 [無断転載禁止]©2ch.net
レス数が1000を超えています。これ以上書き込みはできません。
1デフォルトの名無しさん 転載ダメ©2ch.net (ワッチョイ 3b96-ov1m)
2017/07/29(土) 11:28:28.97ID:o30VDF4g0910デフォルトの名無しさん (ワッチョイ b632-rzHd)
2017/10/07(土) 08:31:55.56ID:r58+Koxz0 あ、すまんちょいミスった
指摘できるやついる?解説頼むわ
指摘できるやついる?解説頼むわ
911デフォルトの名無しさん (ワッチョイ aa9b-ucRI)
2017/10/07(土) 08:41:11.20ID:eyY86HOM0912デフォルトの名無しさん (ワッチョイ dab3-Nz6W)
2017/10/07(土) 09:00:22.02ID:y2Dkbadu0913デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 09:03:55.62ID:7nonADk70 unique_ptr<void>という型なので、
中にtypeというメンバーがあることがコンパイラからはわからない。
static_cast<Structure*>(structure.get())->type = "HogeHoge";
のように明示すればコンパイルだけは通るかと思ったんだが、
こっちだと>>911の問題に引っかかって、その前の行でエラーになる。
中にtypeというメンバーがあることがコンパイラからはわからない。
static_cast<Structure*>(structure.get())->type = "HogeHoge";
のように明示すればコンパイルだけは通るかと思ったんだが、
こっちだと>>911の問題に引っかかって、その前の行でエラーになる。
914デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 09:27:45.88ID:7nonADk70 >>913の最後の行は勘違いだった。
こちらの環境だと、unique_ptr<void>の時点でエラーになる。
こちらの環境だと、unique_ptr<void>の時点でエラーになる。
916デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 11:58:47.95ID:rHfSD+zL0 >>913
delete できないからね
voidを渡すんならカスタムデリータもセットにしなきゃならない。
template <typename T>
struct vp_deleter {
void operator ()(void *p)const
{
delete static_cast<T*>(p);
}
};
std::unique_ptr<void, vp_deleter<int>> a(new int(8));
なら通った。
delete できないからね
voidを渡すんならカスタムデリータもセットにしなきゃならない。
template <typename T>
struct vp_deleter {
void operator ()(void *p)const
{
delete static_cast<T*>(p);
}
};
std::unique_ptr<void, vp_deleter<int>> a(new int(8));
なら通った。
917デフォルトの名無しさん (ブーイモ MMfa-0mrS)
2017/10/07(土) 12:19:56.83ID:jvf7kHO4M void型なんて定義もなければサイズもないから
素で使うがそもそもNG
素で使うがそもそもNG
918デフォルトの名無しさん (ワッチョイ 1ab3-3Fj1)
2017/10/07(土) 12:36:08.56ID:6wfQSWva0 >>907
anyは知りませんでした
stdじゃなくてboostにあるんですね つかってみます
>>909
つまり void*->type は void.type になるってことですね
voidポインタは使ったことなくて、あれから調べたのですが
アクセスする前にキャストが必要だと知りました・・
無知ゆえの初歩的なミスです 指摘ありがとうございます
>>911, >>913, >>916
スマートポインタなのでデストラクタを呼び出せるようにしないといけないんですね
カスタムデリータは知りませんでした コード参考になります
void型なのはStructureの他にもプリミティブ型とかも入れたかったからです
boost::any使うやり方とカスタムデリータ渡すやり方両方やってみます
皆さんレスありがとうございました
anyは知りませんでした
stdじゃなくてboostにあるんですね つかってみます
>>909
つまり void*->type は void.type になるってことですね
voidポインタは使ったことなくて、あれから調べたのですが
アクセスする前にキャストが必要だと知りました・・
無知ゆえの初歩的なミスです 指摘ありがとうございます
>>911, >>913, >>916
スマートポインタなのでデストラクタを呼び出せるようにしないといけないんですね
カスタムデリータは知りませんでした コード参考になります
void型なのはStructureの他にもプリミティブ型とかも入れたかったからです
boost::any使うやり方とカスタムデリータ渡すやり方両方やってみます
皆さんレスありがとうございました
919デフォルトの名無しさん (スップ Sdda-99fN)
2017/10/07(土) 13:41:40.48ID:j+yonEy7d ひとつのカスタムデリータでいろんな型をdeleteするってなら無理
920デフォルトの名無しさん (ワッチョイ 6e8a-+XcG)
2017/10/07(土) 14:16:25.95ID:LB5EP+Z/0 いまだにforkとthreadの動作の違いがわからない
921デフォルトの名無しさん (ブーイモ MMfa-0mrS)
2017/10/07(土) 14:17:50.50ID:jvf7kHO4M ある配列がありそれを指定した順番で並び替えしたい
std::vector< any_struct_t > array; //これを並び替えたい
std::vector< unsigned int > index_list = { 3,8,6,0,2...}; //この順番にしたい
探しているんだけど適当なライブラリが見つからない
標準ライブラリに入ってたりする?
またはアルゴリズムが知りたい
出来ればswap回数が少ない方法が知りたい
std::vector< any_struct_t > array; //これを並び替えたい
std::vector< unsigned int > index_list = { 3,8,6,0,2...}; //この順番にしたい
探しているんだけど適当なライブラリが見つからない
標準ライブラリに入ってたりする?
またはアルゴリズムが知りたい
出来ればswap回数が少ない方法が知りたい
922デフォルトの名無しさん (ササクッテロリ Sp75-o/K3)
2017/10/07(土) 15:34:33.81ID:cqowZFEsp 配列もう一個用意してその添え字に移動するんじゃだめなん
923デフォルトの名無しさん (ワッチョイ 7d81-XSap)
2017/10/07(土) 16:00:10.47ID:ZvmF6v7F0 >>922
それが一番速そうだよね
それが一番速そうだよね
924デフォルトの名無しさん (ワントンキン MMea-zCRe)
2017/10/07(土) 16:14:50.00ID:Mcd7mBScM std::vector<any_struct_t> ret(index_list);
std::transform(index_list.cbegin(), index_list.cend(), ret.begin(), [&array](auto i){ return array[i]; });
std::transform(index_list.cbegin(), index_list.cend(), ret.begin(), [&array](auto i){ return array[i]; });
925デフォルトの名無しさん (ブーイモ MMfa-0mrS)
2017/10/07(土) 16:25:34.07ID:jvf7kHO4M >>924
それタイプミスあります?
でももう一つ配列を用意してコピーする点では
他の方と一緒ですね
別配列を用意せず全てswapで済ます方法も作ってみましたが
これにはindex_listが更に2本必要になり
効率は別配列と変わらないと予想される結果でした
参考になりました
ありがとうございました
それタイプミスあります?
でももう一つ配列を用意してコピーする点では
他の方と一緒ですね
別配列を用意せず全てswapで済ます方法も作ってみましたが
これにはindex_listが更に2本必要になり
効率は別配列と変わらないと予想される結果でした
参考になりました
ありがとうございました
926デフォルトの名無しさん (ワントンキン MMea-zCRe)
2017/10/07(土) 16:38:58.22ID:Mcd7mBScM 一行目初期化はsizeだった
すまん
すまん
927デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 16:55:14.57ID:rHfSD+zL0928デフォルトの名無しさん (ワッチョイ 5593-Xc0J)
2017/10/07(土) 17:23:03.40ID:9j2tI+ab0 index_list に含まれる値がそれぞれ重複なく1回だけ出現とか、
いかにも破られそうな条件を暗黙に期待するライブラリ、
てのも変な感じだしねぇ。
いかにも破られそうな条件を暗黙に期待するライブラリ、
てのも変な感じだしねぇ。
929デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 17:39:38.90ID:7nonADk70 任意の置換は互換の積で表せるので、swap繰り返せばin-placeで可能。
http://rikei-index.blue.coocan.jp/senkei/teigi4senkei.html
http://rikei-index.blue.coocan.jp/senkei/teigi4senkei.html
930デフォルトの名無しさん (ワッチョイ 5504-CLk5)
2017/10/07(土) 17:47:14.55ID:IjrnmnS30931デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 18:00:13.73ID:rHfSD+zL0 >>929
まだやってない場所どこだっけ?
まだやってない場所どこだっけ?
932デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 18:14:41.26ID:7nonADk70 >>927
「別領域を全く使わず」を見落としてたすまぬ
「別領域を全く使わず」を見落としてたすまぬ
933デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 18:35:30.53ID:rHfSD+zL0 「別領域を全く使わず」とはいっても、テンポラリの変数を1個とか2個の固定数だけ使うのは除く。
934デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 19:11:01.43ID:7nonADk70 屁理屈を言うと、index_listを壊していいなら、
以下の手順で別領域を使わない置換は可能。遅いけど。
for( size_t i = 0; i < array.size() - 1; ++i )
{
std::swap( array[i], array[index_list[i]] );
std::swap( index_list[i], *std::find( index_list.begin()+i+1, index_list.end(), i ) );
}
以下の手順で別領域を使わない置換は可能。遅いけど。
for( size_t i = 0; i < array.size() - 1; ++i )
{
std::swap( array[i], array[index_list[i]] );
std::swap( index_list[i], *std::find( index_list.begin()+i+1, index_list.end(), i ) );
}
935デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 19:26:56.50ID:7nonADk70 おっと、index_list.begin()+i+1の「+1」は消してくれ
936デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 19:44:23.58ID:rHfSD+zL0 この話をきっかけに、std::next_permutation の仕様を見てみたが、どういう時に使うのかよくわからない。
937デフォルトの名無しさん (ブーイモ MMfa-0mrS)
2017/10/07(土) 20:14:16.81ID:jvf7kHO4M 流石にO(n)は維持しないと
厳しいと思います
厳しいと思います
938片山博文MZ ◆T6xkBnTXz7B0 (スフッ Sdfa-yc5c)
2017/10/07(土) 20:23:01.47ID:vDiuGwTad お前ら、プログラム書くとき、普通にnoexceptを何回も書いてるの?
939片山博文MZ ◆T6xkBnTXz7B0 (スフッ Sdfa-yc5c)
2017/10/07(土) 20:25:42.72ID:vDiuGwTad >>936
permutation を実装するときに決まってんだろ?
permutation を実装するときに決まってんだろ?
940デフォルトの名無しさん (ワントンキン MMea-zCRe)
2017/10/07(土) 20:53:48.18ID:Mcd7mBScM942はちみつ餃子 ◆8X2XSCHEME (ワッチョイ ae6f-XSap)
2017/10/07(土) 21:05:19.53ID:JUuMz14c0 >>918
any は C++17 で標準に入ったよ。
any は C++17 で標準に入ったよ。
943デフォルトの名無しさん (オッペケ Sr75-BFoK)
2017/10/07(土) 21:13:10.52ID:x4ka+ayCr 規格と規格じゃないものの区別も付かない低能はすっこんでて
944900 (ワッチョイ 76b3-yS8h)
2017/10/07(土) 21:13:19.89ID:m/msdGTM0945デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/07(土) 21:17:07.24ID:rHfSD+zL0 >>939
わからんがな
わからんがな
946デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/07(土) 23:13:09.50ID:7nonADk70 >>934
別領域を使わない置換に再挑戦。今回はO(n)のはず。
for( size_t i = 0; i < array.size() - 1; ++i )
{
size_t j = i, k = index_list[i];
while( k != i )
{
std::swap( array[j], array[k] );
index_list[j] = j; j = k; k = index_list[k];
}
index_list[j] = j;
}
別領域を使わない置換に再挑戦。今回はO(n)のはず。
for( size_t i = 0; i < array.size() - 1; ++i )
{
size_t j = i, k = index_list[i];
while( k != i )
{
std::swap( array[j], array[k] );
index_list[j] = j; j = k; k = index_list[k];
}
index_list[j] = j;
}
947デフォルトの名無しさん (ワッチョイ b65f-lMpN)
2017/10/08(日) 00:16:09.42ID:FGX6bPrh0 >>946
二重ループなのにO(n)なの?
二重ループなのにO(n)なの?
948デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/08(日) 00:28:37.42ID:wi1g/BWB0 後出しのようで心苦しいけどindex_listを壊すのはダメだと思う。
const参照で渡すインタフェースにできないという意味で汎用性条件を満たしていない。
const参照で渡すインタフェースにできないという意味で汎用性条件を満たしていない。
949デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/08(日) 06:22:19.14ID:+SudLjvR0 >>947
以下の2つの理由により、外側のループがn回まわる間に
内側のループの中身はたかだかn回しか実行されない。
1. 内側のループ内で処理済みのインデックスjに対し index_list[j]=j が実行される。
2. index_list[i]==i の条件が最初から満たされていた場合、内側のループは実行されない
要するに、内側のループを実行済みかのフラグとしてindex_listを使ってるだけ。
>>948
index_listを壊している時点で屁理屈なのは自覚しているんで、仕方ない。
一応、別配列にムーブする場合と比べると、
最初から正しい位置にある要素への処理が不要になるというメリットは有る。
以下の2つの理由により、外側のループがn回まわる間に
内側のループの中身はたかだかn回しか実行されない。
1. 内側のループ内で処理済みのインデックスjに対し index_list[j]=j が実行される。
2. index_list[i]==i の条件が最初から満たされていた場合、内側のループは実行されない
要するに、内側のループを実行済みかのフラグとしてindex_listを使ってるだけ。
>>948
index_listを壊している時点で屁理屈なのは自覚しているんで、仕方ない。
一応、別配列にムーブする場合と比べると、
最初から正しい位置にある要素への処理が不要になるというメリットは有る。
950デフォルトの名無しさん (ワッチョイ dab3-Nz6W)
2017/10/08(日) 11:20:44.83ID:HosRocIl0951デフォルトの名無しさん (ワッチョイ b651-iGo5)
2017/10/08(日) 11:34:33.36ID:+SudLjvR0 駄目な理由が引数を壊すってことだけなら、引数を値渡しにしてやれば、
呼び出し時に勝手にコピーされるので問題ないはず。
壊していい引数を渡す時はstd::move()すればいいし。
呼び出し時に勝手にコピーされるので問題ないはず。
壊していい引数を渡す時はstd::move()すればいいし。
952デフォルトの名無しさん (ワッチョイ aaeb-qWqy)
2017/10/08(日) 13:39:35.60ID:GUxnbDfL0 引数がconst参照=引数の状態を変更しない(てか、できない)という意思表示
に対して
引数が右辺値参照=引数の状態を変更する(しても文句言うな)という意思表示
というのはアリ?
右辺値参照に対する理解が曖昧なんで漠然とよく分からない(何が分かって
ないかも分からないw)んだが、もっと別な意思表示方法もある?
に対して
引数が右辺値参照=引数の状態を変更する(しても文句言うな)という意思表示
というのはアリ?
右辺値参照に対する理解が曖昧なんで漠然とよく分からない(何が分かって
ないかも分からないw)んだが、もっと別な意思表示方法もある?
953デフォルトの名無しさん (ワッチョイ dabd-mvC5)
2017/10/08(日) 16:07:31.29ID:6tf5QjxV0 ほ〜ん>>946の奴はちゃんと動いたわ;
ttps://ideone.com/6lwMOn
ttps://ideone.com/6lwMOn
954デフォルトの名無しさん (ワッチョイ dabd-mvC5)
2017/10/08(日) 16:11:39.00ID:6tf5QjxV0 >>946の奴は要素[i]が内側のwhile()ループからは1回以上アクセスされないから確かにO(N)な気配、
955デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/08(日) 23:25:19.93ID:sIfqyVAH0 右辺値参照はさっぱり意味わからんわ。
956デフォルトの名無しさん (ワッチョイ dabd-mvC5)
2017/10/09(月) 09:00:03.09ID:U0LcPFS10 右辺値参照というのは、関数f()へのT型データの値渡し時に暗黙のうちに行われる(C++03までは無条件に行われていた)
(左辺値) = (右辺値)
という代入処理において、
当該代入処理後、右辺値が関数呼び出し元によって使われなくなることが明白なとき、
左辺値へのコピー後、右辺値をデストラクトする
という処理に暗黙のうちになっていたものを、
右辺値から左辺値への移動
と「も」書けるようにするためのしくみ
Tに効率の良いムーブコンストラクタ(か右辺値参照を引数とする代入演算子)を定義しないとメリットが生じない
ポインタに__restrictを付けるべきかどうか悩まねばならないレベルの人用
C++03でもコンストラ・デストラ呼び出し回数削減の最適化がかかって同じような効果になるケースが多々あるから
そういうのが信用できない神経質な人向け
※ 個人の感想です
(左辺値) = (右辺値)
という代入処理において、
当該代入処理後、右辺値が関数呼び出し元によって使われなくなることが明白なとき、
左辺値へのコピー後、右辺値をデストラクトする
という処理に暗黙のうちになっていたものを、
右辺値から左辺値への移動
と「も」書けるようにするためのしくみ
Tに効率の良いムーブコンストラクタ(か右辺値参照を引数とする代入演算子)を定義しないとメリットが生じない
ポインタに__restrictを付けるべきかどうか悩まねばならないレベルの人用
C++03でもコンストラ・デストラ呼び出し回数削減の最適化がかかって同じような効果になるケースが多々あるから
そういうのが信用できない神経質な人向け
※ 個人の感想です
957デフォルトの名無しさん (オッペケ Sr75-BFoK)
2017/10/09(月) 09:09:56.49ID:Ge9OzZ/lr それで>>952の質問の答えはどうなるんだ?
958デフォルトの名無しさん (ワッチョイ dabd-mvC5)
2017/10/09(月) 09:20:15.73ID:U0LcPFS10 >>957
右辺値参照には一時オブジェクトしか代入できない縛りがあるから_
関数fooを
voiid foo(int&& x)
というバージョンしか定義していないとすると、
int g_x = 10;
foo(g_x);
がビルドが通らないのではないか;
一般的な使用を想定すれば、結局foo(const int& x)も定義必要
C++03までしか使ったこと無いから知らんけど;;
右辺値参照には一時オブジェクトしか代入できない縛りがあるから_
関数fooを
voiid foo(int&& x)
というバージョンしか定義していないとすると、
int g_x = 10;
foo(g_x);
がビルドが通らないのではないか;
一般的な使用を想定すれば、結局foo(const int& x)も定義必要
C++03までしか使ったこと無いから知らんけど;;
959デフォルトの名無しさん (ワントンキン MMea-zCRe)
2017/10/09(月) 09:37:56.10ID:nhJ4ZLVgM960デフォルトの名無しさん (ワッチョイ 95b3-BFoK)
2017/10/09(月) 10:15:14.60ID:53KUOYPr0 必然性の無い実装都合のシンクはクソ
961デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/09(月) 17:26:43.28ID:bLguG3ky0 オブジェクトのコピーとかムーブのためにここまで言語仕様を複雑にしないといけないのか。おれにはさっぱり理解不能だわ。
962デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 17:57:29.04ID:0USm99MRM 俺も右辺値参照はどうかと思う
いらないよね
いらないよね
963デフォルトの名無しさん (ワンミングク MMea-zCRe)
2017/10/09(月) 18:35:18.07ID:3udUYydoM 使わなくてもいいんじゃないか?
使ったことないから複雑に感じるだけで、そこまで複雑でもないよ
使ったことないから複雑に感じるだけで、そこまで複雑でもないよ
964デフォルトの名無しさん (ワッチョイ dab3-Nz6W)
2017/10/09(月) 18:45:40.84ID:UEIAYP2F0 >>961
GCをもたない言語の宿命だから嫌なら性能を犠牲にするかGCを持つ言語を使えばいい
GCをもたない言語の宿命だから嫌なら性能を犠牲にするかGCを持つ言語を使えばいい
965デフォルトの名無しさん (ブーイモ MMde-V8Tw)
2017/10/09(月) 18:56:48.86ID:QjIlXwNcM いやいやスマポがあるじゃない。
中級が多いプロジェクトならスマポ強制のほうが性能上がるんじゃないかと思う。
中級が多いプロジェクトならスマポ強制のほうが性能上がるんじゃないかと思う。
966デフォルトの名無しさん (ワッチョイ da04-RixE)
2017/10/09(月) 18:58:40.39ID:8DJAJvC20 個人的にはC++の言語仕様の暗黒面はほとんど「参照」が絡んでいると思う。
967デフォルトの名無しさん (ワンミングク MMea-zCRe)
2017/10/09(月) 19:50:58.39ID:3udUYydoM ADLとか部分特殊化のマッチとかのほうが、はるかに複雑で暗黒だと思う
968デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/09(月) 20:54:40.71ID:bLguG3ky0969デフォルトの名無しさん (ワッチョイ dab3-Nz6W)
2017/10/09(月) 20:56:32.03ID:UEIAYP2F0970デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 20:56:47.16ID:1ynB1O3m0971デフォルトの名無しさん (ワッチョイ 5504-CLk5)
2017/10/09(月) 21:28:57.78ID:iWLkHfj90 右辺値参照なんか、破壊不可オブジェクトをムーブするときくらいしか使わないような。うにーくぽいんたとか。
それ以外は参照でいいし。
それ以外は参照でいいし。
972デフォルトの名無しさん (ワッチョイ 958a-ZNcz)
2017/10/09(月) 21:45:04.70ID:Rk3/uNWr0 右辺値参照の有用性を理解できない人間にとってはそもそもC++自体が無用だと思う
さっさと退散しなさい
さっさと退散しなさい
973デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/09(月) 21:56:43.96ID:bLguG3ky0 ところでなんでそんなに一時オブジエクトを参照しなきゃいけないコードを書くの?
参照元を管理するのが面倒だから? そういう人は初めからGC言語使えばよくね? ということですか?
参照元を管理するのが面倒だから? そういう人は初めからGC言語使えばよくね? ということですか?
974デフォルトの名無しさん (ワッチョイ 958a-ZNcz)
2017/10/09(月) 22:03:17.69ID:Rk3/uNWr0 なんでとか言われても。。。
壊してもいい一時オブジェクトの場合、特別に効率的な扱いをしたくなるケースなんて山ほどある
それが分からないならC++なんて触らずにGC言語専門でやってればいいと思うよ
壊してもいい一時オブジェクトの場合、特別に効率的な扱いをしたくなるケースなんて山ほどある
それが分からないならC++なんて触らずにGC言語専門でやってればいいと思うよ
975はちみつ餃子 ◆8X2XSCHEME (ワッチョイ ae6f-XSap)
2017/10/09(月) 22:10:35.64ID:GeS0S50a0 そのあたりはトレードオフなんだよ。
そりゃあ気にせずに済むなら気にしたくないが、気にしなきゃならないときに出来ることがないのはつらいって話で。
そりゃあ気にせずに済むなら気にしたくないが、気にしなきゃならないときに出来ることがないのはつらいって話で。
976デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 22:13:59.60ID:0USm99MRM 俺もわからん
左辺値参照ではなく右辺値参照を使った方が
良い状況ってどんなの?
あと唐突にガページコレクション出してるけど
何の関係があるの?
左辺値参照ではなく右辺値参照を使った方が
良い状況ってどんなの?
あと唐突にガページコレクション出してるけど
何の関係があるの?
977デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/09(月) 22:24:17.86ID:bLguG3ky0 もしかしてC++で仕事したことないんですか?
978デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 22:25:07.16ID:1ynB1O3m0 そりゃ右辺値を束縛したくてかつconst左辺値じゃダメな場合だろ
979デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 22:43:46.89ID:0USm99MRM んー?
結局無いんでしょ?
使うべきシチュが
そうならそう言えばいいのに
結局無いんでしょ?
使うべきシチュが
そうならそう言えばいいのに
980デフォルトの名無しさん (ワッチョイ 8981-zCRe)
2017/10/09(月) 22:45:47.51ID:jvobj8TT0 >>979
classの初期化はどう?
classの初期化はどう?
981デフォルトの名無しさん (ワッチョイ dab3-Nz6W)
2017/10/09(月) 22:51:16.17ID:UEIAYP2F0 使うシチュエーションがない?
規格決める奴等が無駄にあーだこーだ言ってるだけとか思ってるなら病院に行った方がいいと思う
規格決める奴等が無駄にあーだこーだ言ってるだけとか思ってるなら病院に行った方がいいと思う
982デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 22:54:00.89ID:0USm99MRM 初期化はどう?って言われても・・
右辺値参照で初期化するのがベターな状況は
浮かびませんけど
右辺値参照で初期化するのがベターな状況は
浮かびませんけど
983デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 22:55:12.55ID:0USm99MRM984デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:09:59.39ID:1ynB1O3m0 んん?
右辺値を束縛したい(一時オブジェクトだから左辺値としての実体はない)
けどconst左辺値じゃダメ(中身を変更したいから)
↑
これのどこにわかりにくい点があるというのか?
「RVOが保証されるようになったらいらない」という意見なら理解できるが・・・
右辺値を束縛したい(一時オブジェクトだから左辺値としての実体はない)
けどconst左辺値じゃダメ(中身を変更したいから)
↑
これのどこにわかりにくい点があるというのか?
「RVOが保証されるようになったらいらない」という意見なら理解できるが・・・
985デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:14:06.35ID:1ynB1O3m0 たとえば swap の実装なんか(素朴には)moveを3回繰り返すんだから
右辺値参照の有用性は明らかだろ
右辺値参照の有用性は明らかだろ
986デフォルトの名無しさん (オッペケ Sr75-BFoK)
2017/10/09(月) 23:16:20.29ID:7RyTvmhPr987デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:20:00.09ID:1ynB1O3m0988デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 23:25:56.07ID:0USm99MRM >>985
これを右辺値参照Verに書き換えて
利点を示してもらえますか?
void swap(int& a,int& b)
{
int c = a;
a = b;
b = c;
}
void main()
{
int a = 1;
int b = 2;
swap(a,b);
}
これを右辺値参照Verに書き換えて
利点を示してもらえますか?
void swap(int& a,int& b)
{
int c = a;
a = b;
b = c;
}
void main()
{
int a = 1;
int b = 2;
swap(a,b);
}
989デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:26:35.20ID:1ynB1O3m0990デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:27:28.76ID:1ynB1O3m0991デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 23:31:15.79ID:0USm99MRM なら何なら利点があるの?
long long型ならあるの?
もう訳が分からないよ
long long型ならあるの?
もう訳が分からないよ
992デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/09(月) 23:32:58.04ID:1ynB1O3m0 >>991
コピーコストの大きいコンテナだったら三回も代入したくないだろ?
コピーコストの大きいコンテナだったら三回も代入したくないだろ?
993デフォルトの名無しさん (ワッチョイ 8981-zCRe)
2017/10/09(月) 23:34:48.01ID:jvobj8TT0994デフォルトの名無しさん (ワッチョイ dabd-mvC5)
2017/10/09(月) 23:41:18.28ID:U0LcPFS10995デフォルトの名無しさん (ワッチョイ b183-wbjw)
2017/10/09(月) 23:48:51.82ID:bLguG3ky0 swapが頻繁に起こるような用途なら、なんではじめからポインタで管理しないんですか?
996デフォルトの名無しさん (ワッチョイ aafb-BFoK)
2017/10/09(月) 23:49:46.71ID:qIHa8iWG0 一時オブジェクトもglvalueなんだから
T &に束縛できればよかった
T &に束縛できればよかった
997デフォルトの名無しさん (ワッチョイ 8981-zCRe)
2017/10/09(月) 23:52:41.96ID:jvobj8TT0 >>995
ヒープじゃなくてスタックで処理したいから
ヒープじゃなくてスタックで処理したいから
998デフォルトの名無しさん (ブーイモ MMa1-0mrS)
2017/10/09(月) 23:55:42.49ID:0USm99MRM 結局のところ
右辺値参照はコピーコストを削減出来るのが利点で
それぐらいしか使い道がないってことか
かつ、コピーコンストラクタよりムーブコンストラクタの方が
コストを軽く出来るクラスに限られると
struct a{ void* p; }; // これには効果が期待出来るが
struct b{ int p[65536]; }; // これには効果は期待出来ない
結論としては、やっぱいらねーやこんなのってことだな
右辺値参照はコピーコストを削減出来るのが利点で
それぐらいしか使い道がないってことか
かつ、コピーコンストラクタよりムーブコンストラクタの方が
コストを軽く出来るクラスに限られると
struct a{ void* p; }; // これには効果が期待出来るが
struct b{ int p[65536]; }; // これには効果は期待出来ない
結論としては、やっぱいらねーやこんなのってことだな
999デフォルトの名無しさん (ワッチョイ 8981-zCRe)
2017/10/09(月) 23:58:36.68ID:jvobj8TT0 後者も効果が期待できるよ
そして、コピーコストが削減できるだけってのは正しいが、いるかいらないかは人による
そして、コピーコストが削減できるだけってのは正しいが、いるかいらないかは人による
1000デフォルトの名無しさん (ワッチョイ dae7-XSap)
2017/10/10(火) 00:01:39.19ID:O5j+wjNW010011001
Over 1000Thread このスレッドは1000を超えました。
新しいスレッドを立ててください。
life time: 72日 12時間 33分 11秒
新しいスレッドを立ててください。
life time: 72日 12時間 33分 11秒
レス数が1000を超えています。これ以上書き込みはできません。
ニュース
- 【和訳付き】レーダー照射問題 中国軍と自衛隊との“音声データ”公開 中国国営メディア [♪♪♪★]
- 「中国側も日本機のレーダーを感知していた」 中国メディアが報道 [♪♪♪★]
- 【YouTuber】バイク事故で入院のゆたぼん、振込で「お見舞金」募る [muffin★]
- 堀江貴文、キャッシュレス非対応の店にモヤッ 『PayPay』立ち上げの人物にまさかの直談判「現金決済しかできないんだけど…」 [冬月記者★]
- 空自機レーダー照射、音声データ公開 中国 ★2 [蚤の市★]
- 高市早苗首相、消費税減税に後ろ向き 足かせはレジシステム? 「責任ある積極財政」期待高いが [蚤の市★]
- 【悲惨】中国軍が自衛隊に「事前通告」し自衛隊も返答した音声が公開されてしまうwwwこれは高市チェックアウトゕ★2 [597533159]
- 【悲報】JA「全然米が売れなくて倉庫を圧迫してる。助けて!」米卸売り業者「安売りしたら赤字になる…助けて!」 [802034645]
- 中国の日本向けレアアースの輸出止まる、高市のせいで日本終了のお知らせ [931948549]
- 韓国政府、高市早苗の「竹島領土」発言にブチギレwwwwwwwwwwwwwwww [834922174]
- アジア諸国「なぜドイツは反省しているのに日本人は反省しないのか」これ言われたら誰も言い返せないよな [999047797]
- 年末ジャップ、メルカリが売れまくる… [667744927]
