[表示 : 全て 最新50 1-99 2chのread.cgiへ]
Update time : 05/13 19:36 / Filesize : 12 KB / Number-of Response : 48
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

C++相談室 part70



1 名前:デフォルトの名無しさん [2009/06/14(日) 10:14:10 ]
C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレに
お願いします。

前スレ
C++相談室 part69
pc12.2ch.net/test/read.cgi/tech/1241438694/


22 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 21:44:06 ]
仮に
class A {
public:
 A() {
  m_String = ::GetHogeStr();
  m_pStr = m_String.c_str();
 }
 const char * GetStr() {
  return m_pStr;
 }
 std::string m_String;
 const char *m_pStr;
};

みたいにしてあった場合、例えば
std::vector<A> a;
とかやってると a の操作によっては中身が再配置されてまずいんでないの?

23 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 21:58:49 ]
>>22
おまいは何を勘違いしているんだ。
m_pStrの中身が0x12345678だったとして、
仮にアフリカに再配置されたとしても0x12345678のままだぞ。

24 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:10:27 ]
いや、そうじゃなくて
std::vector<A> vec;
A a;
vec.push_back(a);
const char *a_str = vec[0].GetStr();
vec.push_back(...);
vec.push_back(...);
...
てやったときにさ、a0 が最後まで無効にならないって保障はあるのかと。
vec が保持してるのは A* じゃなくて A じゃん。


25 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:11:17 ]
すまん a0 → a_str とよみかえてくれ

26 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:12:07 ]
>>22
元の質問ではっきり「これ以降 myString に対する操作はすべて myString.c_str() のみ」って
前提がおいてあるのに、なんでわざわざ問題のある状況を作って「まずいんでないの?」とか
スレ汚すの?

27 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:13:41 ]
スレを汚したい年頃だからさ

28 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:15:47 ]
パンツ汚したら親に見つからないように風呂場で洗え^^

29 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:16:21 ]
>>24
保障あるよ

30 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:19:08 ]
myString がグローバル変数だとか、単なるローカル変数ならいいけどさ、
クラスのメンバだったりするとまた話は変わってくるでしょ。
myString に対するそうさが c_str だけとわかっていても、それを含んでいる
インスタンスの扱いによっては、myString を直接いじらなくても
おかしくなる可能性があるんじゃない?




31 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:21:59 ]
>30
え!マジで

32 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:27:22 ]
class A {...}
std::string <A>
とかやったら、内部バッファが拡張されるたびに
あたらしい領域にAのコピーがつくられて、
古い領域にあるA が全廃棄になるものとばかり思っていた

33 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:29:27 ]
そもそも値のセマンティクスを持たないものをSTLコンテナの中に入れちゃらめ^^
R.マッサー先生がそう書いてたでしょ?

34 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 22:45:08 ]
>30
>インスタンスの扱いによっては、myString を直接いじらなくても
>おかしくなる可能性があるんじゃない?

何でわざわざmyStringが破棄される場合の話がでてくるの?
はじめから>>18でもmyStringが破棄されたときは問題だと認識されているが。
いつmyStringが破棄されるか、というのはまったく別の話だろう。



35 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 23:07:06 ]
あまり考えずに丸投げで聞いてみるが
C++でCPSスタイルって出来る?
テンプレート/関数ポインタともに
型の制限は受けるよね、多分

36 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 23:08:16 ]
できるよ。

37 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 23:27:44 ]
template <typename T> void mandelbrot(T cont){
//z=z*z+cを色々計算
cont.parse(z.real(),z.imag());
}

void mandelbrot2(void (*cont)(double,double)){
//略
cont(z.real(),z.imag());
}

一応これで出来そうには思うが
2回以上連続して適用は無理だよな
operator()で統一するぐらいが現実的か

38 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 00:56:33 ]
前スレのABC案に答えてくれた人ありがとうございました。
とりあえずB案で、それがボトルネックになる事態が発生するまでそうしておこうと思います。

39 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 00:57:43 ]
普通Aからだろ。まあいいが。

40 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 01:06:28 ]
個人的にはCがいいかと思っていたのですが、Bでもさほど問題にはならないだろうし、
なにより早すぎる最適化であるという指摘を受けて、なるほどと思いました。
Aであることのメリットは何でしょうか?



41 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 01:12:44 ]
ちなみにCがいいかと思った理由は、スコープを限定できる(C#でいうusingのような)ことと、
ループ内でインスタンス生成することのコスト(が最適化されるかどうかも含めて)を、
そのコードを初めて見た人が心配しなくてすむだろうと思ったからです。

42 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 01:36:47 ]
ブロック式が出てきたら関数化が必要だと思うきがす・・・るけど,採用しなかったならOK

43 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 22:11:48 ]
>>38
お前は何を聞いていたんだ。
コピーコンストラクタには3歳児が10まで数える処理が
含まれているって言ったろ?

44 名前:39 mailto:sage [2009/06/15(月) 23:18:20 ]
>>40
ああ、ごめん。おれもBだわ。勘違いしてた。

45 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 23:23:11 ]
>>43
コピーコンストラクタは速いが、デストラクタでは100まで数えておふろから出る処理が含まれてたと思う

46 名前:デフォルトの名無しさん mailto:sage [2009/06/15(月) 23:42:18 ]
それが問題になるならその時に対処すればいい

47 名前:デフォルトの名無しさん mailto:sage [2009/06/16(火) 05:24:12 ]
そもそも真にボトルネックになっているかどうかが分からない。
実測するしかないだろう。

・コピーコンストラクタで毎回生成する方式
の方が速いこともあれば
・代入演算子で毎回生成する方式
の方が速いこともある。

前者は毎回メモリをスタックに確保する必要がある+コピーコンストラクタを起動する必要がある
が、確保場所は好き好きに決めて良いから速いかもしれない。
後者は毎回メモリをスタックに確保する必要がない+代入演算子を呼び出す必要がある
が、確保場所は既にきまっちゃっているわけで、自由度がないかもしれない。

てな感じでしょうかね。






[ 新着レスの取得/表示 (agate) ] / [ 携帯版 ]

次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧](*・∀・)<12KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef