C++相談室 part69
..
2:デフォルトの名無しさん
09/05/04 21:07:52
STLつかうと一気に実行ファイルサイズが10倍に?!
環境によるだろ。
俺はBorland-C++5.6.2に -D_RTLDLL オプションを指定して、極力
ランタイムを使用するようにして使っているが、例えばstd::vectorを
使っても使わない時と比べ10Kほどしか増えない
すげえ。ダイナミックリンクしといてファイルサイズが増えないとかいってるよ。この人。
C1010: プリコンパイル済みヘッダーの検索中に予期しない EOF を検出しました。
とかいうエラーが出るんだけどこれってどうすればいいの?
#include <stdafx.h>
後死ね。
言葉が悪いな。それで教えているつもりか。
まぁヒントぐらいにはなったな。
うむごくろう。
3:デフォルトの名無しさん
09/05/04 21:09:01
■基本■
[C++ FAQ]
URLリンク(www.parashift.com)
URLリンク(www.bohyoh.com) (日本語)
Cとその仕様を比較しながらの解説なので分かりやすい。
***** 質問の前に必ずこの二つに目を通してください *****
[C/C++ リファレンス]
URLリンク(www.cppreference.com) (英語)
URLリンク(www.cppll.jp) (↑の日本語訳だけど最新は反映しない)
[禿 Stroustrup]
URLリンク(public.research.att.com)
[C++ International Standard]
URLリンク(www.iso.org)
[JTC1/SC22/WG21 - C++]
URLリンク(www.open-std.org)
ここから規格の最新(2003より新しい)ドラフトがダウンロードできる。
[JIS X3014]
URLリンク(www.jisc.go.jp)
ISO規格の日本語訳。JIS X 3014:2003はISO/IEC 14882:2003 (E)に対応。
4:デフォルトの名無しさん
09/05/04 21:09:17
■Books(Templateまわり)■
Effective STL
URLリンク(www.amazon.com)
URLリンク(www.amazon.co.jp) (翻訳)
Modern C++ Design
URLリンク(www.amazon.com)
URLリンク(www.amazon.co.jp) (翻訳)
C++ Templates
URLリンク(www.amazon.com)
C++ Template Metaprogramming
URLリンク(www.amazon.com)
5:デフォルトの名無しさん
09/05/04 21:09:39
■Libraries■
[Boost]
Boost URLリンク(www.boost.org)
(日本語) URLリンク(www.kmonos.net)
(日本語) URLリンク(shinh.skr.jp)
[標準ライブラリ]
SGI-STL URLリンク(www.sgi.com)
STLport URLリンク(stlport.sourceforge.net)
GNU libstdc++ URLリンク(gcc.gnu.org)
Apache STDCXX URLリンク(incubator.apache.org)
STLFilt URLリンク(www.bdsoft.com)
(日本語) URLリンク(www005.upp.so-net.ne.jp)
(日本語) URLリンク(www.wakhok.ac.jp)
[Loki]
URLリンク(sourceforge.net)
LokiPort-MSVC6sp5 URLリンク(fara.cs.uni-potsdam.de)
6:デフォルトの名無しさん
09/05/04 21:12:23
入門ページなど
URLリンク(www.cplusplus.com)
・入門,一覧,使い方
URLリンク(www5c.biglobe.ne.jp)
・メソッド一覧
URLリンク(www.wakhok.ac.jp)
・サンプルプログラム集
URLリンク(www.s34.co.jp)
7:デフォルトの名無しさん
09/05/04 21:13:06
>3-5は古いスレから持ってきたのでリンク切れ等あると思います。
とりあえず、
Apache STDCXX URLリンク(incubator.apache.org)
は
Apache C++ Standard Library (STDCXX) URLリンク(stdcxx.apache.org)
というのは指摘済みでした。ごめんなさい。とりあえず訂正。
■Libraries■
[Boost]
Boost URLリンク(www.boost.org)
(日本語) URLリンク(www.kmonos.net)
(日本語) URLリンク(shinh.skr.jp)
[標準ライブラリ]
SGI-STL URLリンク(www.sgi.com)
STLport URLリンク(stlport.sourceforge.net)
GNU libstdc++ URLリンク(gcc.gnu.org)
Apache C++ Standard Library (STDCXX) URLリンク(stdcxx.apache.org)
STLFilt URLリンク(www.bdsoft.com)
(日本語) URLリンク(www005.upp.so-net.ne.jp)
(日本語) URLリンク(www.wakhok.ac.jp)
[Loki]
URLリンク(sourceforge.net)
LokiPort-MSVC6sp5 URLリンク(fara.cs.uni-potsdam.de)
8:デフォルトの名無しさん
09/05/04 21:19:28
Boost C++ Libraries
URLリンク(www.boost.org)
Boost 翻訳プロジェクト
URLリンク(boost.cppll.jp)
Let's Boost
URLリンク(www.kmonos.net)
boost info
URLリンク(shinh.skr.jp)
9:デフォルトの名無しさん
09/05/04 21:52:57
前スレ>>994
std::multisetのoperator>は任意のクラスの比較オブジェクト若しくは
比較関数を定義する時に用いる
挿入順序を決定する
struct Set {
int a;
double b;
Set(int i, double d) : a(i), b(d) {}
};
bool operator>(const Set& a, const Set& b) {
return a.b > b.b;
}
int main()
{
std::multiset<Set, std::greater<Set> > ms;
ms.insert(Set(1, 2.0));
ms.insert(Set(2, 1.0));
for (std::multiset<Set, std::greater<Set> >::const_iterator pos = ms.begin(); pos != ms.end(); ++pos)
std::cout << pos->a << ' ' << pos->b << std::endl;
}
10:デフォルトの名無しさん
09/05/04 22:07:51
但し次のような例ではstd::greaterを定義していても暗黙の内に
<()std::less)が使われるので定義しておかなければならない。
struct Set {
int a;
double b;
Set(int i, double d) : a(i), b(d) {}
};
bool operator>(const Set& a, const Set& b) {
return a.b > b.b;
}
bool operator<(const Set& a, const Set& b) {
return a.b < b.b;
}
int main()
{
std::multiset<Set, std::greater<Set> > ms, ms2;
ms.insert(Set(1, 2.0));
ms.insert(Set(2, 1.0));
ms2.insert(Set(1, 0.0));
ms2.insert(Set(1, 0.5));
for (std::multiset<Set, std::greater<Set> >::const_iterator pos = ms.begin(); pos != ms.end(); ++pos)
std::cout << pos->a << ' ' << pos->b << std::endl;
if (ms > ms2)
std::cout << "ms > ms2\n";
}
11:前スレ>>994
09/05/04 22:14:59
>>9-10
なるほど。
自作クラスSetに>を実装しないとstd::setやstd::multisetに入れられないのは理解できました。
ありがとうございます。
しかしご教示いただきたいのですが、最後の方の
if (ms > ms2)
このms>ms2の部分がtrueやfalseになるという決定はどういう基準で決まるということですか?
例えばms == ms2でしたら、「最初から最後まで全要素がmsとms2で等しい時true, 他はfalse」ですよね。
ms>ms2はどうなのでしょうか?
12:デフォルトの名無しさん
09/05/04 22:20:09
>>11
これで見る限り木の単純比較のように見えます
std::equal()を使っても同じ結果が得られると思います
struct Set {
int a;
double b;
Set(int i, double d) : a(i), b(d) {}
};
bool operator==(const Set& a, const Set& b) {
return a.b == b.b;
}
bool operator<(const Set& a, const Set& b) {
return a.b < b.b;
}
int main()
{
std::multiset<Set> ms, ms2;
ms.insert(Set(1, 2.0));
ms.insert(Set(2, 1.0));
ms2.insert(Set(1, 1.0));
ms2.insert(Set(3, 2.0));
if (ms == ms2)
std::cout << "ms == ms2\n";
}
13:デフォルトの名無しさん
09/05/04 22:23:27
あ、size()も見ているようですね
size()が等しくかつ単純比較で大小を決めているようです
1,3,5
1,2,6 のような場合はどちらが大きくなるかと、辞書順、つまり
最初に見つかった違いで判断しているようです
14:デフォルトの名無しさん
09/05/04 22:25:14
うーんsize()も見ていないのか?そうなるとstd::lexicographical_compareと同じアルゴリズムか?
struct Set {
int a;
double b;
Set(int i, double d) : a(i), b(d) {}
};
bool operator==(const Set& a, const Set& b) {
return a.b == b.b;
}
bool operator<(const Set& a, const Set& b) {
return a.b < b.b;
}
int main()
{
std::multiset<Set> ms, ms2;
ms.insert(Set(1, 3.0));
ms.insert(Set(2, 1.0));
ms.insert(Set(2, 5.0));
ms2.insert(Set(1, 1.0));
ms2.insert(Set(3, 2.0));
ms2.insert(Set(3, 6.0));
ms2.insert(Set(3, 1.0));
if (ms > ms2)
std::cout << "ms > ms2\n";
}
15:11
09/05/04 22:47:18
>>14
謎ですよね。ありがとうございます。
今、決定打を探してみています。
16:デフォルトの名無しさん
09/05/04 22:52:26
14882:2003 23.1 Table 65 に Container に対する
a < b の operational semantics として
lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())
って書いてあるよ。
17:デフォルトの名無しさん
09/05/04 22:54:00
多分辞書順だと思うんだけどなあ
手持ちの書籍を読んでもなかなか
SGIのホームページを見ると
Lexicographical comparison. This is a global function, not a member function.
とあるから間違いないと思いますが
規格書を読むと§23.1のTable65にやはり
convertible to bool lexicographical_compare linear
(a.begin(),a.end(),b.begin(),b.end())
pre: < is defined for values of T. < is a total ordering relation.
とあります
18:デフォルトの名無しさん
09/05/04 22:54:42
かぶったゴメン
という事で辞書順という事で決まり・・・みたいですね
19:デフォルトの名無しさん
09/05/04 23:06:37
多分順序が付いているということが大事で、その付け方はそんなに重要じゃないと思う
setの入れ子とかが出来るように適当に全順序決めてるだけだろうから
20:11
09/05/04 23:09:32
決定打ありがとうございます。
辞書順と言うことはすなわち
Rule1:msとms2で「格納している最小の要素」が大きい方を大きいとする。
Rule2:最小の要素が等しい場合は、それを除いてもうRule1を適用する。
Rule3:Rule2により要素が無くなったら、無くなった方が小さいとする。
ということですね。なんか変な定義ですねぇ。。。
ですが
ms.insert(Set(2, 1.0));
ms.insert(Set(1, 3.0));
ms.insert(Set(2, 5.0));
ms.insert(Set(2, 7.0));
と
ms2.insert(Set(2, 1.0));
ms2.insert(Set(1, 3.0));
ms2.insert(Set(2, 5.0));
ms2.insert(Set(2, 7.0));
ms2.insert(Set(2, 9.0));
とではms<ms2になるらしいですしやっぱりこういうことですよね。
ありがとうございました。
21:デフォルトの名無しさん
09/05/04 23:12:42
>>20
std::lexicographical_compare()の動作の仕方を理解できればいいよ
22:11
09/05/04 23:15:13
いや、そう変に考えなくても単に先頭から見て大きい方を大きいと見なすってだけですね。
setやmultisetが自動でソートされるから紛らわしいと感じるだけでした。
23:デフォルトの名無しさん
09/05/04 23:32:14
たまには頭のいい体操になるな
24:11
09/05/04 23:34:18
>>21
OKです。ありがとうございます。
25:デフォルトの名無しさん
09/05/05 01:07:29
質問です。
割と大きめの行列にSVD(特異値分解)したいので
そういうライブラリを探しています。
それで、liboctave C++を使おうと思い以下のコードを試しに実行してみたのですが、
2x2程度の行列なら、1秒以内に完了するのですが、このコードだと15分たった現在も結果が返りません。
実際に演算にかけたい対象は、更に大きいものなので、これでは使い物にならないのですが・・・
こんなものなのでしょうか?また他に良いライブラリはないのでしょうか?確かSVDに関しては高速化の手法がいくつか考えられてたとおもうのですが・・・
Matrix m(5, 6);
m(0,0) = 1; m(0,1) = 0; m(0,2) = 1; m(0,3) = 0; m(0,4) = 0; m(0,5) = 0;
m(1,0) = 0; m(1,1) = 1; m(1,2) = 0; m(1,3) = 0; m(1,4) = 0; m(1,5) = 0;
m(2,0) = 1; m(2,1) = 1; m(2,2) = 0; m(2,3) = 0; m(2,4) = 0; m(2,5) = 0;
m(3,0) = 0; m(3,1) = 0; m(3,2) = 0; m(3,3) = 1; m(3,4) = 1; m(3,5) = 0;
m(4,0) = 0; m(4,1) = 0; m(4,2) = 0; m(4,3) = 1; m(4,4) = 0; m(4,5) = 1;
cout << "Original Matrix" << endl << m << endl;
SVD svd(m);
cout << "Left Singular Matrix" << endl << svd.left_singular_matrix() << endl;
cout << "Singular Values" << endl << svd.singular_values() << endl;
cout << "Right Singular Matrix" << endl << svd.right_singular_matrix() << endl;
cout << "Recomposed Matrix" << endl << svd.left_singular_matrix()*Matrix(DiagMatrix(svd.singular_values()))*svd.right_singular_matrix() << endl;
26:デフォルトの名無しさん
09/05/05 04:06:33
>>25
ソースから作った?あと、ATLAS組み込んだ?
ATLASをgcc4&SSE4&マルチコア構成でmakeしてみて
liboctaveに組み込めばかなり高速化すると思う。
SVDの演算ならそんなもんだよ。
そんなに速度が欲しいなら、精度無視してNNを使った方法を取ったら?
27:デフォルトの名無しさん
09/05/05 09:48:54
std::map<std::string, Myclass> the_map;
で、存在しないキーを指定してアクセスした時はそのキーが自動的に登録されそのキーに対応する値はその値の型のデフォルトコンストラクタによって初期化されると聞きました。
試したところ、たしかにthe_map["this key doesn't exist."]とするとその値はMyclass()で初期化されていました。
では
std::map<std::string, int> the_map;
だった場合も大丈夫なのでしょうか?
g++ではthe_map["this key doesn't exist."]とするとその値はint()で初期化されて0になっているようですが、これは他の環境でも期待して良い物でしょうか?
28:デフォルトの名無しさん
09/05/05 10:08:19
>>27
引数なしのコンストラクタが呼ばれます
29:デフォルトの名無しさん
09/05/05 10:39:31
intとかについては T() の結果がマチマチじゃなかったかねえ
30:デフォルトの名無しさん
09/05/05 10:40:13
>>28
はい、それですと、
int型のクラスで言うところのデフォルトコンストラクタ
により0で初期化してくれるのですか?
たとえばstd::string str;だとデフォルトコンストラクタにより""になりますけど
int i;だと初期化されませんよね。
・・・と思いましたが、そう言えばint()で0が返るんでしたね
失礼しました。
31:デフォルトの名無しさん
09/05/05 10:42:00
>>29-30
組み込み型でもT()で全て初期化してくれるんじゃなかったか?
誰か有識者plz
32:デフォルトの名無しさん
09/05/05 11:02:21
8.5あたりに書いてあるな
イニシャライザが空の括弧(要するに()のこと)の場合はdefault-initializeされ、
PODに対してのdefault-initializeとはzero-initializeであって、
スカラー型に対してのzero-initializeとはその型での値0をセットすることである
と決められてる
だからint()は0初期化が保証されてると考えておk
ちなみにint i;みたいなのは「イニシャライザなし」であって()で初期化する場合とは区別される
イニシャライザなしの場合は非PODはdefault-initializeだが、PODの場合は不定値と決まっている
33:30
09/05/05 11:07:19
>>32
理解出来ました!
ありがとうございました。
34:デフォルトの名無しさん
09/05/05 11:41:15
pimplのインターフェースクラスのメンバ関数の実装はどこに書くべき?
具体的には↓↓
pimplイディオムを使うことを想定してMyClassとMyClass_implを定義した。
class MyClass_impl;
class MyClass
{
boost::shared_ptr<MyClass_impl> pimpl;
public:
int foo();
//以下略
};
ここで、MyClassのpublicメンバ関数int foo()からMyClass_implのメンバ関数int foo()を呼び出すように
int MyClass::foo()
{return pimpl->foo();}
と定義しろと学んだんだが、これはどこに書くべきなの?
実装ファイル.cpp(MyClass_implの定義と実装が書かれている)に書くべきなのか、
それともMyClassクラスの定義されたヘッダファイル.hに書かないと意味ないの?
35:34
09/05/05 11:44:16
ただしMyClassクラスの定義されたヘッダファイル.hは
変更されないように極力努めるが、
実装ファイル.cpp(MyClass_implの定義と実装が書かれている)が
しょっちゅう変更される物として。
お願いします。
36:デフォルトの名無しさん
09/05/05 12:33:26
>>35
MyClass.cppでfooの実装とMyClassImpl.hをインクルードすれば済むんじゃね?
37:デフォルトの名無しさん
09/05/05 13:56:10
別にimplがクラスである必要はネエ、PODでもOKと考えれば判ること。
cpp内でPOD*をキャッチボールしたりコンストラクタが役立たずになったりして
コンパイラの最適化お仕事の邪魔になるだろうけど
38:34
09/05/05 14:53:46
ふむ、となると、
int MyClass::foo()
{return pimpl->foo();}
これはどこに書くといいのかい?
39:デフォルトの名無しさん
09/05/05 15:17:54
そもそもそれヘッダに書けるの?
MyClass_implの定義は実装ファイル.cppに書かれてるんでしょ?
40:34
09/05/05 15:26:33
>>39
あ・・・そもそもMyClass_implが不完全型だから
fooを持っているかどうか分からないから書けないのか。
ごごごごごごごめん
正直すまんかった。
41:デフォルトの名無しさん
09/05/05 15:32:19
>>38
cppに書けば実装を隠蔽できる
42:デフォルトの名無しさん
09/05/05 15:33:02
>>37
ん?ClassとPlain Old Data、どっちで_implを実装すべきだというのだい?
興味あるからその辺の話を聞かせてほしい。
43:34
09/05/05 15:35:27
>>41
pimplには実装の隠蔽という役割もあったか。
よし、本気で勉強してみるわ。thx
44:デフォルトの名無しさん
09/05/05 15:44:06
POD*を丸々投げ返す様なローカル関数が無けりゃどっちでも良いんじゃないかな
45:42
09/05/05 15:46:08
>>44
ほう、特にどちらでもおk、と。
どうも。
46:42
09/05/05 23:18:16
しかし中々興味深いな。
明確な解ではないとはいえ、私の情報論理構成の範疇外の事象とは。
おっと、言葉が過ぎたようだ。また組織から小言をもらってしまう。
では。
47:42
09/05/05 23:28:50
>>46
おい成りすますなよ
オレオレ詐欺かw
48:42
09/05/06 02:15:10
私はバカです。
49:42
09/05/06 02:16:48
釣れた!
50:デフォルトの名無しさん
09/05/06 12:26:54
std::cout << HOGE << ':' << PIYO << std::endl;
みたいに書く時って、
std::cout << HOGE << ":" << PIYO << std::endl;
とどっちがいいの?
51:デフォルトの名無しさん
09/05/06 13:18:40
どちらでもお好きに。
52:デフォルトの名無しさん
09/05/06 13:20:44
1バイトのみの出力であれば、「NUL文字までループ」しない分、前者の方がわずかながら速いだろう。
しかし気にするほどではない。
53:デフォルトの名無しさん
09/05/06 13:24:50
考え方によっては":"が何回も出て来るなら、
同じ文字列をマージする最適化をコンパイラが行うとかは考えられない?
54:デフォルトの名無しさん
09/05/06 14:13:20
考えたくない
55:11
09/05/06 14:19:35
また来てすみません
コンテナのa < b
lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())
sed::setの場合は格納している値を辞書式に比較すると言うことでしたが、
std::mapの場合はどうなるのでしょうか?
mapの格納している要素はkeyと値の組になっていますが
どちらで比較するのでしょうか?
サンプルソース
C++ code - 51 lines - codepad
URLリンク(codepad.org)
mymap<yourmapがtrueとなるのは
Rule1:mymapの最初のkey < yourmapの最初のkey の時。
Rule2:(mymapの最初のkey == yourmapの最初のkey) ならば (mymap[key]で得られる値 < yourmap[key]で得られる値) の時。
Rule3:最初のkeyも最初の値も同じなら、次の要素でRule1, Rule2を適用する。
Rule4:Rule3にてmymapの方がyourmapより先に次の要素が無くなった時。
といった感じがするのですが、ご存じの方いらっしゃいますか?
56:50
09/05/06 14:20:47
>>51-54
どうでも良い程度の差ってことか。
どうも。
57:デフォルトの名無しさん
09/05/06 14:25:31
VS2008をダウンロードして起動してみたのですが、
全くどう使っていいのかわかりません…
画像付きで解説してるサイトはありませんか?
とりあえずハローワールドすら出来ないと泣きそうです
VBAなら少しさわったことあります
よろしくお願いします
58:デフォルトの名無しさん
09/05/06 14:28:56
>>57
★初心者にVisual C++を教えるスレ★ Part33
スレリンク(tech板)
59:デフォルトの名無しさん
09/05/06 14:29:25
URLリンク(msdn.microsoft.com)
60:デフォルトの名無しさん
09/05/06 14:33:21
>>58
おお、そんなスレがありましたか失礼しました
>>59
ありがとうございます!
61:11
09/05/06 15:31:33
>>55
・・・な〜んか違うよーな。
コンテナの比較って相変わらず分からないです。
62:デフォルトの名無しさん
09/05/06 15:39:41
>>61
あってんじゃね?俺も知らんけど、見た感じそうなってると思う。
63:デフォルトの名無しさん
09/05/06 15:56:35
その理解でいいだろ。
lexicographical_compare(a.begin(), a.end(), b.begin(), b.end())
は対応するイテレータがそれぞれ参照している要素をoperator<で比較していく。
mapのイテレータが参照しているのはpair<key_type,mapped_type>。
pair<first_type,second_type> x,y に対して x < y が真になるのは
x.first < y.first または !(y.first < x.first) && x.second < y.second が真になるとき。
64:デフォルトの名無しさん
09/05/06 15:58:48
>>63
× !(y.first < x.first) && x.second < y.second
○ y.first == x.first && x.second < y.second
65:64
09/05/06 16:07:08
あ、pairって等価ベースだったか。すまん。
66:デフォルトの名無しさん
09/05/06 17:49:02
本を買って通勤中や暇な時間に勉強しようと思うのですが、
オススメはありますか?
上の方のレス見たらそんな本は捨てた方がいいとか書いてあって怖くなりました(間違った知識がつくんじゃないかと)
とりあえず古本屋も見てみたのですが、10年ぐらい前のしかありませんでした…
67:デフォルトの名無しさん
09/05/06 17:56:43
やさしいC++ 第3版
68:デフォルトの名無しさん
09/05/06 17:58:45
ありがとー!
さっそく買ってきます
69:デフォルトの名無しさん
09/05/06 19:11:35
レビューとか読んでからにしろよ。
70:デフォルトの名無しさん
09/05/06 19:36:39
教えてください、以下のプログラムでいい方法がないものかと。
またはC++的にはこう書いた方が正しい等です。
//-------------------
class AA { int a1; };
//-------------------
class BB {
AA **app;
void setapp(int no) {
app = new (*AA)[no]; //<-ここが不明 エラーになる
}
};
//-------------------
int _tmain(int argc, _TCHAR* argv[])
{
BB dat;
dat.setapp(10);
}
1.<−−ここが不明の部分の書き方
2.こんなのは良くない、もっといい方法がある。
の2つです。お願いします。
71:11
09/05/06 20:30:32
>>62-63
ありがとうございます。
最終的には、>>55の見解で良いとのことですが、
(pairが)等価ベースとはどういう事でしょうか?
72:デフォルトの名無しさん
09/05/06 20:34:12
>>70
エラーメッセージが読めるようになってからまたお越し下さい。
73:デフォルトの名無しさん
09/05/06 20:37:40
>>70
もしかして多言語の経験者かい?
74:70
09/05/06 20:43:33
error C2226: 構文エラー : 'AA' 型指定子の前あるいは内部で構文エラーが発生しました。
エラーメッセージは上記です。 正直わからないから聞いているので。
答えられないのであればあきらめます。
75:デフォルトの名無しさん
09/05/06 20:45:14
>>74
> 答えられないのであればあきらめます。
ああそうか、じゃあ俺の頭じゃ答えられないわ。
76:デフォルトの名無しさん
09/05/06 20:46:35
app = new AA*[no];
77:70
09/05/06 20:52:41
>>76
出来ました、ありがとうございます。
所で、クラスの配列を動的に作ってアクセスする場合。
この様なポインターの配列をnewしてクラスデーターを入れて管理するのは。
ごく普通のやり方でしょうか? どうもなんか、いまいちなような気がして・・・
78:デフォルトの名無しさん
09/05/06 20:53:01
>>70
> 2.こんなのは良くない、もっといい方法がある。
強いて挙げると
newで得た配列はデフォルトコンストラクタでしか初期化されません。
ポインタの(と言いますか組み込み型の)配列となると全く初期化されませんけど大丈夫ですか?
ということと
setappがpublic:じゃいのでアクセスできませんよ。
ということと
忘れずにdeleteしてくださいね
ということと
もしかしたらnewで例外が発生するかもしれませんよ
ぐらいかな。
79:デフォルトの名無しさん
09/05/06 20:57:12
一応、std::vector を使うのがいいかなと思う。std::vector<AA*> って感じ。
これでも>>78の問題はほとんどそのままだが。
80:78
09/05/06 20:58:23
>>77
そもそも>>70だとAAのインスタンスは一つも存在していないんだけど、
それは分かっている?分かっていない?
81:70
09/05/06 21:00:59
public:忘れてました、すみません。 最終的に
//-------------------
class AA { int a1[10]; };
//-------------------
class BB {
public:
AA **app;
void setapp(int no) {
app = new AA*[no]; //<-ここが不明
}
};
//-------------------
int _tmain(int argc, _TCHAR* argv[])
{
BB dat;
dat.setapp(3);
dat.app[0] = new AA();
dat.app[1] = new AA();
dat.app[2] = new AA();
}
こんな感じでうまくいったのですが、本当にこのままでいいのだろうかという疑問が・・・
82:70
09/05/06 21:06:15
std::vector 使ったことないです、調べて見ます。ありがとうございます
83:デフォルトの名無しさん
09/05/06 21:08:14
あとはboost::ptr_vector<AA>とか
84:78
09/05/06 21:10:22
>>81
> こんな感じでうまくいったのですが、本当にこのままでいいのだろうかという疑問が・・・
>>78にあるとおり、良くない。
いつdeleteするかとか、newが4回あるうちのどこかで例外が発生しうるがその時はどうするかとかは?
たぶんboostないしstd::tr1のshared_ptrが必要になるのではないでしょうかね。
・・・ってstd::vector使ったこと無いのか。
じゃあまずSTLのお勉強だな。
85:デフォルトの名無しさん
09/05/06 21:14:26
STLの前にポインタの勉強からじゃ
86:デフォルトの名無しさん
09/05/06 23:45:57
構成上、どうしてもコンストラクタで例外を投げたいんだけど、
良いんだよね?別に。
そう言うこともあるよね?
87:デフォルトの名無しさん
09/05/06 23:50:53
某サイトで「コンストラクタで例外を投げるな」なんて書いた人がいたけど
基本的には問題ないし、コンストラクタで正常にオブジェクトの構築が出来ないときは
例外を投げるのが最も適切。
もし、気になっている問題があるなら、具体的に書いてもらってもいいけど。
88:デフォルトの名無しさん
09/05/07 00:05:27
>>86
全く問題ないよ。
89:デフォルトの名無しさん
09/05/07 00:13:08
>>71
> (pairが)等価ベースとはどういう事でしょうか?
その元レスは直前のレスに対する独り言のようなものだろうから文面をそのまま受け取っては駄目。
おそらく以下の説明のようなことを踏まえての発言。
pairのoperator<はまずfirst同士を比較して、それが等しければsecond同士を比較するという流れ。
ここで等しければを判定するのに等値かどうかで判定するのではなく等価かどうかで判定する。
90:デフォルトの名無しさん
09/05/07 00:21:12
>>86
後始末が必要なものをしっかりかたづけてればおk。
A(){
h = gethandle(); // 後で明示的に解放する必要あり
/* このあとに例外投げるかもしれない処理を行う */
}
~A(){
releasehandle(h);
}
みたいな場合、例外をコンストラクタの外に投げる前に後始末が必要。
91:デフォルトの名無しさん
09/05/07 00:32:28
「解放すべきもの(newで確保されたメモリや、その他のリソースなど)を保持してデストラクタで解放する」
という仕事をするためのクラスを利用すると、例外に対処しやすい。
そういうクラス自体の設計時は例外安全に注意する必要がある(コンストラクタでうかつに例外を投げてはならない)
が、そういうクラスの利用者のほうは適当に例外を投げてもリソースリークが起こらないようになる。
92:デフォルトの名無しさん
09/05/07 00:44:59
日本語でおk
93:91
09/05/07 01:02:48
>>92は俺に言ってる?
例えばスマートポインタを使う場合が最も分かりやすい。
次のようなクラス MyClass があったとする。
class MyClass {
public:
MyClass();
~MyClass();
private:
MyAnotherClass* p;
};
で、MyClass::MyClass() の内部で p = new MyAnotherClass(); などとして、
MyClass::~MyClass() で delete p; しているとする。この場合、MyClass::MyClass() が迂闊に例外を
スローすると、MyClass::~MyClass() が実行されないためにpが解放されない場合があるから、
例外をスローする場合はpの解放がきちんとされるように、注意深くコードを書かなければならない。
ただし、メンバ変数 p をポインタではなくスマートポインタとすると、そのような注意は不要となる。
例えば std::auto_ptr<MyAnotherClass> p; となっていて、MyClass::MyClass() の内部で
p(new MyAnotherClass()); とした場合、たとえMyClass::MyClass()が例外をスローしても
newされたものはちゃんと解放されるから、神経質にならなくて済む。
忘れてはならないのは、スマートポインタのコンストラクタが迂闊に例外をスローしてしまうと、
結局、リソースリークの可能性は消えないということだ。まあ自分でスマートポインタを書いて使うことは
普通の人はないと思うけど、実際 boost::shared_ptr 等はコンストラクタで例外を投げる場合があり、
その場合でもリソースリークが起こらないようにちゃんと配慮されている。
94:91
09/05/07 01:08:31
ごめん、std::auto_ptr 使って p(new MyAnotherClass()); は無いね。
コンストラクタのメンバ初期化子に書いたと思ってくれ。
95:デフォルトの名無しさん
09/05/07 08:24:20
>>91
「そういうクラス」「そういうクラスの利用者」って何?
「そういうクラスの利用者『のほう』」って何と比べてるの?
96:デフォルトの名無しさん
09/05/07 10:34:03
>>95
文脈から明らかでないか?
97:デフォルトの名無しさん
09/05/07 11:10:34
明らかじゃないから聞いてるんだろ。
明らかだと思うなら、どう明らかか書けばいい。
98:デフォルトの名無しさん
09/05/07 11:16:18
例えば、>>93が>>91の説明であるならば、
>>93に登場するクラスのどれが、「そういうクラス」に相当するのか?
99:11
09/05/07 11:35:51
>>89
等値(equality)
a == b
等価(equivalence)
!(a < b) && !(b < a)
これの事ですね。
ありがとうございました。
100:デフォルトの名無しさん
09/05/07 11:36:10
>>98
std::auto_ptr とか boost::shared_ptr とかが「そういうクラス」。
101:100
09/05/07 11:37:50
まあクラスじゃなくてクラステンプレートか。
std::auto_ptr<MyAnotherClass> とかが「そういうクラス」だと思ってもらえれば。
102:86
09/05/07 11:51:26
>>87-101
サンクス。
でかいクラスじゃなく、リソース漏れも起こすことはないハズのコーディングにしてあるので
大丈夫だ。どうも!
103:デフォルトの名無しさん
09/05/07 15:40:22
>>101
thx
104:デフォルトの名無しさん
09/05/09 16:12:48
std::vector< std::pair< key_t, value_t > > v;
for( std::vector< std::pair< key_t, value_t > >::iterator i = i.begin();....
というコードがあるとして、for文の「std::vector< std::pair< key_t, value_t > >」のように
長いテンプレート型書く必要が多々あり、それが面倒に感じます。
「v.self_type」のような、変数名から型を引っ張ってくるような
仕組みは出来ないものでしょうか?
105:デフォルトの名無しさん
09/05/09 16:15:39
typedef すれば?
106:デフォルトの名無しさん
09/05/09 16:22:02
次期規格でdecltypeというのが出来るが今は無理
107:デフォルトの名無しさん
09/05/09 16:25:10
typedef しとけ
108:デフォルトの名無しさん
09/05/09 16:32:54
>>105-107
承知しました。
ありがとうございました。
109:デフォルトの名無しさん
09/05/09 17:09:32
decltype よりゃ auto じゃね
110:デフォルトの名無しさん
09/05/09 17:10:34
>>107
だからC++03ではtypmlateのtypedefは無理だっつーに
111:デフォルトの名無しさん
09/05/09 17:11:17
×typmlate
○template
112:デフォルトの名無しさん
09/05/09 17:16:55
>>110
部分特殊化のような形の typedef は無理だが
>>104 みたいなのは全く問題ないっつーか、常套手段だろ
113:デフォルトの名無しさん
09/05/09 17:17:48
>>110
パラメータが確定してるテンプレートクラスならできるぞ
できないのはtypedefのテンプレート
114:デフォルトの名無しさん
09/05/09 17:17:57
>>110
・・・まさかやったこと無いわけじゃないよな?
115:デフォルトの名無しさん
09/05/09 17:21:48
typedef typename std::vector< std::pair< key_t, value_t > > hoge;
通りませんでしたよ^^
VC2008
116:デフォルトの名無しさん
09/05/09 17:30:40
typename要らない
117:デフォルトの名無しさん
09/05/09 17:55:02
釣り臭いな
118:デフォルトの名無しさん
09/05/09 18:03:04
>>115
using alias使うんだよ
using hoge = std::vector< std::pair< key_t, value_t > >;
119:デフォルトの名無しさん
09/05/09 18:19:02
素だろ
また的外れてるし。
120:デフォルトの名無しさん
09/05/09 18:48:32
>通りませんでしたよ^^
これは釣りだろ
121:デフォルトの名無しさん
09/05/09 23:06:38
VC++の学習用にサブPCを導入しようと思うのですが、
atom330でも問題なさそうでしょうか
あまりに重そうならE1400辺りで自作しようと思います
122:デフォルトの名無しさん
09/05/09 23:46:34
別に問題ないだろ
IDE使いたいなら話は別だが
123:デフォルトの名無しさん
09/05/10 00:12:43
>>121
全く問題ないよ。
IDE使ったところで問題なんて起きないから大丈夫。
124:デフォルトの名無しさん
09/05/10 00:20:19
VC++2008EE使っていますが、
変数の値を常に表示する方法はありますか?
現在はcout<<hoge;みたいなものを随所に入れています
VBにあったウォッチウィンドウみたいな奴が欲しいです・・
125:デフォルトの名無しさん
09/05/10 00:34:37
メニューの
デバッグ|ウィンドウ|ウォッチ
デバッグ|クイックウォッチ
126:デフォルトの名無しさん
09/05/10 00:34:47
>>124
無いわけ無い。
それともEEだと存在しないとか??
127:デフォルトの名無しさん
09/05/10 00:44:28
>>125-126
URLリンク(www1.axfc.net)
ないっぽいです・・
イミディエイトウィンドウならあるんですが、無料だとこんなものかもしれません
128:デフォルトの名無しさん
09/05/10 00:51:16
>>127
メニューにはデバッグ実行中でないと出てこないはず
というか、初期状態でデバッグ実行したら下に自動変数とかローカル変数のタブ出てこない?
129:デフォルトの名無しさん
09/05/10 00:53:32
確かに間違って閉じちゃうと探すのに苦労するね
130:デフォルトの名無しさん
09/05/10 00:55:52
ああ、出てきましたありがとう!!!
コッソリタブが増えてました
こりゃ気づきませんぜ・・
131:デフォルトの名無しさん
09/05/10 05:03:03
>>130
いや、まぁ・・・気づくけどな。
132:デフォルトの名無しさん
09/05/10 09:21:46
誰でもそりゃわかってりゃ気づくけどな。
普通はなかなか気づかないだろう。
133:デフォルトの名無しさん
09/05/10 09:26:07
VC6の時代から使ってる人なら「必ずあるはずだ」って必死に探すなw
134:デフォルトの名無しさん
09/05/10 09:29:17
有用なサービスほど消えることは無い、 無いよな、 しかし気がつくと、 いや、無いと言ってくれー
135:デフォルトの名無しさん
09/05/10 11:09:06
メニューから消えてるだけのこともある
いくつかのショートカットキーとか
136:デフォルトの名無しさん
09/05/10 17:08:18
動的なハッシュテーブルを作っていて、[]演算子をオーバーロードしようと考えているんですが、
代入する時と参照する時とで挙動が完全に変わってしまいます。
C#のgetメソッドやsetメソッドのような完全な書き分けってどうやるんでしたっけ。
137:デフォルトの名無しさん
09/05/10 17:12:27
そういう書き分けは無いのでやるなら別関数にすれ
挙動が異なるなら、別の表記を取るのが一番間違いが無い
138:デフォルトの名無しさん
09/05/10 17:13:10
書き分けは無理
proxyクラスでも使え
139:デフォルトの名無しさん
09/05/10 17:13:45
const メンバ関数か非 const メンバ関数かという差で挙動を変える事はできるが、
それで大丈夫なものなのかは疑問だ
140:デフォルトの名無しさん
09/05/10 17:14:40
[] の戻り値をクラスにする方法もあるけど・・・
個人的にはあまり好きではないな
141:136
09/05/10 17:16:05
>>137-139
thx
いくらヘルプを読んでも分からないわけだ。
142:136
09/05/10 17:16:58
>>140
やっぱそれしかないか・・・
143:デフォルトの名無しさん
09/05/10 17:18:27
演算子のオーバーロードはあまり乱用すべきものではないので
細かい技法を使わないと演算子のオーバーロードでは実現できないような処理は
普通のメンバ関数にしてしまった方がいいと個人的には思う
144:デフォルトの名無しさん
09/05/10 17:48:08
>代入する時と参照する時とで挙動が完全に変わってしまいます。
同じように見せたいのなら<map>みたいにすればいいと思うけど
145:デフォルトの名無しさん
09/05/10 18:00:21
std::cin >> hoge;で受け取れるような自作クラスMyClassのオペレータオーバーロードはどうすればよいのですか?
std::cout << hoge;ならサンプルコードが良く見つかるのですが。。。
146:デフォルトの名無しさん
09/05/10 18:17:54
同じようにすりゃ良いじゃん
147:デフォルトの名無しさん
09/05/10 18:22:19
>>146
というのは、例えば
std::string str;
std::cin >> str;
としてstrから適切に処理すれば良いってことですか?
148:デフォルトの名無しさん
09/05/10 18:32:28
std::complex<> を参考にしろよ
(n,m) の形式で読み取るが、どのようにして実現しているのか
考えるのも楽しいものだ
149:デフォルトの名無しさん
09/05/10 18:33:27
istream &operator >>( istream&, const MyClass& );
150:147
09/05/10 19:52:38
>>148
ありがとうございます。
さっそく見てみます。
>>149
ありがとうございます。
宣言の方は
std::ostream& operator << 〜
で理解しました。
151:デフォルトの名無しさん
09/05/10 21:46:01
C++ code - 31 lines - codepad
URLリンク(codepad.org)
このソースはgccに付いてきた
std::complex<〜>のstd::istream& operator>>(std::istream&,complex&);のソースなのですが、
この
if (__ch == ')')
__x = complex<_Tp>(__re_x, __im_x);
else
__is.setstate(ios_base::failbit);
が何をしているのか分かりません。
自分なりに推測するとstd::istreamで読み込んでいった結果、所定のフォーマットになっていない(閉じ括弧がおかしい)場合にエラーを伝えるべくsetstateとやらをしているようなのですが、
__is.setstate(ios_base::failbit);
ってどういう意味ないし効力なのでしょうか?
152:デフォルトの名無しさん
09/05/10 22:00:38
std::ios::failbit が立つと、それ以降の入力は一切行われなくなる
これがCとは違う所
この状態をクリアするにはis.clear()を行う
153:151
09/05/10 22:02:27
>>152
フラグ立てですか。
読み込みに失敗したと言うことで、エラー状態にしているわけですね。
ありがとうございます。
・・・でも何で例外を投げる仕様にしなかったのでしょう?
使いづらそうな。。。
154:デフォルトの名無しさん
09/05/10 22:04:40
C++の本ってみんな今何読んでる?
155:デフォルトの名無しさん
09/05/10 22:05:30
今は何も読んでない
156:デフォルトの名無しさん
09/05/10 22:06:21
>>153
例外を投げる事もできる
ただ歴史的経緯があって例外がC++に存在しなかった時代から
iostreamは使われて来ているわけでデフォルトで例外はOFFに
されている
例外を投げるにはメンバ関数exceptions()にトリガとなるビットを
セットすればよい
157:153
09/05/10 22:14:28
>>156
なるほどー!
サンクス。了解できた。
158:デフォルトの名無しさん
09/05/10 22:15:39
>>154
Boost C++ libraries 第二版
159:デフォルトの名無しさん
09/05/10 22:45:39
>>154
はじめてのC。
電車の中で立ち読みして
JKやOLからの冷たい視線でたまらなく興奮する人にお勧め。
160:デフォルトの名無しさん
09/05/10 22:48:21
>>154
やさしいC++
電車の中で読む度胸はないぜ
161:デフォルトの名無しさん
09/05/11 00:01:31
配列に配列を代入したいときは、
配列1[i]=配列2[i]などとしてforで回すのが一般的でしょうか
162:デフォルトの名無しさん
09/05/11 00:04:14
C++なら<algorithm>のcopy関数を使う方が一般的
163:デフォルトの名無しさん
09/05/11 00:05:59
memc(ry
164:デフォルトの名無しさん
09/05/11 00:07:18
つ std::copy
一見関数だらけになるが、恐ろしいほど最適化される。
165:デフォルトの名無しさん
09/05/11 00:09:03
>>162-164
ありがとうございます
とりあえず全部試して見ます
166:デフォルトの名無しさん
09/05/11 08:04:07
>>154
Programming - Principles and Practice Using C++
167:デフォルトの名無しさん
09/05/12 22:16:57
std::vector<char> v(256);
で &v[0] を char 256個の配列として扱って良いものですか?
168:デフォルトの名無しさん
09/05/12 22:41:08
>>167
> &v[0] を char 256個の配列として扱って良いものですか?
v[0]でvの先頭要素のリファレンスが返ってくる。
そして&v[0]はそのアドレスを取得している。
よって先頭アドレスが取得できるのか?ということかい?
たしかOKと聞いたことがあるなぁ。
C++編(標準ライブラリ) 第2章 vector
URLリンク(www.geocities.jp)
の○生の配列との関連のところで。
169:デフォルトの名無しさん
09/05/12 23:11:26
>>167
ええよ
C++98とC++03間の変更点の一つにvectorはリニアアドレス↑に
取られる事が保証されたというのがある
規格票を見れば書いてあるはず
stringはまだでc++0xで保証される予定
170:デフォルトの名無しさん
09/05/13 05:29:54
GUIを考えています。
例えば、ボタンの上にマウスを持っていった時に、ヘルプメッセージを出す事を考えます。
所謂コマンドパターンによる実装になると思うのですが、
ボタンが親子関係でもないオブジェクトの参照を持つ事になり、気持ち悪く感じます。
これは気にしても仕方ない事なのでしょうか?
171:デフォルトの名無しさん
09/05/13 08:13:10
仕方ないというより、別に気持ち悪くないし。
172:デフォルトの名無しさん
09/05/13 18:48:03
履歴一覧を表示する元に戻すボタンでも実装するのか?
>所謂コマンドパターン
って言ってみたかっただけなんじゃ
173:167
09/05/13 21:17:48
>>168, 169
ありがとうございます。
std::string の c_str() のようにポインタを取得するというメソッドが
無いので、もしかしてやっちゃいけないことなのかと不安に思ったのです。
174:デフォルトの名無しさん
09/05/13 21:43:46
C/C++の趣味グラマなんだけど、
アセンブラも勉強した方がいいのかな?
175:デフォルトの名無しさん
09/05/13 21:47:28
わざわざしなくていいと思うよ
意識せずとも、いずれ自然に必要になって自然に勉強してる
176:174
09/05/13 21:52:03
>>175
ほほう、そんなもんなのか。ありがとう。
むしろもうちょっと高級言語も知っとこうかなぁ。。。
177:デフォルトの名無しさん
09/05/13 23:27:37
C/C++をやると平気でインラインアセンブラを書くようになるよな
特にSSE2/SSE3関連は
178:デフォルトの名無しさん
09/05/14 00:48:26
>>171,172
クラスの関連が複雑になるのと、オブジェクトの寿命管理の点が気になりました。
> 履歴一覧を表示する元に戻すボタンでも実装するのか?
これも1つです。
ソースの見通しが悪くなり、あとで機能を追加したいと思った時に困るのではないかと思いました。
179:デフォルトの名無しさん
09/05/14 01:13:32
ササビーってIntelから出るけどあれどうなの?
次ページ最新レス表示スレッドの検索類似スレ一覧話題のニュースおまかせリスト▼オプションを表示暇つぶし2ch
5007日前に更新/243 KB
担当:undef