[表示 : 全て 最新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/


2 名前:デフォルトの名無しさん [2009/06/14(日) 10:15:25 ]
■基本■
[C++ FAQ]
 www.parashift.com/c++-faq-lite/
 www.bohyoh.com/CandCPP/FAQ/ (日本語)
  Cとその仕様を比較しながらの解説なので分かりやすい。
  ***** 質問の前に必ずこの二つに目を通してください *****
[C/C++ リファレンス]
 www.cppreference.com/ (英語)
 www.cppll.jp/cppreference/ (↑の日本語訳だけど最新は反映しない)
[禿 Stroustrup]
 public.research.att.com/~bs/
[C++ International Standard]
 www.iso.org/iso/iso_catalogue/catalogue_tc/catalogue_detail.htm?csnumber=38110
[JTC1/SC22/WG21 - C++]
 www.open-std.org/jtc1/sc22/wg21/
  ここから規格の最新(2003より新しい)ドラフトがダウンロードできる。
[JIS X3014]
 www.jisc.go.jp/app/pager?&RKKNP_vJISJISNO=X3014
  ISO規格の日本語訳。JIS X 3014:2003はISO/IEC 14882:2003 (E)に対応。

3 名前:デフォルトの名無しさん [2009/06/14(日) 10:16:10 ]
■Books(Templateまわり)■
Effective STL
 www.amazon.com/exec/obidos/ASIN/0201749629/
 www.amazon.co.jp/exec/obidos/ASIN/4894714108/ (翻訳)
Modern C++ Design
 www.amazon.com/exec/obidos/ASIN/0201704315/
 www.amazon.co.jp/exec/obidos/ASIN/4894714353/ (翻訳)
C++ Templates
 www.amazon.com/exec/obidos/ASIN/0201734842/
C++ Template Metaprogramming
 www.amazon.com/exec/obidos/ASIN/0321227255/


4 名前:デフォルトの名無しさん [2009/06/14(日) 10:17:19 ]
■Libraries■
[Boost]
 Boost www.boost.org/
 (日本語) www.kmonos.net/alang/boost/
 (日本語) shinh.skr.jp/boost/
[標準ライブラリ]
 SGI-STL www.sgi.com/tech/stl/
 STLport stlport.sourceforge.net/
 GNU libstdc++ gcc.gnu.org/libstdc++/
 Apache STDCXX incubator.apache.org/stdcxx/
 STLFilt www.bdsoft.com/tools/stlfilt.html
 (日本語) www005.upp.so-net.ne.jp/episteme/html/stlprog/
 (日本語) www.wakhok.ac.jp/~sumi/stl/
[Loki]
 sourceforge.net/projects/loki-lib/
 LokiPort-MSVC6sp5 fara.cs.uni-potsdam.de/~kaufmann/?page=lokiport


5 名前:デフォルトの名無しさん [2009/06/14(日) 10:18:34 ]
入門ページなど

www.cplusplus.com/

・入門,一覧,使い方
www5c.biglobe.ne.jp/~ecb/cpp/07_01.html
・メソッド一覧
www.wakhok.ac.jp/~sumi/stl/
・サンプルプログラム集
www.s34.co.jp/cpptechdoc/reference/stl_samples/


6 名前:デフォルトの名無しさん [2009/06/14(日) 10:19:28 ]
Apache STDCXX incubator.apache.org/stdcxx/

Apache C++ Standard Library (STDCXX) stdcxx.apache.org/
というのは指摘済みでした。ごめんなさい。とりあえず訂正。

■Libraries■
[Boost]
 Boost www.boost.org/
 (日本語) www.kmonos.net/alang/boost/
 (日本語) shinh.skr.jp/boost/
[標準ライブラリ]
 SGI-STL www.sgi.com/tech/stl/
 STLport stlport.sourceforge.net/
 GNU libstdc++ gcc.gnu.org/libstdc++/
 Apache C++ Standard Library (STDCXX) stdcxx.apache.org/
 STLFilt www.bdsoft.com/tools/stlfilt.html
 (日本語) www005.upp.so-net.ne.jp/episteme/html/stlprog/
 (日本語) www.wakhok.ac.jp/~sumi/stl/
[Loki]
 sourceforge.net/projects/loki-lib/
 LokiPort-MSVC6sp5 fara.cs.uni-potsdam.de/~kaufmann/?page=lokiport

7 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 10:20:08 ]
結論

Cでいい

8 名前:デフォルトの名無しさん [2009/06/14(日) 10:25:44 ]
Boost C++ Libraries
www.boost.org/

Boost 翻訳プロジェクト
boost.cppll.jp/HEAD/

Let's Boost
www.kmonos.net/alang/boost/

boost info
shinh.skr.jp/boost/

9 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 10:39:30 ]
最悪言語C++は不要
スレも不要

10 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 10:54:15 ]
C++で作れない人にとってはC++は不要
Cスレに帰れ



11 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 11:11:49 ]
c++最高

12 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 11:25:53 ]
>>1

13 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 11:33:21 ]
STLつかうと一気に実行ファイルサイズが10倍に?!

環境によるだろ。
俺はBorland-C++5.6.2に -D_RTLDLL オプションを指定して、極力
ランタイムを使用するようにして使っているが、例えばstd::vectorを
使っても使わない時と比べ10Kほどしか増えない

すげえ。ダイナミックリンクしといてファイルサイズが増えないとかいってるよ。この人。

C1010: プリコンパイル済みヘッダーの検索中に予期しない EOF を検出しました。
とかいうエラーが出るんだけどこれってどうすればいいの?

#include <stdafx.h>
後死ね。

言葉が悪いな。それで教えているつもりか。
まぁヒントぐらいにはなったな。
うむごくろう。

14 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 12:27:14 ]
誤爆

15 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 16:52:33 ]
テンプレはまだ続きます

16 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 17:27:51 ]
『C++再考』

17 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 17:29:40 ]
『C++サイコ』

18 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 19:51:02 ]
std::string myString = GetHogeString();

みたいにした場合、これ以降 myString に対する操作はすべて myString.c_str() のみで、
その他の操作はいっさいしないと仮定した場合

const char * pStr = myString.c_str();

としておいて、以降ずっと(いつの日かmyStringが破棄されるまで)
pStr を使っていても問題ない?


19 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 19:54:33 ]
>>18
問題ない。
myString が破棄されるか、 myString の非 const メンバ関数を呼び出すまで
c_str() の戻り値は有効。

20 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 19:57:06 ]
規格書広げるまでもなく
"いつの日"が1msec後で、1msec後にpStrが向こうになったら困るから、
"いつの日か"破棄されるまでずっと有効。



21 名前:デフォルトの名無しさん mailto:sage [2009/06/14(日) 21:00:47 ]
開封後はお早めにお召し上がりください

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