C++相談室 part69

このエントリーをはてなブックマークに追加
1デフォルトの名無しさん
C++に関する質問やら話題やらはこちらへどうぞ。
ただし質問の前にはFAQに一通り目を通してください。
IDE (VC++など)などの使い方の質問はその開発環境のスレに
お願いします。

前スレ
C++相談室 part66
http://pc12.2ch.net/test/read.cgi/tech/1231640498/

※part63, part66 が重複していたようですので part69 としました。
2デフォルトの名無しさん:2009/05/04(月) 21:07:52
STLつかうと一気に実行ファイルサイズが10倍に?!

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

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

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

#include <stdafx.h>
後死ね。

言葉が悪いな。それで教えているつもりか。
まぁヒントぐらいにはなったな。
うむごくろう。
3デフォルトの名無しさん:2009/05/04(月) 21:09:01
■基本■
[C++ FAQ]
 http://www.parashift.com/c++-faq-lite/
 http://www.bohyoh.com/CandCPP/FAQ/ (日本語)
  Cとその仕様を比較しながらの解説なので分かりやすい。
  ***** 質問の前に必ずこの二つに目を通してください *****
[C/C++ リファレンス]
 http://www.cppreference.com/ (英語)
 http://www.cppll.jp/cppreference/ (↑の日本語訳だけど最新は反映しない)
[禿 Stroustrup]
 http://public.research.att.com/~bs/
[C++ International Standard]
 http://www.iso.org/iso/iso_catalogue/catalogue_tc/catalogue_detail.htm?csnumber=38110
[JTC1/SC22/WG21 - C++]
 http://www.open-std.org/jtc1/sc22/wg21/
  ここから規格の最新(2003より新しい)ドラフトがダウンロードできる。
[JIS X3014]
 http://www.jisc.go.jp/app/pager?&RKKNP_vJISJISNO=X3014
  ISO規格の日本語訳。JIS X 3014:2003はISO/IEC 14882:2003 (E)に対応。
4デフォルトの名無しさん:2009/05/04(月) 21:09:17
5デフォルトの名無しさん:2009/05/04(月) 21:09:39
6デフォルトの名無しさん:2009/05/04(月) 21:12:23
入門ページなど

http://www.cplusplus.com/

・入門,一覧,使い方
http://www5c.biglobe.ne.jp/~ecb/cpp/07_01.html
・メソッド一覧
http://www.wakhok.ac.jp/~sumi/stl/
・サンプルプログラム集
http://www.s34.co.jp/cpptechdoc/reference/stl_samples/
7デフォルトの名無しさん:2009/05/04(月) 21:13:06
>3-5は古いスレから持ってきたのでリンク切れ等あると思います。
とりあえず、
Apache STDCXX http://incubator.apache.org/stdcxx/

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

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

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

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

boost info
http://shinh.skr.jp/boost/
9デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/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:2009/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デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/04(月) 22:23:27
あ、size()も見ているようですね
size()が等しくかつ単純比較で大小を決めているようです

1,3,5
1,2,6 のような場合はどちらが大きくなるかと、辞書順、つまり
最初に見つかった違いで判断しているようです
14デフォルトの名無しさん:2009/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";
}
1511:2009/05/04(月) 22:47:18
>>14
謎ですよね。ありがとうございます。
今、決定打を探してみています。
16デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/04(月) 22:54:42
かぶったゴメン
という事で辞書順という事で決まり・・・みたいですね
19デフォルトの名無しさん:2009/05/04(月) 23:06:37
多分順序が付いているということが大事で、その付け方はそんなに重要じゃないと思う
setの入れ子とかが出来るように適当に全順序決めてるだけだろうから
2011:2009/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デフォルトの名無しさん:2009/05/04(月) 23:12:42
>>20
std::lexicographical_compare()の動作の仕方を理解できればいいよ
2211:2009/05/04(月) 23:15:13
いや、そう変に考えなくても単に先頭から見て大きい方を大きいと見なすってだけですね。
setやmultisetが自動でソートされるから紛らわしいと感じるだけでした。

23デフォルトの名無しさん:2009/05/04(月) 23:32:14
たまには頭のいい体操になるな
2411:2009/05/04(月) 23:34:18
>>21
OKです。ありがとうございます。
25デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/05(火) 04:06:33
>>25
ソースから作った?あと、ATLAS組み込んだ?
ATLASをgcc4&SSE4&マルチコア構成でmakeしてみて
liboctaveに組み込めばかなり高速化すると思う。

SVDの演算ならそんなもんだよ。
そんなに速度が欲しいなら、精度無視してNNを使った方法を取ったら?
27デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/05(火) 10:08:19
>>27
引数なしのコンストラクタが呼ばれます
29デフォルトの名無しさん:2009/05/05(火) 10:39:31
intとかについては T() の結果がマチマチじゃなかったかねえ
30デフォルトの名無しさん:2009/05/05(火) 10:40:13
>>28
はい、それですと、
int型のクラスで言うところのデフォルトコンストラクタ
により0で初期化してくれるのですか?

たとえばstd::string str;だとデフォルトコンストラクタにより""になりますけど
int i;だと初期化されませんよね。

・・・と思いましたが、そう言えばint()で0が返るんでしたね
失礼しました。
31デフォルトの名無しさん:2009/05/05(火) 10:42:00
>>29-30
組み込み型でもT()で全て初期化してくれるんじゃなかったか?
誰か有識者plz
32デフォルトの名無しさん:2009/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の場合は不定値と決まっている
3330:2009/05/05(火) 11:07:19
>>32
理解出来ました!
ありがとうございました。
34デフォルトの名無しさん:2009/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に書かないと意味ないの?
3534:2009/05/05(火) 11:44:16
ただしMyClassクラスの定義されたヘッダファイル.hは
変更されないように極力努めるが、
実装ファイル.cpp(MyClass_implの定義と実装が書かれている)が
しょっちゅう変更される物として。
お願いします。
36デフォルトの名無しさん:2009/05/05(火) 12:33:26
>>35
MyClass.cppでfooの実装とMyClassImpl.hをインクルードすれば済むんじゃね?
37デフォルトの名無しさん:2009/05/05(火) 13:56:10
別にimplがクラスである必要はネエ、PODでもOKと考えれば判ること。
cpp内でPOD*をキャッチボールしたりコンストラクタが役立たずになったりして
コンパイラの最適化お仕事の邪魔になるだろうけど
3834:2009/05/05(火) 14:53:46
ふむ、となると、
int MyClass::foo()
{return pimpl->foo();}
これはどこに書くといいのかい?
39デフォルトの名無しさん:2009/05/05(火) 15:17:54
そもそもそれヘッダに書けるの?
MyClass_implの定義は実装ファイル.cppに書かれてるんでしょ?
4034:2009/05/05(火) 15:26:33
>>39
あ・・・そもそもMyClass_implが不完全型だから
fooを持っているかどうか分からないから書けないのか。

ごごごごごごごめん

 正直すまんかった。
41デフォルトの名無しさん:2009/05/05(火) 15:32:19
>>38
cppに書けば実装を隠蔽できる
42デフォルトの名無しさん:2009/05/05(火) 15:33:02
>>37
ん?ClassとPlain Old Data、どっちで_implを実装すべきだというのだい?
興味あるからその辺の話を聞かせてほしい。
4334:2009/05/05(火) 15:35:27
>>41
pimplには実装の隠蔽という役割もあったか。
よし、本気で勉強してみるわ。thx
44デフォルトの名無しさん:2009/05/05(火) 15:44:06
POD*を丸々投げ返す様なローカル関数が無けりゃどっちでも良いんじゃないかな
4542:2009/05/05(火) 15:46:08
>>44
ほう、特にどちらでもおk、と。
どうも。
4642:2009/05/05(火) 23:18:16
しかし中々興味深いな。
明確な解ではないとはいえ、私の情報論理構成の範疇外の事象とは。
おっと、言葉が過ぎたようだ。また組織から小言をもらってしまう。
では。
4742:2009/05/05(火) 23:28:50
>>46
おい成りすますなよ
オレオレ詐欺かw
4842:2009/05/06(水) 02:15:10
私はバカです。
4942:2009/05/06(水) 02:16:48
釣れた!
50デフォルトの名無しさん:2009/05/06(水) 12:26:54
std::cout << HOGE << ':' << PIYO << std::endl;
みたいに書く時って、
std::cout << HOGE << ":" << PIYO << std::endl;
とどっちがいいの?
51デフォルトの名無しさん:2009/05/06(水) 13:18:40
どちらでもお好きに。
52デフォルトの名無しさん:2009/05/06(水) 13:20:44
1バイトのみの出力であれば、「NUL文字までループ」しない分、前者の方がわずかながら速いだろう。
しかし気にするほどではない。
53デフォルトの名無しさん:2009/05/06(水) 13:24:50
考え方によっては":"が何回も出て来るなら、
同じ文字列をマージする最適化をコンパイラが行うとかは考えられない?
54デフォルトの名無しさん:2009/05/06(水) 14:13:20
考えたくない
5511:2009/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
ttp://codepad.org/XOdZ3Avt

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より先に次の要素が無くなった時。
といった感じがするのですが、ご存じの方いらっしゃいますか?
5650:2009/05/06(水) 14:20:47
>>51-54
どうでも良い程度の差ってことか。
どうも。
57デフォルトの名無しさん:2009/05/06(水) 14:25:31
VS2008をダウンロードして起動してみたのですが、
全くどう使っていいのかわかりません…
画像付きで解説してるサイトはありませんか?

とりあえずハローワールドすら出来ないと泣きそうです
VBAなら少しさわったことあります
よろしくお願いします
58デフォルトの名無しさん:2009/05/06(水) 14:28:56
>>57
★初心者にVisual C++を教えるスレ★ Part33
ttp://pc12.2ch.net/test/read.cgi/tech/1235292263/
59デフォルトの名無しさん:2009/05/06(水) 14:29:25
60デフォルトの名無しさん:2009/05/06(水) 14:33:21
>>58
おお、そんなスレがありましたか失礼しました
>>59
ありがとうございます!
6111:2009/05/06(水) 15:31:33
>>55
・・・な〜んか違うよーな。
コンテナの比較って相変わらず分からないです。
62デフォルトの名無しさん:2009/05/06(水) 15:39:41
>>61
あってんじゃね?俺も知らんけど、見た感じそうなってると思う。
63デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/06(水) 15:58:48
>>63
× !(y.first < x.first) && x.second < y.second
○ y.first == x.first && x.second < y.second
6564:2009/05/06(水) 16:07:08
あ、pairって等価ベースだったか。すまん。
66デフォルトの名無しさん:2009/05/06(水) 17:49:02
本を買って通勤中や暇な時間に勉強しようと思うのですが、
オススメはありますか?
上の方のレス見たらそんな本は捨てた方がいいとか書いてあって怖くなりました(間違った知識がつくんじゃないかと)

とりあえず古本屋も見てみたのですが、10年ぐらい前のしかありませんでした…
67デフォルトの名無しさん:2009/05/06(水) 17:56:43
やさしいC++ 第3版
68デフォルトの名無しさん:2009/05/06(水) 17:58:45
ありがとー!
さっそく買ってきます
69デフォルトの名無しさん:2009/05/06(水) 19:11:35
レビューとか読んでからにしろよ。
70デフォルトの名無しさん:2009/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つです。お願いします。
7111:2009/05/06(水) 20:30:32
>>62-63
ありがとうございます。
最終的には、>>55の見解で良いとのことですが、
(pairが)等価ベースとはどういう事でしょうか?

72デフォルトの名無しさん:2009/05/06(水) 20:34:12
>>70
エラーメッセージが読めるようになってからまたお越し下さい。
73デフォルトの名無しさん:2009/05/06(水) 20:37:40
>>70
もしかして多言語の経験者かい?
7470:2009/05/06(水) 20:43:33
error C2226: 構文エラー : 'AA' 型指定子の前あるいは内部で構文エラーが発生しました。
エラーメッセージは上記です。 正直わからないから聞いているので。
答えられないのであればあきらめます。
75デフォルトの名無しさん:2009/05/06(水) 20:45:14
>>74
> 答えられないのであればあきらめます。
ああそうか、じゃあ俺の頭じゃ答えられないわ。
76デフォルトの名無しさん:2009/05/06(水) 20:46:35
app = new AA*[no];
7770:2009/05/06(水) 20:52:41
>>76
出来ました、ありがとうございます。
所で、クラスの配列を動的に作ってアクセスする場合。
この様なポインターの配列をnewしてクラスデーターを入れて管理するのは。
ごく普通のやり方でしょうか? どうもなんか、いまいちなような気がして・・・
78デフォルトの名無しさん:2009/05/06(水) 20:53:01
>>70
> 2.こんなのは良くない、もっといい方法がある。
強いて挙げると
 newで得た配列はデフォルトコンストラクタでしか初期化されません。
 ポインタの(と言いますか組み込み型の)配列となると全く初期化されませんけど大丈夫ですか?
ということと
 setappがpublic:じゃいのでアクセスできませんよ。
ということと
 忘れずにdeleteしてくださいね
ということと
 もしかしたらnewで例外が発生するかもしれませんよ
ぐらいかな。
79デフォルトの名無しさん:2009/05/06(水) 20:57:12
一応、std::vector を使うのがいいかなと思う。std::vector<AA*> って感じ。
これでも>>78の問題はほとんどそのままだが。
8078:2009/05/06(水) 20:58:23
>>77
そもそも>>70だとAAのインスタンスは一つも存在していないんだけど、
それは分かっている?分かっていない?
8170:2009/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();
}
こんな感じでうまくいったのですが、本当にこのままでいいのだろうかという疑問が・・・
8270:2009/05/06(水) 21:06:15
std::vector 使ったことないです、調べて見ます。ありがとうございます
83デフォルトの名無しさん:2009/05/06(水) 21:08:14
あとはboost::ptr_vector<AA>とか
8478:2009/05/06(水) 21:10:22
>>81
> こんな感じでうまくいったのですが、本当にこのままでいいのだろうかという疑問が・・・
>>78にあるとおり、良くない。
いつdeleteするかとか、newが4回あるうちのどこかで例外が発生しうるがその時はどうするかとかは?
たぶんboostないしstd::tr1のshared_ptrが必要になるのではないでしょうかね。

・・・ってstd::vector使ったこと無いのか。
じゃあまずSTLのお勉強だな。
85デフォルトの名無しさん:2009/05/06(水) 21:14:26
STLの前にポインタの勉強からじゃ
86デフォルトの名無しさん:2009/05/06(水) 23:45:57
構成上、どうしてもコンストラクタで例外を投げたいんだけど、
良いんだよね?別に。
そう言うこともあるよね?
87デフォルトの名無しさん:2009/05/06(水) 23:50:53
某サイトで「コンストラクタで例外を投げるな」なんて書いた人がいたけど
基本的には問題ないし、コンストラクタで正常にオブジェクトの構築が出来ないときは
例外を投げるのが最も適切。

もし、気になっている問題があるなら、具体的に書いてもらってもいいけど。
88デフォルトの名無しさん:2009/05/07(木) 00:05:27
>>86
全く問題ないよ。
89デフォルトの名無しさん:2009/05/07(木) 00:13:08
>>71
> (pairが)等価ベースとはどういう事でしょうか?
その元レスは直前のレスに対する独り言のようなものだろうから文面をそのまま受け取っては駄目。
おそらく以下の説明のようなことを踏まえての発言。

pairのoperator<はまずfirst同士を比較して、それが等しければsecond同士を比較するという流れ。
ここで等しければを判定するのに等値かどうかで判定するのではなく等価かどうかで判定する。
90デフォルトの名無しさん:2009/05/07(木) 00:21:12
>>86
後始末が必要なものをしっかりかたづけてればおk。

A(){
 h = gethandle(); // 後で明示的に解放する必要あり
 /* このあとに例外投げるかもしれない処理を行う */
}

~A(){
 releasehandle(h);
}

みたいな場合、例外をコンストラクタの外に投げる前に後始末が必要。
91デフォルトの名無しさん:2009/05/07(木) 00:32:28
「解放すべきもの(newで確保されたメモリや、その他のリソースなど)を保持してデストラクタで解放する」
という仕事をするためのクラスを利用すると、例外に対処しやすい。

そういうクラス自体の設計時は例外安全に注意する必要がある(コンストラクタでうかつに例外を投げてはならない)
が、そういうクラスの利用者のほうは適当に例外を投げてもリソースリークが起こらないようになる。
92デフォルトの名無しさん:2009/05/07(木) 00:44:59
日本語でおk
9391:2009/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 等はコンストラクタで例外を投げる場合があり、
その場合でもリソースリークが起こらないようにちゃんと配慮されている。
9491:2009/05/07(木) 01:08:31
ごめん、std::auto_ptr 使って p(new MyAnotherClass()); は無いね。
コンストラクタのメンバ初期化子に書いたと思ってくれ。
95デフォルトの名無しさん:2009/05/07(木) 08:24:20
>>91
「そういうクラス」「そういうクラスの利用者」って何?

「そういうクラスの利用者『のほう』」って何と比べてるの?
96デフォルトの名無しさん:2009/05/07(木) 10:34:03
>>95
文脈から明らかでないか?

97デフォルトの名無しさん:2009/05/07(木) 11:10:34
明らかじゃないから聞いてるんだろ。
明らかだと思うなら、どう明らかか書けばいい。
98デフォルトの名無しさん:2009/05/07(木) 11:16:18
例えば、>>93>>91の説明であるならば、
>>93に登場するクラスのどれが、「そういうクラス」に相当するのか?
9911:2009/05/07(木) 11:35:51
>>89
等値(equality)
a == b
等価(equivalence)
!(a < b) && !(b < a)
これの事ですね。
ありがとうございました。
100デフォルトの名無しさん:2009/05/07(木) 11:36:10
>>98
std::auto_ptr とか boost::shared_ptr とかが「そういうクラス」。
101100:2009/05/07(木) 11:37:50
まあクラスじゃなくてクラステンプレートか。
std::auto_ptr<MyAnotherClass> とかが「そういうクラス」だと思ってもらえれば。
10286:2009/05/07(木) 11:51:26
>>87-101
サンクス。
でかいクラスじゃなく、リソース漏れも起こすことはないハズのコーディングにしてあるので
大丈夫だ。どうも!
103デフォルトの名無しさん:2009/05/07(木) 15:40:22
>>101
thx
104デフォルトの名無しさん:2009/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デフォルトの名無しさん:2009/05/09(土) 16:15:39
typedef すれば?
106デフォルトの名無しさん:2009/05/09(土) 16:22:02
次期規格でdecltypeというのが出来るが今は無理
107デフォルトの名無しさん:2009/05/09(土) 16:25:10
typedef しとけ
108デフォルトの名無しさん:2009/05/09(土) 16:32:54
>>105-107
承知しました。
ありがとうございました。
109デフォルトの名無しさん:2009/05/09(土) 17:09:32
decltype よりゃ auto じゃね
110デフォルトの名無しさん:2009/05/09(土) 17:10:34
>>107
だからC++03ではtypmlateのtypedefは無理だっつーに
111デフォルトの名無しさん:2009/05/09(土) 17:11:17
×typmlate
○template
112デフォルトの名無しさん:2009/05/09(土) 17:16:55
>>110
部分特殊化のような形の typedef は無理だが
>>104 みたいなのは全く問題ないっつーか、常套手段だろ
113デフォルトの名無しさん:2009/05/09(土) 17:17:48
>>110
パラメータが確定してるテンプレートクラスならできるぞ
できないのはtypedefのテンプレート
114デフォルトの名無しさん:2009/05/09(土) 17:17:57
>>110
・・・まさかやったこと無いわけじゃないよな?
115デフォルトの名無しさん:2009/05/09(土) 17:21:48
typedef typename std::vector< std::pair< key_t, value_t > > hoge;

通りませんでしたよ^^
VC2008
116デフォルトの名無しさん:2009/05/09(土) 17:30:40
typename要らない
117デフォルトの名無しさん:2009/05/09(土) 17:55:02
釣り臭いな
118デフォルトの名無しさん:2009/05/09(土) 18:03:04
>>115
using alias使うんだよ
using hoge = std::vector< std::pair< key_t, value_t > >;
119デフォルトの名無しさん:2009/05/09(土) 18:19:02
素だろ
また的外れてるし。
120デフォルトの名無しさん:2009/05/09(土) 18:48:32
>通りませんでしたよ^^
これは釣りだろ
121デフォルトの名無しさん:2009/05/09(土) 23:06:38
VC++の学習用にサブPCを導入しようと思うのですが、
atom330でも問題なさそうでしょうか
あまりに重そうならE1400辺りで自作しようと思います
122デフォルトの名無しさん:2009/05/09(土) 23:46:34
別に問題ないだろ
IDE使いたいなら話は別だが
123デフォルトの名無しさん:2009/05/10(日) 00:12:43
>>121
全く問題ないよ。
IDE使ったところで問題なんて起きないから大丈夫。
124デフォルトの名無しさん:2009/05/10(日) 00:20:19
VC++2008EE使っていますが、
変数の値を常に表示する方法はありますか?
現在はcout<<hoge;みたいなものを随所に入れています
VBにあったウォッチウィンドウみたいな奴が欲しいです・・
125デフォルトの名無しさん:2009/05/10(日) 00:34:37
メニューの
デバッグ|ウィンドウ|ウォッチ
デバッグ|クイックウォッチ
126デフォルトの名無しさん:2009/05/10(日) 00:34:47
>>124
無いわけ無い。
それともEEだと存在しないとか??
127デフォルトの名無しさん:2009/05/10(日) 00:44:28
>>125-126
ttp://www1.axfc.net/uploader/Img/so/45753.jpg
ないっぽいです・・
イミディエイトウィンドウならあるんですが、無料だとこんなものかもしれません
128デフォルトの名無しさん:2009/05/10(日) 00:51:16
>>127
メニューにはデバッグ実行中でないと出てこないはず
というか、初期状態でデバッグ実行したら下に自動変数とかローカル変数のタブ出てこない?
129デフォルトの名無しさん:2009/05/10(日) 00:53:32
確かに間違って閉じちゃうと探すのに苦労するね
130デフォルトの名無しさん:2009/05/10(日) 00:55:52
ああ、出てきましたありがとう!!!
コッソリタブが増えてました
こりゃ気づきませんぜ・・
131デフォルトの名無しさん:2009/05/10(日) 05:03:03
>>130
いや、まぁ・・・気づくけどな。
132デフォルトの名無しさん:2009/05/10(日) 09:21:46
誰でもそりゃわかってりゃ気づくけどな。
普通はなかなか気づかないだろう。
133デフォルトの名無しさん:2009/05/10(日) 09:26:07
VC6の時代から使ってる人なら「必ずあるはずだ」って必死に探すなw
134デフォルトの名無しさん:2009/05/10(日) 09:29:17
有用なサービスほど消えることは無い、 無いよな、 しかし気がつくと、  いや、無いと言ってくれー
135デフォルトの名無しさん:2009/05/10(日) 11:09:06
メニューから消えてるだけのこともある
いくつかのショートカットキーとか
136デフォルトの名無しさん:2009/05/10(日) 17:08:18
動的なハッシュテーブルを作っていて、[]演算子をオーバーロードしようと考えているんですが、
代入する時と参照する時とで挙動が完全に変わってしまいます。

C#のgetメソッドやsetメソッドのような完全な書き分けってどうやるんでしたっけ。
137デフォルトの名無しさん:2009/05/10(日) 17:12:27
そういう書き分けは無いのでやるなら別関数にすれ
挙動が異なるなら、別の表記を取るのが一番間違いが無い
138デフォルトの名無しさん:2009/05/10(日) 17:13:10
書き分けは無理

proxyクラスでも使え
139デフォルトの名無しさん:2009/05/10(日) 17:13:45
const メンバ関数か非 const メンバ関数かという差で挙動を変える事はできるが、
それで大丈夫なものなのかは疑問だ
140デフォルトの名無しさん:2009/05/10(日) 17:14:40
[] の戻り値をクラスにする方法もあるけど・・・
個人的にはあまり好きではないな
141136:2009/05/10(日) 17:16:05
>>137-139
thx

いくらヘルプを読んでも分からないわけだ。
142136:2009/05/10(日) 17:16:58
>>140
やっぱそれしかないか・・・
143デフォルトの名無しさん:2009/05/10(日) 17:18:27
演算子のオーバーロードはあまり乱用すべきものではないので
細かい技法を使わないと演算子のオーバーロードでは実現できないような処理は
普通のメンバ関数にしてしまった方がいいと個人的には思う
144デフォルトの名無しさん:2009/05/10(日) 17:48:08
>代入する時と参照する時とで挙動が完全に変わってしまいます。

同じように見せたいのなら<map>みたいにすればいいと思うけど
145デフォルトの名無しさん:2009/05/10(日) 18:00:21
std::cin >> hoge;で受け取れるような自作クラスMyClassのオペレータオーバーロードはどうすればよいのですか?
std::cout << hoge;ならサンプルコードが良く見つかるのですが。。。
146デフォルトの名無しさん:2009/05/10(日) 18:17:54
同じようにすりゃ良いじゃん
147デフォルトの名無しさん:2009/05/10(日) 18:22:19
>>146
というのは、例えば
std::string str;
std::cin >> str;
としてstrから適切に処理すれば良いってことですか?
148デフォルトの名無しさん:2009/05/10(日) 18:32:28
std::complex<> を参考にしろよ

(n,m) の形式で読み取るが、どのようにして実現しているのか
考えるのも楽しいものだ
149デフォルトの名無しさん:2009/05/10(日) 18:33:27
istream &operator >>( istream&, const MyClass& );
150147:2009/05/10(日) 19:52:38
>>148
ありがとうございます。
さっそく見てみます。

>>149
ありがとうございます。
宣言の方は
std::ostream& operator << 〜
で理解しました。
151デフォルトの名無しさん:2009/05/10(日) 21:46:01
C++ code - 31 lines - codepad
ttp://codepad.org/YWNCgmUO
このソースは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デフォルトの名無しさん:2009/05/10(日) 22:00:38
std::ios::failbit が立つと、それ以降の入力は一切行われなくなる
これがCとは違う所

この状態をクリアするにはis.clear()を行う
153151:2009/05/10(日) 22:02:27
>>152
フラグ立てですか。
読み込みに失敗したと言うことで、エラー状態にしているわけですね。
ありがとうございます。
・・・でも何で例外を投げる仕様にしなかったのでしょう?
使いづらそうな。。。
154デフォルトの名無しさん:2009/05/10(日) 22:04:40
C++の本ってみんな今何読んでる?
155デフォルトの名無しさん:2009/05/10(日) 22:05:30
今は何も読んでない
156デフォルトの名無しさん:2009/05/10(日) 22:06:21
>>153
例外を投げる事もできる
ただ歴史的経緯があって例外がC++に存在しなかった時代から
iostreamは使われて来ているわけでデフォルトで例外はOFFに
されている

例外を投げるにはメンバ関数exceptions()にトリガとなるビットを
セットすればよい
157153:2009/05/10(日) 22:14:28
>>156
なるほどー!
サンクス。了解できた。
158デフォルトの名無しさん:2009/05/10(日) 22:15:39
>>154
Boost C++ libraries 第二版
159デフォルトの名無しさん:2009/05/10(日) 22:45:39
>>154
はじめてのC。

電車の中で立ち読みして
JKやOLからの冷たい視線でたまらなく興奮する人にお勧め。
160デフォルトの名無しさん:2009/05/10(日) 22:48:21
>>154
やさしいC++
電車の中で読む度胸はないぜ
161デフォルトの名無しさん:2009/05/11(月) 00:01:31
配列に配列を代入したいときは、
配列1[i]=配列2[i]などとしてforで回すのが一般的でしょうか
162デフォルトの名無しさん:2009/05/11(月) 00:04:14
C++なら<algorithm>のcopy関数を使う方が一般的
163デフォルトの名無しさん:2009/05/11(月) 00:05:59
memc(ry
164デフォルトの名無しさん:2009/05/11(月) 00:07:18
つ std::copy
一見関数だらけになるが、恐ろしいほど最適化される。
165デフォルトの名無しさん:2009/05/11(月) 00:09:03
>>162-164
ありがとうございます
とりあえず全部試して見ます
166デフォルトの名無しさん:2009/05/11(月) 08:04:07
>>154
Programming - Principles and Practice Using C++
167デフォルトの名無しさん:2009/05/12(火) 22:16:57
std::vector<char> v(256);

で &v[0] を char 256個の配列として扱って良いものですか?
168デフォルトの名無しさん:2009/05/12(火) 22:41:08
>>167
> &v[0] を char 256個の配列として扱って良いものですか?
v[0]でvの先頭要素のリファレンスが返ってくる。
そして&v[0]はそのアドレスを取得している。
よって先頭アドレスが取得できるのか?ということかい?

たしかOKと聞いたことがあるなぁ。
C++編(標準ライブラリ) 第2章 vector
ttp://www.geocities.jp/ky_webid/cpp/library/002.html
の○生の配列との関連のところで。

169デフォルトの名無しさん:2009/05/12(火) 23:11:26
>>167
ええよ
C++98とC++03間の変更点の一つにvectorはリニアアドレス↑に
取られる事が保証されたというのがある

規格票を見れば書いてあるはず

stringはまだでc++0xで保証される予定
170デフォルトの名無しさん:2009/05/13(水) 05:29:54
GUIを考えています。
例えば、ボタンの上にマウスを持っていった時に、ヘルプメッセージを出す事を考えます。
所謂コマンドパターンによる実装になると思うのですが、
ボタンが親子関係でもないオブジェクトの参照を持つ事になり、気持ち悪く感じます。
これは気にしても仕方ない事なのでしょうか?
171デフォルトの名無しさん:2009/05/13(水) 08:13:10
仕方ないというより、別に気持ち悪くないし。
172デフォルトの名無しさん:2009/05/13(水) 18:48:03
履歴一覧を表示する元に戻すボタンでも実装するのか?

>所謂コマンドパターン
って言ってみたかっただけなんじゃ
173167:2009/05/13(水) 21:17:48
>>168, 169
ありがとうございます。
std::string の c_str() のようにポインタを取得するというメソッドが
無いので、もしかしてやっちゃいけないことなのかと不安に思ったのです。
174デフォルトの名無しさん:2009/05/13(水) 21:43:46
C/C++の趣味グラマなんだけど、
アセンブラも勉強した方がいいのかな?
175デフォルトの名無しさん:2009/05/13(水) 21:47:28
わざわざしなくていいと思うよ
意識せずとも、いずれ自然に必要になって自然に勉強してる
176174:2009/05/13(水) 21:52:03
>>175
ほほう、そんなもんなのか。ありがとう。
むしろもうちょっと高級言語も知っとこうかなぁ。。。
177デフォルトの名無しさん:2009/05/13(水) 23:27:37
C/C++をやると平気でインラインアセンブラを書くようになるよな
特にSSE2/SSE3関連は
178デフォルトの名無しさん:2009/05/14(木) 00:48:26
>>171,172
クラスの関連が複雑になるのと、オブジェクトの寿命管理の点が気になりました。

> 履歴一覧を表示する元に戻すボタンでも実装するのか?
これも1つです。
ソースの見通しが悪くなり、あとで機能を追加したいと思った時に困るのではないかと思いました。
179デフォルトの名無しさん:2009/05/14(木) 01:13:32
ササビーってIntelから出るけどあれどうなの?
180デフォルトの名無しさん:2009/05/14(木) 01:53:25
俺、趣味でオセロプログラム書いてるけど、>>177みたいなことに手を出してみた。
最初は難しいイメージがあったが、やってみるとそうでもなかった。
181デフォルトの名無しさん:2009/05/14(木) 02:25:47
0から1の乱数を表示させるプログラムがほしいんですがわかる人いますか?
調べてみてはいるのですが、なかなかうまく動きません。
乱数生成のためのソフトとかはいるのでしょうか?

もしお暇がありましたらよろしくおねがいします。
182デフォルトの名無しさん:2009/05/14(木) 02:30:59
>>181
今、どれくらいの知識を持ってるの? どんなコード書いてみたの?
とりあえず、標準Cライブラリの rand っていう関数は知ってる?
183デフォルトの名無しさん:2009/05/14(木) 02:31:35
double r;
srand((unsigned int)time(0));
r = rand() / RAND_MAX;
printf("%lf", r);
184デフォルトの名無しさん:2009/05/14(木) 02:44:00
static_cast<double>(rand()) / RAND_MAX;だろとツッコミがほしいんだろ
185デフォルトの名無しさん:2009/05/14(木) 02:54:43
>>183
きっと0か1しか返さないぞ。

>>178
>ボタンが親子関係でもないオブジェクトの参照を持つ
ここでいってるオブジェクトってコマンドクラスのこと?
同じボタンの機能がころころ変化するのでもなければ
参照を持つ必要なんて無いと思うけど?
どうしてもUIにヘルプ文字列を埋め込みたくないのなら
コントロールクラスに自分(ボタン)が今どんな機能なのか
問い合わせるメソッドでも作ったら?
186デフォルトの名無しさん:2009/05/14(木) 03:34:01
>>182
rand関数はさっきから学びはじめたばかりです。
知識は基本的なプログラムならつくれる程度です。
187デフォルトの名無しさん:2009/05/14(木) 03:38:42
randは本格用途では使い物にならんぞ
ゲームのサイコロ振るくらいに使うならいいけど
188デフォルトの名無しさん:2009/05/14(木) 03:40:12
>>186
rand関数は、0 から RAND_MAX までの範囲の整数を返す。
(RAND_MAX は実際にはある特定の数値であり、コード中に RAND_MAX と書けばその数値として扱われる)

後は、0 から RAND_MAX までの範囲の整数を、0 から 1 までの間の小数の値に変換すればよい。
>>183-185あたりを参考に。まだ分からんところがあったら聞いてくれ。

もし本格的な乱数を使用したいなら、boostのrandomってのを調べてみるといいが、
まあそこまでする気がないならrandでいいよ。
189デフォルトの名無しさん:2009/05/14(木) 03:43:14
>>187
本格用途ではなくごく簡単なプログラムで、サイコロを振る程度です。

>>188
rand関数について自分でも調べていたところです。
丁寧におしえていただきありがとうございます。
もしわからないことがあったら書き込みたいと思います。
ありがとうございました!
190189:2009/05/14(木) 04:34:11
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{
double random;

srand((unsigned) time(NULL)); // rand関数による乱数生成を不規則にする
for(int i=0; i<20; i++){
random = (double)rand()/RAND_MAX; // 0から1までの乱数の生成
printf("%f\n",random); // 表示する
}
}

ここでのアドバイスなどをもとにして自分でつくりました。
コメントは自分でつけたので語弊があるかもしれません。
191189:2009/05/14(木) 05:08:06
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

int main(void)
{
double random;

srand((unsigned) time(NULL)); // rand関数による乱数生成を不規則にする
for(int i=0; i<20; i++){
random = (double)rand()/RAND_MAX; // 0から1までの乱数の生成
printf("%f\n",random); // 表示する
}
}

ここでのアドバイスなどをもとにして自分でつくりました。
コメントは自分でつけたので語弊があるかもしれません。
192189:2009/05/14(木) 05:11:06
すみません一つはまちがいです。

上のプログラムだと乱数表示はされるのですが
一個だけ乱数表示するプログラムを実行すると、何度実行してもほとんど変わらない乱数
(例えば、0.963742 ⇒0.972378 ⇒0.981201など)
になってしまいます。

良い解決方法はないでしょうか?
193デフォルトの名無しさん:2009/05/14(木) 05:37:58
win32環境ならtime()をGetTickCount()なりQueryPerformanceCounter()なりで置き換えるとか。
194デフォルトの名無しさん:2009/05/14(木) 06:28:58
>>185
> ここでいってるオブジェクトってコマンドクラスのこと?
> 同じボタンの機能がころころ変化するのでもなければ
> 参照を持つ必要なんて無いと思うけど?
ヘルプメッセージを表示するクラスのメンバ関数をboost::functionに入れてボタンクラスに渡すという意味です。
Clickなど他のイベントも同様に「他のクラスのメンバ関数をboost::functionに入れて〜」とやっていったらクラスの関連が複雑になるのではないのかと。
また、boost::functionの中で保持されているポインタの寿命(有効か)の不安を感じます。
195デフォルトの名無しさん:2009/05/14(木) 06:33:38
random = (double)rand()/(RAND_MAX+1.0); // に、しとけ。
196デフォルトの名無しさん:2009/05/14(木) 07:42:43
struct A{virtual void operator()()=0;};
struct B:A{virtual int operator()(int)=0;};
struct C{A&x;C(A&a):x(a){} int operator()(int i){return static_cast<B&>(x)(i);}};
struct D:A{void operator()(){}} d;

int f(){
C c(d);
c();
return c(1u); // これ・・・
}
コンパイルを通ってしまわない様にするにはどう改造すればいいのでしょう?
197デフォルトの名無しさん:2009/05/14(木) 08:01:28
>>196
コンパイルが通らないようにする方法ならいくらでもわるわけで、
何がしたいのか挙げてもらわないと望む答えは得られないでしょう。
198196:2009/05/14(木) 08:10:12
void operator()(){x();} を書き忘れ
struct C{A&x;C(A&a):x(a){} int operator()(int i){return static_cast<B&>(x)(i);} void operator()(){x();}};
199デフォルトの名無しさん:2009/05/14(木) 09:03:46
>>195
なんのために+1.0するの?
200デフォルトの名無しさん:2009/05/14(木) 09:06:17
>>199
結果に整数 N をかけることで、簡単に N とおりの選択に使う乱数が得られる。
「0 から 1 の乱数」が 1.0 を含んでいると、こうはいかない。
201デフォルトの名無しさん:2009/05/14(木) 09:12:53
>>200
今回の目的は
「0から1の乱数を表示させる」
だけど、いいの?
202デフォルトの名無しさん:2009/05/14(木) 09:20:22
>>201
日本語だけでは閉区間なのか開区間なのか、区別がつかないんで、
質問者に判別してもらうしかないな。

簡単なサイコロの用途であれば 200 の性質が役に立つはずなんだけど。
203デフォルトの名無しさん:2009/05/14(木) 09:22:50
簡単なサイコロの用途であれば、
random = rand()%6; // で、十分。
204189:2009/05/14(木) 11:12:04
>>193
「GetTickCount()識別子が見つかりませんでした」とでます。
変数として扱われているのですかね・・・
他のプログラムをみてみたのですが使い方がわかりません
勉強不足ですよねスミマセン

>>195
お返事ありがとうございます
プログラムの下から4行目のことですよね?
してみたのですがほとんど値がかわりませんでした
何かまちがっているでしょうか
205189:2009/05/14(木) 11:13:50
>>193
「GetTickCount()識別子が見つかりませんでした」とでます。
変数として扱われているのですかね・・・
他のプログラムをみてみたのですが使い方がわかりません
勉強不足ですよねスミマセン

>>195
お返事ありがとうございます
プログラムの下から4行目のことですよね?
してみたのですがほとんど値がかわりませんでした
何かまちがっているでしょうか
206189:2009/05/14(木) 12:43:26
>>193
GetTickCount()は識別子が定義されてませんとでてしまいます
変数としてあつかわれてしまっているようです

>>195
お返事ありがとうございます
1を足したのですがあまり乱数はかわらなかったのですが
何かまちがっているのでしょうか
207195:2009/05/14(木) 12:45:45
コンパイラは Borland だろ。
208189:2009/05/14(木) 12:49:10
>>193
GetTickCount()は識別子が定義されてませんとでてしまいます
変数としてあつかわれてしまっているようです

>>195
お返事ありがとうございます
1を足したのですがあまり乱数はかわらなかったのですが
何かまちがっているのでしょうか
209189:2009/05/14(木) 12:51:07
すみません何度もかきこんでしまいました
210189:2009/05/14(木) 12:55:04
>>202
[0,1)区間となっています。0以上1未満ということです。
サイコロの乱数程度といってしまいましたが
サイコロは関係ありません
211デフォルトの名無しさん:2009/05/14(木) 13:25:26
>>208
windows.hをインクルードしてないとか言うなよ
212デフォルトの名無しさん:2009/05/14(木) 13:29:26
だって、それを書けなんて誰も言ってないじゃないですか。
213189:2009/05/14(木) 13:30:44
>>211
ご指摘ありがとうございます。
してませんでした。
214195:2009/05/14(木) 13:41:16
>>212 コンパイラの名前とバージョンは?
215デフォルトの名無しさん:2009/05/14(木) 23:50:55
すごく初歩的な質問ですが、C++で数字の小数点以下を
繰り上げるには何をつけたらいいんですか?
216デフォルトの名無しさん:2009/05/14(木) 23:53:45
std::ceil()だろ
Cにもある
217デフォルトの名無しさん:2009/05/14(木) 23:55:09
つceil
218デフォルトの名無しさん:2009/05/15(金) 00:16:28
それは「切り上げ」じゃん。ちゃんと答えてやれよ
因みに俺は小数点以下の「繰り上げ」なる概念について知らないので答えられん
219デフォルトの名無しさん:2009/05/15(金) 00:17:50
くだらねえ…
220215:2009/05/15(金) 00:21:12
おかげさまで解決しました。どうもありがとうございましたm(_ _)m
221デフォルトの名無しさん:2009/05/15(金) 00:25:23
ちなみにceil()は負の数は0から離れる方向になるからな
222デフォルトの名無しさん:2009/05/15(金) 09:52:02
>>203
それって偏りが出るよね。
223デフォルトの名無しさん:2009/05/15(金) 10:02:11
RAND_MAXが極端に小さい環境ならね。
32767程度あれば、5461回が5462回になる程度のばらつきだよ。
224デフォルトの名無しさん:2009/05/15(金) 10:22:09
マジで⁉
225デフォルトの名無しさん:2009/05/15(金) 10:23:33
>>222
サイコロに偏りが無いとでも?
226デフォルトの名無しさん:2009/05/15(金) 10:45:40
線型合同法は下位ビットの周期性が
227デフォルトの名無しさん:2009/05/15(金) 12:14:07
テンプレートのテクニックをまとめた、テンプレートの著書を教えてください。
知っているのは、modern C++ と、テンプレートテクニックという本です。

良いサイトや良い本の情報ください。
228デフォルトの名無しさん:2009/05/15(金) 12:26:08
C++ Template Metaprogramming: Concepts, Tools, And Techniques From Boost And Beyond
229デフォルトの名無しさん:2009/05/15(金) 12:53:18
マウスでいまクリック、もしくはドラッグしているファイルやディレクトリのパスを
取得する方法ってありますか?常駐ソフトのような形で、起動してからクリック、ドラッグ
したファイルのパスをテキストログとして、出力するようなものを作りたいのですが・・・。
230デフォルトの名無しさん:2009/05/15(金) 12:56:30
なんでこっちに来たんですか?
231デフォルトの名無しさん:2009/05/15(金) 13:00:38
>>226
そんな乱数でもない数列をrand()という名前の関数の出力にする処理系が悪い。
ゴミだから早急に廃棄しろ。
232デフォルトの名無しさん:2009/05/15(金) 13:39:39
>>225
製作工程の都合で、1,6の面積が微妙に大きいという話しか?
それとも、くりぬかれた目による重心のずれ、密度の偏りの方か?
233デフォルトの名無しさん:2009/05/15(金) 13:55:52
>>228
ありがとうございます。
翻訳出てないんですかね……残念です。

C++の一番の特徴であるテンプレート関係の本が少ないのは何故?
わかりやすくテクニックを知りたいのに
234デフォルトの名無しさん:2009/05/15(金) 15:54:15
すみませぬ JAVAから入っていまC++を勉強し始めたのですが、
C++で、配列で宣言した変数は、跡になってから自らがいくつの要素を持つ配列なのかチェックする方法ってありますか?


Javaだと、
String str[] = new String[3]
のように宣言した場合、
str.length を見れば要素数を見ることができますが、C++の場合は方法ありますか?
235デフォルトの名無しさん:2009/05/15(金) 15:56:52
>>234
ないから素直にstd::vector使っとけ
236デフォルトの名無しさん:2009/05/15(金) 15:57:32
>>234
sizeof(str) / sizeof(str[0]) で自分は調べてる
237デフォルトの名無しさん:2009/05/15(金) 15:58:40
>>236
アホか
238デフォルトの名無しさん:2009/05/15(金) 16:03:46
え?駄目なの
俺も>>236を常用してるけど・・
239デフォルトの名無しさん:2009/05/15(金) 16:07:00
大丈夫、話が噛み合ってないだけだ。
char * foo = new char[3];
した場合は要素数を知る手段はない。
char foo[] = "abc";
した場合は要素数(≠文字数)を>236で得られる。
240234:2009/05/15(金) 16:20:29
ありがとうございます。
C言語の場合、
配列を作ったら作りっぱなし、メモリのどこまでがその配列に割り当てられた場所かという情報はどこにもないという認識で良いですか?

たとえば10要素の配列を作ったあとに20番目の要素にアクセスしようとすると、JAVAだとぬるぽが出て教えてくれますが、
Cの場合はシステムから見てそれが分からずに、20番(に相当する場所)を読みに行ったり、書き込んでしまう という理解で良いですか?
241デフォルトの名無しさん:2009/05/15(金) 16:25:57
良いです。
ちなみにここはC++のスレです。
242デフォルトの名無しさん:2009/05/15(金) 16:39:03
>>240
そうです
運が良ければアプリ自体が吹っ飛んでくれますが運が悪いとそのままメモリ破壊して動き続けます
なのでJavaしかできない人が集まってC++案件とかやるととても楽しいことになります
243デフォルトの名無しさん:2009/05/15(金) 16:41:59
そもそも、10要素の配列を作ったあとに20番目の要素にアクセスしようとするような奴は
「Javaしかできない人」ではなく、「Javaもできない人」
244デフォルトの名無しさん:2009/05/15(金) 16:47:00
>>240
大きな勘違いをしている。
>配列を作ったら作りっぱなし、メモリのどこまでがその配列に割り当てられた場所かという情報はどこにもないという認識で良いですか?
配列は、>36でサイズを得ることができる。
つまり、newなんていう外道なモノを使わずに、(昔なつかしの)固定長配列を使うかstd::vectorを使えと言うことだ。
245デフォルトの名無しさん:2009/05/15(金) 20:48:50
Cに配列なんてなかった
246デフォルトの名無しさん:2009/05/15(金) 21:16:41
>>245
何??
247デフォルトの名無しさん:2009/05/15(金) 21:18:10
何の話?
248デフォルトの名無しさん:2009/05/15(金) 21:19:50
ついに狂ったか?
249デフォルトの名無しさん:2009/05/15(金) 21:22:37
Cなんてなかった
250デフォルトの名無しさん:2009/05/15(金) 21:50:31
コンピュータなんてなかった
251デフォルトの名無しさん:2009/05/15(金) 21:52:47
平行世界とつながったな
252デフォルトの名無しさん:2009/05/15(金) 22:09:27
仕事なんてなかった
253デフォルトの名無しさん:2009/05/16(土) 22:00:39
ISOのC++の2003年の規格のJISは訳がひどいですね。
原文の構成もひどいけど。
規格をもっと読みやすくしたような、同じだけ詳しい本ってあるんでしょうか?
254デフォルトの名無しさん:2009/05/16(土) 22:06:55
無いから我慢して読め
255デフォルトの名無しさん:2009/05/16(土) 22:15:03
規格書の文章なんてどれもああいうもんだよ。
訳が酷いわけじゃない。
256デフォルトの名無しさん:2009/05/17(日) 01:01:57
C++は規格自体がひどいから文章もひどくなる
257デフォルトの名無しさん:2009/05/17(日) 01:56:44
C++の文法があまりに酷いもんで翻訳者もイライラしながら
訳してたんじゃないか?w
258デフォルトの名無しさん:2009/05/17(日) 02:35:49
どのくらいメモリを使っているかという情報は型が持っているのだから
例えば、char[3] 型の最初の要素のアドレスをchar*型に代入したら
もうメモリサイズがわからなくなるのは当然といえば当然。
char[3] 型を char[3] 型に代入する分にはちゃんとサイズがわかる。

という感じかしら
259デフォルトの名無しさん:2009/05/17(日) 04:11:03
変数の型も含めてすべてをクラスにってのがJava以降に導入されたもんだからね
260デフォルトの名無しさん:2009/05/17(日) 04:25:19
それは別にJavaで初めてというわけじゃないだろ。
261デフォルトの名無しさん:2009/05/17(日) 08:18:01
Javaも全てがクラスというわけでもないし。
262デフォルトの名無しさん:2009/05/17(日) 08:57:46
全てがクラスになる


unlambdaやれば全てが関数だからオススメ。
263デフォルトの名無しさん:2009/05/17(日) 09:49:55
C++の一行の文字数って標準仕様上、制限ありますか?
またあるとして、現実的に気にした方が良いですか?
264デフォルトの名無しさん:2009/05/17(日) 10:53:44
>>263
言語仕様としてはメモリの許す限りおk
265デフォルトの名無しさん:2009/05/17(日) 10:56:29
メモリの許す限りという制限すらない無制限
266デフォルトの名無しさん:2009/05/17(日) 11:16:18
ありがとうございます。
じゃあ気にせず行きます!
267デフォルトの名無しさん:2009/05/17(日) 11:29:51
80文字が一つの目安だな。
120文字超えてたらちょっとイラッとする。
268デフォルトの名無しさん:2009/05/17(日) 11:32:26
クラスのメンバ関数の返り値は
コピー返しでも可能ならconstにしろ

とEffective C++で言われていましたが、
なぜか返り値がbool型だけはconst付けない風習がありません?
例: bool is_valid() const {return member?true:false;}
この場合も返り値にconst付けた方が良いのでしょうか?
269デフォルトの名無しさん:2009/05/17(日) 11:34:17
付けた方がいいよ。
270デフォルトの名無しさん:2009/05/17(日) 11:54:31
>>268
メリットはなに?
271268:2009/05/17(日) 11:58:07
>>269
そうですよね。ありがとうございます。

>>270
組み込み型の返り値を万が一変更するバカが居た場合の予防です。
272デフォルトの名無しさん:2009/05/17(日) 12:12:37
>組み込み型の返り値を万が一変更する
なんてできません。

馬鹿って言う人が馬鹿なんだぞw
ちゃんと読もうぜ。
273デフォルトの名無しさん:2009/05/17(日) 12:25:20
メリットは記述の統一感かな?
テンプレート引数にするときにいいことってある?

自分は組み込み型にはconst付けない派だな
274デフォルトの名無しさん:2009/05/17(日) 12:34:53
それ書いてあるのってEffecitve C++だっけ? Exceptionalかなんかのほうだった気がするが。
275デフォルトの名無しさん:2009/05/17(日) 12:35:35
> テンプレート引数にするときにいいことってある?
全くない。

むしろ
組み込み型戻り値のconstは
環境によってはwarningやerrorになるから
うっとうしいことこの上ない。


276デフォルトの名無しさん:2009/05/17(日) 13:02:35
constな自クラス型参照メンバなんか使いだすと有りとあらゆる宣言にconstが波及して`err passing〜'の楽しい事になるんだよね。
277271:2009/05/17(日) 13:06:18
>>272
> >組み込み型の返り値を万が一変更する
> なんてできません。
有名どころのコンパイラならちゃんとコンパイルエラー出してくれるみたいですが
環境が違っても確実に予防してくれるのでしょうかね?

>>274
Exceptional C++だったかもしれません。


>>275
gccやboostの実装でも確かに組み込み型の戻り値にconstは付いていないようですね。

278デフォルトの名無しさん:2009/05/17(日) 13:59:47
そもそも「組み込み型の返り値を万が一変更する」って
どういう意味なの?
279デフォルトの名無しさん:2009/05/17(日) 14:00:46
public継承は分かる。
private継承も分かる。

ではprotected継承は?
使ったことある人います?(遊びじゃなく実用で。)
280デフォルトの名無しさん:2009/05/17(日) 14:17:27
だからちゃんと嫁ってば。

Effecitve C++ 2ndの21節と29節に書いてあるのは、
非組み込み型のコピーを返す関数を左辺値として使われないように、
左辺値になり得る型が戻り値の場合はconst付けよーねってことと、
const宣言したメソッドがデータのハンドル(stringクラスのcharポインタとか)を
返却するときは戻り値にconst付けよーねってこと。

わざわざ押し入れからEffectiveC++取り出してきた俺に
プッチンプリン買ってこいw

>環境が違っても確実に予防してくれるのでしょうかね?
ぶっ壊れたコンパイラの話をされても困る。
281デフォルトの名無しさん:2009/05/17(日) 14:18:55
じゃあ俺はなめらかプリンでよろしく
282271:2009/05/17(日) 14:33:58
>>280
サーセン。吊って来ます。

ありがとうございました。
283デフォルトの名無しさん:2009/05/17(日) 14:35:03
constの同音異義語っぷりもなかなか見事なものだ
284デフォルトの名無しさん:2009/05/17(日) 17:10:42
>>280
非組み込み型の戻り値について const つけてあると、右辺値参照として取れなくなっちゃいそう。
この指針は将来的に非推奨になるんじゃなかろうか?
285デフォルトの名無しさん:2009/05/17(日) 17:52:26
そもそも右辺値参照自体が、
Effective C++で問題が広く知れ渡ったことで
実装されることになったんじゃないかな。

ぷらぷら界に多大な影響を与えた引き替えに、
次の版は全面改定だな。
286デフォルトの名無しさん:2009/05/17(日) 17:55:23
cppunitに関する質問ってありですか?
287デフォルトの名無しさん:2009/05/17(日) 17:56:06
>>286
専用スレがあるから、まずはそっちで。

CPPUnitについて少し話そうかい
http://pc12.2ch.net/test/read.cgi/tech/1042358524/
288デフォルトの名無しさん:2009/05/17(日) 18:07:21
互換性考えたら右辺const値のオブジェクト代入は右辺値参照を無視してコピー噛ますんじゃないかな
289デフォルトの名無しさん:2009/05/17(日) 18:09:03
そう。だから右辺値参照を使って最適化しているつもりが、うっかり今までどおりの
コピーになったりすることが考えられる。まぁ最適化の範疇と認識する分には問題には
ならないんだろうけど。
290デフォルトの名無しさん:2009/05/17(日) 19:44:11
右辺値参照って、なんだかよく分からない。
C++0xが出れば解説も増えるかな?
291デフォルトの名無しさん:2009/05/17(日) 20:32:36
僕もよく解らないけど、関数の返すオブジェクトがコピーされるとき、
もとのオブジェクトが捨てられる場面で、
コピーコンストラクタを呼ばないでよりコストの低い破壊的なコピー、
つまりオブジェクトのメンバを移動することをするってことなんでしょ?
ただそれだけでしょ?
292290:2009/05/17(日) 21:12:34
現在 標準C++のコンパイラの最適化機能として実装されている
 戻値最適化
とは違うのかいな?

C++ ラビリンス Return value and constructor
ttp://www.fides.dti.ne.jp/~oka-t/cpplab-retval-ctor.html
293デフォルトの名無しさん:2009/05/17(日) 21:12:36
そうそう、「移動」の概念(ムーブセマンティクス)を容易に実現するための言語仕様として考え出されたのが右辺値参照。
ほかに分かりやすい例を挙げるとしたらauto_ptr(の後継)がvectorに入れられるようになることとか、
functionやbindなどで各引数のconstや参照の有無の挙動を完全に再現したoperator ()を実現できるなんて効果がある。
294デフォルトの名無しさん:2009/05/17(日) 21:27:43
多次元配列の要素全てを任意の値で埋めたい場合
どう書くのが良いでしょうか。
1次元の場合は std::fill や std::fill_n が使えるのですが。

int a[10][10];
for(int i=0; i < 10; i++)
for(int j=0; j < 10; j++)
a[i][j] = 42;

ということをしたいわけです。
295デフォルトの名無しさん:2009/05/17(日) 21:28:25
>>292
最初の例や2番目のコピーコンストラクタ・代入演算子が呼ばれる例でもムーブセマンティクスは効く。
そこのコピーコンストラクタ・代入演算子の呼出が、ムーブコンストラクタ・代入演算子の呼出になる。
一般にムーブコンストラクタ代入演算子はコピーコンストラクタと違って、
それより遙かに低コストで例外の投げようもない実装になるので、より最適なコードになるとされる。
296デフォルトの名無しさん:2009/05/17(日) 21:31:12
>>294
自分で書いてるじゃねーか。何が不満なの?
297デフォルトの名無しさん:2009/05/17(日) 21:34:04
酒鬼薔薇
298290:2009/05/17(日) 21:34:39
>>295
ほっほー。
そうなのかぁ。
ありがとう。C++0xが楽しみになって来たんだぜ。
299デフォルトの名無しさん:2009/05/17(日) 21:46:45
いや普通に

 memset(a, 42, 100);

で、いいんでない。string.h が使える環境なら



それより最近、スザンヌとギャル曽根の区別が付かなくて困ってます
見分け方を教えてください
300デフォルトの名無しさん:2009/05/17(日) 21:47:47
>>299
int に memset() して 42 になるとでも思ってんのか?
301299:2009/05/17(日) 21:47:53
アンカー忘れ。>>294 な
302デフォルトの名無しさん:2009/05/17(日) 21:51:12
>>299
これはひどい。
303299:2009/05/17(日) 21:52:38
すまん。レス取り消し。int だったね

回線切って(ry
304299:2009/05/17(日) 21:53:52
>>301-302
仕事速いな。暇人
305デフォルトの名無しさん:2009/05/17(日) 22:04:38
>>304
お前の方がよっぽど暇人に見えるんだが
306デフォルトの名無しさん:2009/05/17(日) 22:11:27
>>294
その配列だったら連続性が保証されてるから
std::fill_n(&a[0][0], 100, 42)
でいいだろ。
307デフォルトの名無しさん:2009/05/17(日) 22:12:15
>>294
お好きなほうをどうぞ。
std::fill_n(&a[0][0], sizeof a / sizeof a[0][0], 42);

namespace bll = boost::bind;
std::for_each(a, a + sizeof a / sizeof a[0], bll::bind(std::fill_n<int*, std::size_t, int>, bll::_1, sizeof a[0] / sizeof a[0][0], 42));
308デフォルトの名無しさん:2009/05/17(日) 22:23:24
>>307
std::fill_n(first, n, val) は [first, first + n) に対しての操作だから
要素数でOK。sizeof a / sizeof a[0][0] は冗長。
309デフォルトの名無しさん:2009/05/17(日) 22:26:42
それも要素数・・・
310デフォルトの名無しさん:2009/05/17(日) 22:28:14
g++にてテンプレートに暗黙の型変換を絡めたら分からなくなったので教えてください。

C++ code - 60 lines - codepad
ttp://codepad.org/l7pocEaw
このソースコードでは50行目hoge < short(1)の部分で
error: no match for 'operator<' in 'hoge < 1'
と言われてしまいます。どうやら暗黙の型変換がうまくいかないようです。

これを改変してForward declarationを無くして代わりにクラステンプレートの内部で friend 関数を定義することで回避できます。
C++ code - 49 lines - codepad
ttp://codepad.org/F0VomJTk

しかし、どうして前者のソースコードでは暗黙の型変換がうまくいかないのでしょうか?

311294:2009/05/17(日) 22:30:18
みなさまありがとうございます。

std::fill_n(&a[0][0], sizeof a / sizeof a[0][0], 42)

がよさそうですね。勉強になりました。

312デフォルトの名無しさん:2009/05/17(日) 22:39:30
>>309
だから、要素数が既知なのに一々冗長に書くことないってこと。
313デフォルトの名無しさん:2009/05/17(日) 22:42:54
>>312
「要素数が既知」ということに依存したコードにするほうが面倒なこともあると覚えておけ。

一般的には、保守性のほうが一回だけの記述の利便よりも重要だ。
314デフォルトの名無しさん:2009/05/17(日) 22:45:14
>>313
何頭に血を登らせてるの?
質問者が提示したコードで要素数が定数になってたんだからそれでいいだろ。
不明な場合に要素数を計算するのは当然のこと。
315デフォルトの名無しさん:2009/05/17(日) 22:45:22
>>312
マジックナンバーは避けるべきだろjk
const N = 10;
int a[N][N];
なんてしているならsizeofを使わずにNと書いてもいいとは思うけど。
316デフォルトの名無しさん:2009/05/17(日) 23:08:17
そういう本質でない話はもういい
317デフォルトの名無しさん:2009/05/18(月) 01:54:38
template<T,U>void fill(T (&d)[U],T v){for(unsigned i=0;i<U;++i)d[i]=v;}
template<T,U0,U1>void fill(T (&d)[U0][U1],T v){for(unsigned i=0;i<U0;++i)for(unsigned j=0;j<U1;++j)d[i][j]=v;}

マジックナンバーイラズサイテキ化キタイダイ
int a[10][10];
double b[10];
fill(a,0);
fill(b,0.0);
318デフォルトの名無しさん:2009/05/18(月) 02:07:27
オナニーレスうぜえな
ループを書きたくないってのが本題なのに、それじゃ本末転倒だろうが
319デフォルトの名無しさん:2009/05/18(月) 02:22:32
>>318
何いってんの?
ライブラリって知ってる?
320デフォルトの名無しさん:2009/05/18(月) 02:57:44
>>310
暗黙の型変換はテンプレートを具象化しなければならない時には行われないから
んで、どうすればいいかというと後者のようにすればいい
Effective C++の46項に詳しく書いてあるよ
321デフォルトの名無しさん:2009/05/18(月) 03:25:03
>>284,285,288,289
C++0x の話としては,戻り値の型が const 修飾されていると
move 出来ない (immutable な右辺値になる) ので,
Effective C++ の記述がやや古くなるのはその通りだと思います.

C++0x 的には, EC++ のこの記述は
恐らく "Extending move semantics to *this" と
"Defaulted and Deleted Functions" との組み合わせに置き換わるべき話だと思います.
322デフォルトの名無しさん:2009/05/18(月) 03:56:14
C++が苦手なCプログラマなのですが、ちょっと質問です。
ファイル内の文字列を探すプログラムです。
これをC++で書くとしたらこの程度でもクラスを作るのですか?
#include <stdio.h>
#include <string.h>
int main(int ac, char * av[])
{
 //ファイルからメモリーに読み込み
 FILE * fp = fopen("文字列が入ったファイル", "r");
 fseek(fp, 0, SEEK_END);
 int fSize = ftell(fp);
 fseek(fp, 0, SEEK_SET);
 char * buf = (char *)malloc(fSize);
 fread(buf, 1, fSize, fp);
 fclose(fp);
 //さがす
 char ss = "abcde";
 int ss_len = strlen(ss);
char * p = buf;
 for (int i = 0; i < fSize - ss_len; i++) {
  if (strncmp(ss, p, ss_len) == 0) {
   printf("%d番目に見つかりましたよ\n", i);
   return 0;
  }
  p++;
 }
 free(buf);
 return 0;
}

323デフォルトの名無しさん:2009/05/18(月) 04:00:29
おれはc++のOOP が標準だから、特別な理由が無い限りOOPで書く。
英語で育った人は、特に何も考えずに英語会話するのと同じ
324デフォルトの名無しさん:2009/05/18(月) 04:03:57
その程度だと、既存のクラスを使うだけで出来上がるね。つまり、クラスを作る出番ではないと。

極論すればクラスってのは作るものというより使うもの。
325デフォルトの名無しさん:2009/05/18(月) 04:09:51
それに、mallocをfreeしてないでしょ、終われば開放するけど、
それはたまたま短いプログラムだから、OOPだと、明示的にディストラクタがある。
まあ使わなきゃ意味無いけど、私はこれも標準で書いてしまう。だから少し安心なわけ。
それに、そのプログラムはバッファーオーバランしないようだけど、それも、保護されやすい。
ただし、標準でOOPが身についてるからであって、人によってはOOPでもいくらでも汚くかける。
326デフォルトの名無しさん:2009/05/18(月) 04:13:16
あ、ごめ freeしてた orz
327デフォルトの名無しさん:2009/05/18(月) 04:14:40
いや…、Cはもう、身についてないから…と言い訳する  orz orz orz
328デフォルトの名無しさん:2009/05/18(月) 04:16:55
一人で無駄に4レスも使いやがって
329デフォルトの名無しさん:2009/05/18(月) 04:17:57
俺はその程度ならclass内でやったりしないな。FILEも普通に使うし。

ただ、バッファはvector<char>で確保するし
探索も文字列探索クラス(BM法とか)を作って実行するね。

処理自体は(mainには限らないが)普通の関数に置く。
ただこれは当然「ファイル内の文字列探索が処理の全て」の場合。
何らかのclassの処理の中でファイル内探索を必要とする時は、当然そのように書く。
330310:2009/05/18(月) 05:52:46
>>320
Effective C++では後者の方式が天下りに与えられていました。

あくまで前者のような方式(実装をクラス宣言部分に書かない)
で解決する方法はありませんか?
(後者の方式でprivate宣言されたヘルパー関数を呼び出すという回避策もありますけれど。)
331デフォルトの名無しさん:2009/05/18(月) 05:56:50
>>325
destructor
はディストラクタではなくデストラクタね。発音的にも用語的にも。
ディスクトップでなくデスクトップなのと同じで。

332デフォルトの名無しさん:2009/05/18(月) 10:51:25
>>330
関数が2つになっちゃうけど、
クラス内に
template<typename T> friend bool operator <(const Hoge &lhs, T rhs);
template<typename T> friend bool operator <(T lhs, const Hoge &rhs);
って書けば、関数テンプレートの定義を外に書けると思う…たぶん

それか、関数テンプレートをやめて定義を特殊化して書いてもいけるんじゃないかな。

間違ってたらサーセン
333デフォルトの名無しさん:2009/05/18(月) 16:13:37
>>322 を見て思ったんですが、
ファイルを読み込み文字列検索するだけでこんな長く分り難いにコードにえーって感じなんですが、
C++を使って書くとこれより短く解りやすいコードになるんですか?
それはどんな感じになるんですか?

>>322 で
printf("%d番目に見つかりましたよ\n", i);
return 0;
ここでreturnしているんですが、ここではfreeしなくて良いんですか?
334デフォルトの名無しさん:2009/05/18(月) 16:41:01
>333
main() {system("grep abcde 文字列が入ったファイル");}

>free
リークしていないので問題ないが、姑に目を付けられる。
335デフォルトの名無しさん:2009/05/18(月) 16:53:00
でも突然サブルーチンに昇格する可能性もあるから、
常にfreeした方がいいよ。
336デフォルトの名無しさん:2009/05/18(月) 17:02:55
>>334
>free
見つかった時、見つからない時の両方でfreeしないなら良いけど
片方しかしてないって、C使いらしくないんじゃない?
短いコードでたった2箇所を管理するだけなのに、それすら出来ないなんて
337デフォルトの名無しさん:2009/05/18(月) 17:55:44
freeの仕様について言及しただけで、
>>322のソース自体に文句付けるなら
もっといろいろあるだろ。
338デフォルトの名無しさん:2009/05/18(月) 21:07:11
return 0; を break; に置き換えるとか?
339デフォルトの名無しさん:2009/05/18(月) 21:14:11
ファイルを一気に読むのが好きになれない、俺なら1行ずつの処理にする。
340デフォルトの名無しさん:2009/05/18(月) 21:15:00
配列まではすんなり頭に入ったけど、ポインタとかクラスのメンバ関数とかわけわかんねー・・
なんにしても作りたい物が無ければ頭に入らない気がしてきたんだけど、ドリルみたいなものって無いですか
341デフォルトの名無しさん:2009/05/18(月) 21:16:19
宿題スレに山ほど
342デフォルトの名無しさん:2009/05/18(月) 21:19:51
こんなスレあったのか、ありがとう
343デフォルトの名無しさん:2009/05/18(月) 21:35:44
>>341
宿題スレはいいよな
糞問ばっかりだけど最初のうちは数こなす方が大事だし
344310:2009/05/18(月) 23:20:37
>>332
なるほど。
やはり関数を1つにまとめ、かつ
(特殊化をすると妨げられる)汎用性を保とうとするならば
Dan Saksの
More C++ Idioms/friend 関数の生成(Making New Friends) - Wikibooks
ttp://ja.wikibooks.org/wiki/More_C%2B%2B_Idioms/friend_%E9%96%A2%E6%95%B0%E3%81%AE%E7%94%9F%E6%88%90(Making_New_Friends)
すなわちEffective C++でいう後者の方式しかないようですね。

ありがとうございました。
345デフォルトの名無しさん:2009/05/18(月) 23:30:53
次はコナン風で頼む。
346デフォルトの名無しさん:2009/05/18(月) 23:32:24
どっちのコナンだよ
347デフォルトの名無しさん:2009/05/18(月) 23:43:35
やってくれるのか?
わくわく
348デフォルトの名無しさん:2009/05/19(火) 01:23:32
コナン・ザ・グレート風で頼む。
349デフォルトの名無しさん:2009/05/22(金) 23:15:48
クラス中の宣言の中でメンバ関数の定義をした場合、
自動的にinline展開要請になるんだよね?

では
クラス中の宣言の中でfriend関数の定義を記述した場合、
inline展開要請になるのかい?
350デフォルトの名無しさん:2009/05/22(金) 23:32:49
^^
351デフォルトの名無しさん:2009/05/22(金) 23:35:26
inline展開陳情のほうがいいかも。
352デフォルトの名無しさん:2009/05/22(金) 23:49:36
俺のBCC 6.1.0ではオプションを付けない限り inline は全部無視される\(^o^)/

デバッグの時の事を考えてだと
353デフォルトの名無しさん:2009/05/23(土) 00:48:25
>>352
BCC以外でもみんなそうだけど……。
354デフォルトの名無しさん:2009/05/23(土) 15:44:38
同じ質問になるのですが、86とは別人です。
コンストラクタで例外を投げるな、というのをかなり以前Cマガジンで読みました。
その後、Google や >>93 で、コンストラクタ内で例外を投げる時に
適切にリソースを解放すれば問題ない、というのが多かったのですが、
以下のサイトに気になる記述も見つけました。

ttp://www.geocities.jp/chacha_yhk1219/prog/prog004.html
newで作ったときにオブジェクト自体がリークしてしまう

http://monoist.atmarkit.co.jp/fembedded/symbian/symbian04/symbian03.html
ポインタが返ってこない。知らないポインタは消せない

コンストラクタで例外を発生させてもよいが、その場合は new するな、
という理解でよいでしょうか。
355デフォルトの名無しさん:2009/05/23(土) 16:19:13
>>354
Symbianは組込だからそうなっていないのかもしれないが、普通はその心配は要らない。

その場合は確かにプログラムで対処できないので、言語が面倒を見てdeleteしてくれる。
規格では15.2にそう定められている。

ちなみに、そういうわけでnewを定義するときには必ず対応するdeleteを定義しないといけない。
ttp://www.fides.dti.ne.jp/~oka-t/cpplab-placement-new-2.html
356デフォルトの名無しさん:2009/05/23(土) 17:13:34
>>355
規格での項番まで示していただきまして、有難う御座います。
15.2/2 の箇所ですね。
規格に正しく準拠した処理系であれば問題ないとことで、懸念なく利用したいと思います。
有難うございました。
357デフォルトの名無しさん:2009/05/23(土) 22:49:39
初心者ではないと思っていたのですが、初心者からこんな質問を受けて
的確に答えられなかった自分が恥ずかしいです。どなたか、模範解答を教えてください。

「ヘッダファイルの用途と、使用によるメリットは理解できました。
ただ、cpp ファイルを分ける目的がわかりません。
また、cpp ファイルを複数持たせた場合、ビルド順はどうなるのですか?」

宜しくお願いします。
358デフォルトの名無しさん:2009/05/23(土) 23:01:32
むしろcppファイルを分けないでどうやってまともに開発しているのか分からないぐらいだが。

分割コンパイルすることで仕様変更に伴う再コンパイル時間の短縮とかも見込めるけど、
それ以上にそもそも他人が作ったクラスとかを使いたい(再利用したい)場合とか
cppファイルが分かれてなかったら再利用できないだろ。
359デフォルトの名無しさん:2009/05/23(土) 23:06:45
>>358
その観点で考えると、うちのプロジェクトは基本的にほどんどがヘッダファイルで構成されていて、
クラスは基本的に .h で作って #include で取り込む、っていう方法を取っています。
なので、再利用には困りません。
ほとんどがヘッダっていう考え方がNG?
あと、ビルド順序はどうなるものですか?やってみたんですが分かりませんでした。
360デフォルトの名無しさん:2009/05/23(土) 23:07:48
いやまて。ヘッダファイルに直接定義を書き込んでいるのか?
そんなことできないだろ。
361デフォルトの名無しさん:2009/05/23(土) 23:10:52
出来るだろ。じゃないとboostのビルド不要なライブラリは実現できないよ。
362デフォルトの名無しさん:2009/05/23(土) 23:12:36
「ビルド順はどうなるか」って、質問者はもちろん、>>357自身も理解してない気配。
分割コンパイルやリンクについてわかってないまま脱初心者とは。

ちなみに、グローバルやclass-staticな変数の初期化順については
何も規定されていないことが規定されている。
ということは、リンク順についてそれが当てはまることを意味するが
規格に「リンク」という単語が出ているかは知らない。

cppの分割については>>358と同じ。
classにわけたり、意味的なまとまりにわけたりして
まともなものを作るのなら分割するのが当然。

>>359
Javaチックな書き方ってことかね。
別にそれならそれで良いんじゃないの。
.hに全部書く、ということは、「ビルド(コンパイル)時間の短縮」なんて
露ほどにも考えていないということだから、
再利用もできるし分割コンパイルなんて必要無いかもね。
363デフォルトの名無しさん:2009/05/23(土) 23:13:20
言い方がまずかったか。「できないものがある」。こうだな。
もしかして、全部 inline にしたり、あらかじめ obj にしたりしてあるのだろうか。
364デフォルトの名無しさん:2009/05/23(土) 23:17:24
>>359
>クラスは基本的に .h で作って #include で取り込む、っていう方法を取っています。
>なので、再利用には困りません。
>ほとんどがヘッダっていう考え方がNG?
マジ??
その会社 大丈夫???

考えて見ればcppファイルが1つだけなら関数の定義とかを.hに書き込んでも
バイナリの時点で重複は起らないが(hでインクルードガードしていること前提ね。)
それにしても、、、ねぇ。。。
365デフォルトの名無しさん:2009/05/23(土) 23:18:54
>>360
dllexport が必要な時と、main() 系、コールバック系以外はすべてヘッダファイルなんです。
クラスの定義や構造体など、ほとんど。
ヘッダファイルの考え方が違うのかな…

>>362
規定が無い点について理解しました。
確かにうちのプロジェクトのソースはビルド時間かなりかかるんです…
.cpp で書くと分割コンパイルされて速度が向上するということですね。
まったく知りませんでした。。

まさに java チックです。
なので、include 順序がかなり大事で問題も結構起きるんですよね。
でも私個人的には、c++ で開発しているので、c++ の基本を知りたいです。

>>363
全然、そんなことないんです><
おまけに、プリコンパイルヘッダもないので時間ばかりが掛かって…
366デフォルトの名無しさん:2009/05/23(土) 23:21:28
>>365
ヘッダに定義を全部書いたら、クラスのインタフェースに全く影響を及ぼさない
変更であっても、そのヘッダに依存するソースファイルすべてが再コンパイル
されるじゃないか。その程度も分かってない会社って一体・・・
367デフォルトの名無しさん:2009/05/23(土) 23:22:39
>>364
インクルードガードしてもできないよ。
インクルードガードは同一翻訳単位内でしか有効ではないから。
368デフォルトの名無しさん:2009/05/23(土) 23:25:16
>>364
そうなんですよ!!
.cpp ファイルは main 用に1つだけあって、あとは .h の処理を呼び出したり、
クラスを生成してクラスに処理を任せたり、、、
グローバル関数までもが .h に居る始末です。

>>366
まさにその通りですね。
これでも一部上場なのですが、本当にお恥ずかしいです。
369364:2009/05/23(土) 23:25:54
>>367
いやできるでしょ。
cppが1つしかないんだぜ?
ってことは翻訳単位も(恐ろしいことだが)一つってことじゃん。
370デフォルトの名無しさん:2009/05/23(土) 23:27:17
すでに拡張子の意味を逸脱した使い方なのはわかった
371デフォルトの名無しさん:2009/05/23(土) 23:29:20
>>369
あぁ、そういうことか。理解したw
すごいな。
372357:2009/05/23(土) 23:33:35
結論としては、>>370 がおっしゃっているように、
拡張子の意味を確実に逸脱しているのですね。

みなさんがおっしゃったように、リンクの意味を理解していなかったようです。
分割ビルドは十分理解できました。

今一度教えてください。みなさんは .h を基本的にどのような用途で利用されていますか?
また、現状のように .cpp を1つだけもち、ほとんどすべてを .h に置くことで発生しうる
考えられる問題がありましたら教えてください。

>>369
すみません、私は理解できませんでした。
まだ初心者であることを思い知りました。
翻訳単位が1つだと、恐ろしいものですか?時間が掛かる、という観点でしょうか。
373369:2009/05/23(土) 23:40:35
>>372
>翻訳単位が1つだと、恐ろしいものですか?
そんな開発者見たことないから、恐ろしいと形容した。
>今一度教えてください。みなさんは .h を基本的にどのような用途で利用されていますか?
あくまで宣言だけを書いておく。
MyClassを使う必要があればMyClass.hをインクルードする。
一方MyClass.cppにもMyClass.hをインクルードしておいて、別途コンパイルしておく。
こうすることで、MyClass.cppが変更されても他の大部分のcppは再コンパイルしないで済む。
あるいはMyClass.cppをコンパイルしてライブラリとして公開する場合、
他社には.hだけを見せるわけだから実装を隠せるとか。

>また、現状のように .cpp を1つだけもち、ほとんどすべてを .h に置くことで発生しうる
>考えられる問題がありましたら教えてください。
他の会社や組織に公開する時に実装がだだ漏れになるとか
374デフォルトの名無しさん:2009/05/23(土) 23:46:19
つか、どんな教科書で勉強したんだよ。
大概の教科書は分割の仕方書いてあるだろ^^
375デフォルトの名無しさん:2009/05/23(土) 23:49:36
>>372
ビルドに時間が掛かって仕方がないだろう
376357:2009/05/23(土) 23:54:38
>>323
なるほど、、、将来を見据えた設計をしながら開発してるんですね。
なんかもう、うちの会社が悩ましいです。

>>374
会社の研修では一切…
ちなみにほとんどのプロジェクトがそんな感じです。
java と COBOL 人間ばかりなので、include = そこにそのファイル内容を挿入、っていう
意味合いだけしか着目していないんだと思います。

>>375
その通りですね。勉強になりました。


今日皆さんにご指導いただいた内容を以って、会社の開発体制の改善を
促して以降と思います。
ありがとうございました。
377デフォルトの名無しさん:2009/05/23(土) 23:55:23
まて、>>357は本当にC++を扱う一部上場企業に勤めているのか?

例えば、分割コンパイルには関係ないようなC++の問題だしても解けるか?
378357:2009/05/23(土) 23:55:32
>>376

>>323
× >>373
379デフォルトの名無しさん:2009/05/23(土) 23:56:27
どうせ元ABCのあそこだろ?
380デフォルトの名無しさん:2009/05/23(土) 23:59:44
>>377
私も信じられなくなってきましたが、こんな開発者ばかりながらも、
一部上場です。

私はアセンブル系のドライバ開発あがりで、ウィザードを利用して ATL/WTL アプリケーションの
開発をやっているので、一から自分でファイルを作ってプロジェクトを構成したことがありませんでした。
20年弱もプログラミングをして来ましたが、初心者からはなかなか抜け出せませんね。

大変勉強になりました。
381デフォルトの名無しさん:2009/05/24(日) 00:06:46
>>380
そうなのか。
じゃあもういっそC++やめて、各自が得意なCOBOLとかアセンブラやればいいのではないでしょうかね。。。

少なくとも一人、C++の知識がある人が居ないととんでもないことになるのでは。

まああなたがその一人になれば良いだけだが。
頑張ってください。
382デフォルトの名無しさん:2009/05/24(日) 00:07:00
>>380
大丈夫。そのやり方で会社が回っているならそれで正しい。
開発の仕方に正解なんてないんだし、そもそも他と同じことをやっていたらこのご時世生き残れない。

君の会社は君の会社なりのやり方を見つけたんだと思う。だから生き残っているんだろう。
もっと、堂々としていいよ。
383デフォルトの名無しさん:2009/05/24(日) 00:16:10
>>381
なかなか COBOL やアセンブルの案件が見つからなくなってきたんですよね。。
でも、頑張ります!ありがとうございます。

>>382
ありがとうございます。
基本をしっかり抑えた上で、スタイルを大事にして行くことにします。
384デフォルトの名無しさん:2009/05/24(日) 00:37:07
>>380
優秀であってもドカタ企業のドカタじゃどうしよもないよ
一部上場の正社員とドカタ企業のドカタじゃ霄壌の差
385デフォルトの名無しさん:2009/05/24(日) 02:15:34
言わなくてもわかってるからもうドカタに触れるのやめようよ
可哀想だろ俺が
386デフォルトの名無しさん:2009/05/24(日) 02:27:32
一部上場ならお給金もそれなりでしょ
まともな本買いましょうよ
387デフォルトの名無しさん:2009/05/24(日) 02:39:06
初心者にまともな本買えって言っても、
どれがまともな本なのかわからんでしょ
まともな本教えましょうよ
388デフォルトの名無しさん:2009/05/24(日) 02:54:41
学生の勉強じゃない仕事の事なんだから、休みの日にでも本屋に出向いて
中を見て初心者なりでも”自分”で選ぶべきだと、俺は思う
で、幾つかの本を読破してこそ、まともな本かどうかの判断が付く脱初心者になって行くんだと思う

その最初のステップを”初心者”と言う理屈で飛ばすような奴が
プログラムの本を読んで技術力を上げていくなんて出来ないだろ

そもそも、本人が教えてと言ってるならともかく
初心者なんだから教えるべき、と言って自分は教えてない奴は好きじゃないw
389デフォルトの名無しさん:2009/05/24(日) 02:59:18
兎にも角にも禿本は重要だよな。
特に後半の設計に関する部分を読んでない人は多いと思うけど、色々含蓄あるし。
390デフォルトの名無しさん:2009/05/24(日) 03:02:13
俺が書いたネタレスに入魂レスとは....
ネタと分かるように語尾を>>386と同じにしたのに
釣られる奴居るんだな
391デフォルトの名無しさん:2009/05/24(日) 03:05:39
>>388
長々と小言を言う暇があるなら、自分が薦める本を挙げればいいのに。

>>390
釣りならVIPでも行ってやれば?
392デフォルトの名無しさん:2009/05/24(日) 03:15:54
だから最初の理解なんて人それぞれ
俺が良いと言ったって、合う合わないがある、だから教えないし、
自分でググるなり、本を手に取れって言ってるじゃん

アンタゆとり?
393デフォルトの名無しさん:2009/05/24(日) 03:25:13
釣りに延々とマジレスしてきもいな
394デフォルトの名無しさん:2009/05/24(日) 03:25:14
以下のプログラムがうまく行かないのですが、
解決方法を教えて下さい。

 5 class B;
 6
 7 class A{
 8  public:
 9   int hoge;
10   A(int i){ i = hoge; }
11
12   B conv(){ return B(hoge); }
13 };
14
15 class B{
16  public:
17   int hoge;
18   B(int i){ i = hoge; }
19
20   A conv(){ return A(hoge); }
21 };


-------------------

エラー
test.cpp: In member function ‘B A::conv()’:
test.cpp:12: error: return type ‘struct B’ is incomplete
test.cpp:12: error: invalid use of incomplete type ‘struct B’
test.cpp:5: error: forward declaration of ‘struct B’
395デフォルトの名無しさん:2009/05/24(日) 04:39:09
Bの定義より後にA::convの定義を置けば上手くいく。
class B;

class A {
public:
int hoge;
    A(int i) { i = hoge; }

    B conv();
};

class B {
public:
int hoge;
    B(int i) { i = hoge; }

    A conv() { return A(hoge); }
};

B A::conv(){ return B(hoge); }
396デフォルトの名無しさん:2009/05/24(日) 04:40:16
class B;
class A {
 ...
 B conv();
 ...
};
class B {
 ...
};

B A::conv() {
 return B(...);
}
397デフォルトの名無しさん:2009/05/24(日) 04:45:07
>>395
>>396
ありがとうございます。
398デフォルトの名無しさん:2009/05/24(日) 05:36:49
complexは実数、虚数にreal()、imag()でアクセスするわけですが、
この関数って参照返すだけだから、
それだったら内部の実数、虚数変数に直接アクセスした方が関数呼び出し無い分早いだろうし、
ソースコードも見やすく(多分)なると思うのですが、
これには何か理由があるのでしょうか?
399デフォルトの名無しさん:2009/05/24(日) 08:12:11
400デフォルトの名無しさん:2009/05/24(日) 10:53:54
>>398
基本的に内部の実装に触れられるようにしちゃうと
いざインターフェースは変わらないが実装が変わるような仕様変更をするときに
悲劇がおこるからとか。
401デフォルトの名無しさん:2009/05/24(日) 14:06:24
あと、関数呼出のオーバーヘッドなんてないと思っていいよ。
それくらいコンパイラの最適化でいともたやすく消え去るられる。
402デフォルトの名無しさん:2009/05/24(日) 14:11:10
そんなことはない
だったらなぜわざわざinlineなんて予約語が用意されてるんだ?

関数呼び出しを減らすのは高速化の基本のキだ
ウソを教えるのはやめろ
403デフォルトの名無しさん:2009/05/24(日) 14:15:36
>>402 の年齢が気になる
404デフォルトの名無しさん:2009/05/24(日) 14:15:42
現在は なんでもかんでもゲッタセッタ教 の勢が強いから
狂信者の戯言は聞き流して己が道を進めばいいと思うよ
405デフォルトの名無しさん:2009/05/24(日) 14:20:59
下駄雪駄教徒だって、下駄雪駄は基本的にインライン関数にするだろう
アウトラインの下駄雪駄なんておぞましいものは狂信者でも書くわけがない

少なくとも長いループ内では、アウトライン関数を呼んではいけない
これは今も重要なガイドラインだ
406デフォルトの名無しさん:2009/05/24(日) 15:01:18
少なくともC++でフィールド変数直接アクセスするのは
百害あって一利なしだな。

>>402
>>401が言ってるのはreal/imagの話だろ。
言葉足らずならそう指摘すればいいのに。力抜けよ。
407デフォルトの名無しさん:2009/05/24(日) 15:05:37
http://ja.wikipedia.org/wiki/%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89_(%E8%A8%88%E7%AE%97%E6%A9%9F%E7%A7%91%E5%AD%A6)
下の方のアクセサの項目
408デフォルトの名無しさん:2009/05/24(日) 15:06:24
せったげったって言うけどさ

hoge.hage.foo.bar.set_value(0); とかはあったとしても
hoge.get_hage().get_foo().get_bar().set_value(0); なんてことはしないよね

この辺みんなどうしてるんだろ。
hage や foo は public なメンバにするよね?でもそれだと統一感ないよね?
409デフォルトの名無しさん:2009/05/24(日) 15:08:19
どっちもねーよ
410デフォルトの名無しさん:2009/05/24(日) 15:12:41
データ主体なものは構造体にしている
メンバ関数はコンストラクタ、コピー、シライライズ、ダンプ、アサートぐらいしか定義しない

それと同じ目的の変数は構造体にまとめる

class A
411デフォルトの名無しさん:2009/05/24(日) 15:15:28
途中で送ってしまったぜ
後ろの段落は class の中で struct xxx_param とか struct xxx_item, xxx_state とかを定義して
まとめてあつかう
412デフォルトの名無しさん:2009/05/24(日) 15:18:06
おなじくどっちもねーよ

> hoge.hage.foo
この辺までですでに内部状態の一貫性を壊していると思われ(setの場合)。
設計が悪いから作り直せ。
413デフォルトの名無しさん:2009/05/24(日) 15:38:47
え?でもさ、よくしらないけど、フォームアプリなんて
System.Form.SetValue() みたいにどんどん深くなっていってない?

実モデルでたとえても、例えば
部屋A.本棚B.本C.ページD.GetText();
みたいな例は十分にありえるんじゃないの?
414デフォルトの名無しさん:2009/05/24(日) 15:39:02
>>402は今でもregisterを使っているのだろうか。
415デフォルトの名無しさん:2009/05/24(日) 16:02:00
せめてこうだろ
void foo::set_bar_value(int n) { bar.set_value(n); }
void hage::set_bar_value(int n) { foo.set_bar_value(n); }
void hoge::set_bar_value(int n) { hage.set_bar_value(n); }
hoge.set_bar_value(0);

俺はvector3やmatrix44みたいなのは公開してるなあ。
あとは、クラスとして独立させるほどでもないが、関連のあるメンバ変数をグループ化したいときに
structを使ってる。
416デフォルトの名無しさん:2009/05/24(日) 16:05:06
>>413
System.Form.SetValue()
どこのC#?

あとそれ名前空間と混ざってるから。
417デフォルトの名無しさん:2009/05/24(日) 16:13:50
でも名前空間って要するに全メンバがpublic静的なクラスのことだろ
418デフォルトの名無しさん:2009/05/24(日) 16:21:41
>>415
それはない
419デフォルトの名無しさん:2009/05/24(日) 16:38:05
しょぼい設計でなければ
名前空間で内部状態を壊されることはないから問題ない。
420デフォルトの名無しさん:2009/05/24(日) 17:11:46
class A{
  B* get();
}

というクラスで、get()メソッドをインライン関数にしたい
テンプレートクラスと同様に同じヘッダファイルに実装を書く場合、
inline B* A::get(){
  コード
}
の「inline」は意味があるのでしょうか?
421デフォルトの名無しさん:2009/05/24(日) 17:15:11
ない
というか意味があるかないかで言うなら、inlineは常に意味がない
コンパイラは自由にインライン化要請を無視できるし、要請されてない関数をインライン化することが出来る
422デフォルトの名無しさん:2009/05/24(日) 17:25:36
規格上はそうだが、一応現実的には意味はあるから、意味なしと言い切ってしまうのは誤解を招くのでは。
例えば俺が使っているコンパイラは「inline指定に従う/無視する」「inline指定がなくても勝手にinline化する/しない」
などの指示を自分で出すことができる。
423422:2009/05/24(日) 17:26:22
もちろん環境依存の話だから、詳しくは「自分が使ってるコンパイラについて調べてね」ってことだけど。
424デフォルトの名無しさん:2009/05/24(日) 17:33:39
inlineは、コンパイラの最適化云々ではなく、
ヘッダに直接(= インラインで)定義するぞ、という意味だと思えばいい。
425デフォルトの名無しさん:2009/05/24(日) 17:53:20
>>424
変な誤解を生むから詳しく知らないなら
黙ってるか断定的に書くな。
426デフォルトの名無しさん:2009/05/24(日) 18:02:20
>>424
適当なこと書くなよ。
cppファイルにてもinlineは書けるわけだし
もう何が何なのかw
427デフォルトの名無しさん:2009/05/24(日) 18:05:30
>>424
インラインに”ヘッダに直接”という意味があったなんて白なkったおれはどうすればいい?
428デフォルトの名無しさん:2009/05/24(日) 18:06:30
 "C++" "ヘッダに直接" "インライン"の検索結果 5 件中 1 - 5 件目 (0.33 秒)
429426:2009/05/24(日) 18:08:40
>>428
よくやったwww
430デフォルトの名無しさん:2009/05/24(日) 18:35:56
ところで>>420でinlineを付けなかったらリンカエラーにならない?
そういう意味でinlineはいると思うんだけど。
431デフォルトの名無しさん:2009/05/24(日) 18:37:06
んなわけない。
432デフォルトの名無しさん:2009/05/24(日) 18:38:13
>>430
よくわからないけどオブジェクトコードにクロージャっぽいのがつくられるきがするぅ
433デフォルトの名無しさん:2009/05/24(日) 18:53:52
int DLLAPI (*mcOpenDevice ) (void) = NULL;

あるDLLについてたヘッダ内の記載なんですがVCで「構文エラー : '('」が出ます
カッコの数は合ってるし、関数ポインタの宣言としてもおかしくないように見えるのですが
詳しい方から見て何か違和感はありますでしょうか?

ちなみに #define DLLAPI WINAPI されてます
434デフォルトの名無しさん:2009/05/24(日) 18:55:29
ん、俺の環境(gcc 3.4.5)だと、ヘッダファイルのクラス定義内部じゃないところにinlineがついてない関数定義があって
それを複数の翻訳単位でインクルードしてコンパイルしてリンクすると、多重定義エラーでるなぁ。
435デフォルトの名無しさん:2009/05/24(日) 18:56:14
問題ないと思う
多分その直前に何かおかしい所がありそう
436デフォルトの名無しさん:2009/05/24(日) 18:58:40
WINAPIを関数名と勘違いしちゃったんだろうな。
437デフォルトの名無しさん:2009/05/24(日) 19:02:20
>>435 ありがとうございます
自分の作ったのでも結構悩むのに、さらに人の作ったのだと難度高いです・・・
もうちょっと見直してきます
438デフォルトの名無しさん:2009/05/24(日) 19:18:02
プリプロセスだけ通してみるとか
439デフォルトの名無しさん:2009/05/24(日) 19:19:27
先に<windows.h>をインクルードしたらいいと思う。
440デフォルトの名無しさん:2009/05/24(日) 19:30:27
>>438
プリプロセッサ以外の記述を削除ってことですか?

>>439
<windows.h>とかメジャー系はいくつか試したんですがダメでした・・・
441433:2009/05/24(日) 19:35:13
>>433のはMCRWwinというツールのです
ttp://www.geocities.jp/altshibabou/win/image/mcrwwin110.LZH

どなたかVC使いの方でビルド通るか実験して頂ける方はおりますでしょうか
最近入れなおしたので、私のVCの設定が悪いのかもしれない
442デフォルトの名無しさん:2009/05/24(日) 19:37:14
とりあえず
#define WINAPI

#define WINAPI __stdcall
って書いとけ。
443433:2009/05/24(日) 19:52:22
>>438
すんません、勘違いしてました
/E /Pで.i吐かせて該当行見ましたら

int __stdcall (*mcOpenDevice ) (void) = ((void *)0);
と展開されてました、他の箇所も見た感じ悪くはなさげなのです
444デフォルトの名無しさん:2009/05/24(日) 20:09:04
>>443
おお、それはエラーになる。
int (DLLAPI *mcOpenDevice)(void) = NULL;としてみるんだ。

http://msdn.microsoft.com/ja-jp/library/zxk0tw93.aspx
一番最後のExampleでもそうなっている。
445420:2009/05/24(日) 20:19:30
>>421-434
VC++2003を使っていて、今のところ1つのcppファイルからしかインクルードしてないので
inlineを付けても付けなくても問題はなかったのですが、
付けないとcppファイル毎に関数が定義されているとみなされる=>>430>>434
ということなんでしょうね。
どうもありがとうございました。
446433:2009/05/24(日) 20:19:42
>>444
ありがとうございます、無事ビルド通りました
>>436さんも多分同じこと指摘してくれてたんですよね、分からなくて申し訳ないです

みなさんのおかげで先に進めそうです
本当にありがとうございました。
447デフォルトの名無しさん:2009/05/24(日) 21:06:14
超初心者ですがコンパイラ何使ったらいでしょう?
448デフォルトの名無しさん:2009/05/24(日) 21:06:41
gcc
449デフォルトの名無しさん:2009/05/24(日) 21:09:35
書き忘れました
windowsで使えるものをお願いします
450デフォルトの名無しさん:2009/05/24(日) 21:10:55
>>448
よくわからないのでとりあえずぐぐってみます
ありがとうございます
451デフォルトの名無しさん:2009/05/24(日) 21:13:22
>450
WinならMinGW
まあgccなんだけどな
452デフォルトの名無しさん:2009/05/24(日) 21:13:37
453デフォルトの名無しさん:2009/05/24(日) 21:15:33
>>451-452
レスありがとうございます
454デフォルトの名無しさん:2009/05/24(日) 21:35:25
Toubo C++
455デフォルトの名無しさん:2009/05/25(月) 01:23:27
>>454
初めて聞いた。
そしてググってみてちょっと面白かった。
456デフォルトの名無しさん:2009/05/25(月) 01:28:58
7件しかヒットしないぞ?
しかも全部中国。
457デフォルトの名無しさん:2009/05/25(月) 02:44:48
昔はTurboCといえば、M$としのぎを削った人気コンパイラだったのだよ。
458デフォルトの名無しさん:2009/05/25(月) 04:02:59
いやTouboだし。
459デフォルトの名無しさん:2009/05/25(月) 05:23:12
Toubo C++

検索したら漢字ばっかで
いじる勇気がでない。
460デフォルトの名無しさん:2009/05/25(月) 06:40:45
JIS X3014 6.6.3 return の 2 の最終行、「未定」が「末定」になってるw
461デフォルトの名無しさん:2009/05/25(月) 07:46:16
しばらくVBAばっかりいじってたから、C++のウィンドウの扱いが面倒に思えて困る

いつもVCの空のプロジェクトにダイアログリソース突っ込んで出してるんだが
ひょっとして空のプロジェクト使わなければC#とかみたいに簡単に扱えるのかな?
空じゃないプロジェクトって最初からコードいっぱい書いてて抵抗あったから今まで触ったこと無いんだ
462デフォルトの名無しさん:2009/05/25(月) 07:48:25
スレ違いすぎるだろ…
463デフォルトの名無しさん:2009/05/25(月) 08:31:50
>>461
vcでポトペタできるのはダイアログだけだよ
ウィンドウはムリポ
スケルトンコードは慣れかな
どうせ似たようなコード書くんだし

続きはVSスレかWinAPIスレかMFCスレで
464デフォルトの名無しさん:2009/05/25(月) 08:46:11
461です、スレ違いすまんかった
覗いてみた感じここの奴は視野が広そうだったから、ここで聞いてしまった

数年前に比べて大して便利になってないという事だな
昔作ったスケルトン掃除して使ってみるよ、ありがとう
465デフォルトの名無しさん:2009/05/25(月) 19:30:32
blitz::Arrayって何を意味してる? ググってもわからんかった
466デフォルトの名無しさん:2009/05/25(月) 19:46:06
>>465
C++の言語に関する話としては
blitzというクラスの、Arrayというメンバ。もしくは、blitzという名前空間に含まれる Array というもの。

実際ぐぐってみたところ、Blitz++というライブラリがあるみたいだね。
このライブラリでblitzという名前空間を使っているようだ。
467466:2009/05/25(月) 19:47:15
英語が苦手で無いなら以下をどうぞ。
ttp://www.oonumerics.org/blitz/docs/blitz_2.html
468デフォルトの名無しさん:2009/05/25(月) 20:11:46
>>467
回答どうも 軽く読んでみた。
じゃあどうやら 『blitz::Array< int, 2 > A 』 って宣言だと
『中に整数値の入る2次元の行列式の定義をbiltzっていう名前空間でやってる』って感じでいいのかね
Arrayは直訳で行列じゃなくて配列なのが気になるんだけどね・・・
469デフォルトの名無しさん:2009/05/25(月) 20:15:59
>>468
細かいとこちょっと違うけど概ねそんな感じ。
470デフォルトの名無しさん:2009/05/25(月) 20:21:33
>>469
ごめん Cは前々からやってたんだけどC++は最近独学で始めたばっかりなんだわ…
で、違うところって? (俺の知識が浅いから、伝わらなそうだったらスルーしてくれ)
471デフォルトの名無しさん:2009/05/25(月) 20:24:23
>>470
ごめん、ちょっと忙しくなるから、後でまた来るわ
そのときまでに他のレスがついてなかったら書くよ
472471:2009/05/25(月) 21:07:14
まず、blitz::Array そのものは blitz名前空間の中に入ってるが、
blitz::Array< int, 2 > A;
とした場合、(これ自体をblitz名前空間の中に書かない限り)このAはblitz名前空間には入らない。

あと、「行列式」じゃなくて「行列」だな。(似てるけど意味が違う)
473デフォルトの名無しさん:2009/05/25(月) 21:10:27
行列式でいいだろ
行列を表すexpressionなんだから

determinantのことを言いたいなら、それは揚げ足取りと言うものだ
感心しない
474デフォルトの名無しさん:2009/05/25(月) 21:10:55
C++始めたばかりなら名前空間をよく分かってないかもしれんが
まあ、ちょっと語弊があるけど “blitz::Array<int,2>” で1つのクラス名だと思ってしまってもよい。
int a;
がint型の変数aであるのと同じように
blitz::Array<int,2> a;
は blitz::Array<int,2> 型の変数aだ。

名前空間ってのは、例えばライブラリ作成者がArrayっていう名前のものを提供している場合、
利用者のコードにもArrayってのがあると名前が衝突してしまって不都合だから、
名前がぶつからないように blitz:: という修飾をつけてるんだと思えばよい。
475デフォルトの名無しさん:2009/05/25(月) 21:12:06
>>473
そうか? 俺はどうしても気になるし明確に誤りだと思うが、まあ揚げ足取りと取られるならこれ以上は言うまい。
476デフォルトの名無しさん:2009/05/25(月) 21:14:04
>>473
アホだろお前。
477デフォルトの名無しさん:2009/05/25(月) 21:55:28
行列式は駄目でしょ
478470:2009/05/25(月) 22:04:48
なんか複数人からレスもらってるみたいで、皆さんどうもありがとう
blitz::Array<int,2> 型の変数aって感じは掴めてたんだけど、そもそもblitz::Arrayは何を表現するのかが不明で困ってたのよ

それはそうとプログラム板って初めて来たけどID表示ないんだな、不便じゃない?
479デフォルトの名無しさん:2009/05/25(月) 22:13:22
>>476
そういう言い方はたとえ2chでもどうかと思うぞ

まぁでも
行列と行列式は…何と何くらい違うんだろ。ブドウとグレープフルーツくらい?
480デフォルトの名無しさん:2009/05/25(月) 22:16:39
>>478
スクリプト書けばID丸わかりだから不便じゃないよ。
481デフォルトの名無しさん:2009/05/25(月) 22:53:31
IDが分からなくても別に不便を感じたことない。
482デフォルトの名無しさん:2009/05/25(月) 23:01:25
Win32APIスレはなりすましで大変なことに…
483デフォルトの名無しさん:2009/05/25(月) 23:06:44
別に大変じゃないし
484デフォルトの名無しさん:2009/05/26(火) 10:34:48
>>395

A(int i) { i = hoge; }

↑ は何をしたいの?
485デフォルトの名無しさん:2009/05/26(火) 15:55:38
とてもサイズの大きなメンバ変数があったとき、
「そのメンバ変数のポインタを返すようなメンバ関数を作る」か、
「そのメンバ変数のコピーを返すようなメンバ関数を作る」か、
どちらがオブジェクト指向としてはよろしいのでしょうか?
前者だと、privateなメンバ変数に対して外部からタッチしてしまうことになりますが、
無駄が少ないように思えます。
後者だとprivateなメンバ変数を保護(?)できるというか、そういう考え方に則しているような気がしますが、
無駄にメモリを食ってしまう気がします。
完全に独学のため、ちょっと意味不明な単語が混じっているかもしれませんが、
教えてください。よろしくお願いします。
486デフォルトの名無しさん:2009/05/26(火) 16:03:49
>>485
どちらも問題外
クラスの設計をし直せ
487デフォルトの名無しさん:2009/05/26(火) 16:11:05
int gethoge();のような関数を作るのはよろしくないということなんでしょうか?
↑だとintのコピーを返す関数に当たると思うのですが、問題外となると、ちょっと目の前が真っ暗になってきました…。
488デフォルトの名無しさん:2009/05/26(火) 16:49:15
privateな構造がしゃしゃり出てくるクラス設計が間違い
最初からpublicに分類すべき
それで問題が出るなら普通の人なら根本から作り直すね
489デフォルトの名無しさん:2009/05/26(火) 16:54:31
すみません、現段階ではちょっと理解できないのですが、文献を漁ってなんとかしてみます。
貴重なアドバイスありがとうございます。
490デフォルトの名無しさん:2009/05/26(火) 16:55:12
>>485
const なポインタ or 参照を返せば、他から変更はできないけど、
他の部分がそのオブジェクトの構造に依存することになるね
491デフォルトの名無しさん:2009/05/26(火) 19:08:44
アクセス制御がなんのためにあるのかという根本が分かってないように見える
492デフォルトの名無しさん:2009/05/26(火) 19:49:43
>>485
まあ要するに、

クラスのクライアント(使う人)が
privateなメンバ変数(およびprivateメンバ関数)
については何も知らなくても
publicなメンバ関数を見るだけで
使えるように設計すべき

ということだよ。
これはすなわち、public/protectedなメンバ関数以外が変わっても
クライアントが書いたコードには影響がないということ。

ちなみにpublicなメンバ変数なんて大抵はクソ設計の証。
493デフォルトの名無しさん:2009/05/26(火) 20:06:47
485じゃないけど
>>492
それは基本的にはカプセル化に重点を置いてコードを書いた方が良い、ということで良いんでしょうか?
494492:2009/05/26(火) 20:41:33
>>493
そう。基本的にはね。
オブジェクト指向プログラミング (OOP; object-oriented programming)
においてカプセル化はとーーっても大事。

たまにいっそ全部publicにということで構造体structを使うことがあるけど
基本的にはそういうこと。
495デフォルトの名無しさん:2009/05/26(火) 21:29:31
なんとなく分かってきました、ありがとうございます
496デフォルトの名無しさん:2009/05/26(火) 21:44:30
まあ現実的にはpublic変数だの参照返しも使うことはあるけどね
497デフォルトの名無しさん:2009/05/26(火) 21:47:56
ねえよ
498デフォルトの名無しさん:2009/05/26(火) 21:52:34
無意味な隠ぺい無意味な複スレッドは考える力が足りない人が一度はハマる道程だからね
499492:2009/05/26(火) 21:54:08
現実にはそういう場合もあるかもしれないけど、
「良いクラス設計」の話に限った場合、フツーはない。

「全部publicにということで構造体struct」
は返り値に複数の情報を持たせたい時とかにありえる。
ただ複数の型を束ねただけ。
500デフォルトの名無しさん:2009/05/26(火) 21:57:34
GetとSetがズラリと並んだクラスは結構見るな
501デフォルトの名無しさん:2009/05/26(火) 22:00:53
ねえよ
502デフォルトの名無しさん:2009/05/26(火) 22:04:41
>>500
学生の頃作ったプログラム見直してみるとGetとSet多用しててえらいことになってた
今でもうまい設計はできないけど、他で使うならpublicでいいよねって話だよな
503デフォルトの名無しさん:2009/05/26(火) 23:46:22
Effective C++には最悪でもget()とset()用意しろって書いてあるよ^^

structでメンバ変数をpublicにするのは
>>499の言うとおり、値を束ねただけのものとして、
構造体を値として扱う場合にだけ許される。

Effective C++やC++ Coding Standards、Google Coding Standardsなんかを
ひとつも読んでいない人間はC++触らないでください
504デフォルトの名無しさん:2009/05/27(水) 00:14:57
>>503センセー俺1つも読んだことないんですけどー
505デフォルトの名無しさん:2009/05/27(水) 00:21:02
読むだけなら馬鹿でもできるから気にする必要無い
506デフォルトの名無しさん:2009/05/27(水) 00:43:52
class A{
int a;
public:
int get(){return a;}
void set(int i){a = i;}
};

こういうのはさすがにpublic派のほうが多い気がする
507デフォルトの名無しさん:2009/05/27(水) 00:53:05
宗教になぞらえられたりする理由なんだろうけど本人が気付くまで周りが何を言っても無駄なんだよね
距離を置いて厄災に巻き込まれないようにするだけ
508デフォルトの名無しさん:2009/05/27(水) 01:15:12
>>506 が「何を」 public にするのかは知らないけど、
もし int a を public にする気なら、豆腐の角に頭をぶつけて死ねといいたい
509デフォルトの名無しさん:2009/05/27(水) 01:27:16
メンバ変数をpublicに置くような人間は抽象化には興味ないんだろうな。
C++使う理由がないよ。多分。
510デフォルトの名無しさん:2009/05/27(水) 01:33:51
aがクラスや配列やポインタなら全くもってその通りだがintだぜ?
こんなプリミティブなメンバまで変更しなきゃならない時にはどうせインターフェースも変更入るよ
そこまでいちいちgetset噛ませと言い出すとちょっと原理主義すぎて現実的でない
511デフォルトの名無しさん:2009/05/27(水) 01:49:08
こういうとき、プロパティのある言語がうらやましいと思う。
512デフォルトの名無しさん:2009/05/27(水) 01:50:40
もしgetterやsetterで参照する対象が巨大な配列やクラスだったら
重いコピーが発生する事を覚悟しなければならない

つまり巨大な配列やクラスはgetterやsetterの対象にはならない
513デフォルトの名無しさん:2009/05/27(水) 01:55:01
>>510
返すのがintだからどうだって話じゃないだろ。たとえば
class A{
int a,b,c,d,e,f,g,h,i,j,k,l,m,n;
以下略
};
こんなのの実装をimplイディオムに変えたいと思ったときどうすんだよって話。
514デフォルトの名無しさん:2009/05/27(水) 01:55:07
どこの世界も原理主義には付き合ってられない
515デフォルトの名無しさん:2009/05/27(水) 02:00:14
getとsetをpublicで公開するということは、
「いつでも誰でも見ていいし好き勝手に変えてもいい『何か』を持ってますよ」ということを
外部に向けて大っぴらに公開しているということです
したがって、そのセマンティクスを変更するのはインターフェースの変更なんだから
getとsetを使っている全ての箇所に影響が出てしまいます

これってよく見ると『何か』を変数としてpublicで公開した時と状況はまったく変わりませんね
publicなgetとsetを両方用意するというのは、同じ事を回りくどく書かせるだけであって
可読性も保守性も一切上がりません

intだろうと何だろうと何でもかんでもgetsetというのは罠であり、有害な迷信です
public変数のセマンティクスを持つものはpublic変数でいいんです
516デフォルトの名無しさん:2009/05/27(水) 02:10:14
わずかなタイプ数の増加が"現実的"でない理由って何よ?
517デフォルトの名無しさん:2009/05/27(水) 02:13:29
privateに固執するおまえはマダマダ無能と言われてるんだよ。
518デフォルトの名無しさん:2009/05/27(水) 02:14:45
無意味なget setで行が肥大化するのはプログラムを見づらくするだけ。
原理主義的には、カプセル化した気分に浸れていい
519デフォルトの名無しさん:2009/05/27(水) 02:14:47
現実には、そのセッタでだた代入するだけなんてことはなくて、
たいてい、ついでにどこかに値の変更を通知したり、
入力値が範囲外なら例外投げるようにしたりしていて、
単純にメンバ変数をpublicにできる場合なんて全然ないと思うんだけど。

そんな場合の話はしていないって?
520デフォルトの名無しさん:2009/05/27(水) 02:18:11
今回の基準は>>506だろ。ただ代入するだけ。
521デフォルトの名無しさん:2009/05/27(水) 02:18:39
今話題に上がっているのは、ただのset get。
意味があるのは問題なし。
522デフォルトの名無しさん:2009/05/27(水) 02:27:02
マルチスレッドから操作されるようになったので、
aを防御したくなったらどうするの?
aが頻繁に変更されるようになったので、
毎回最新の値をサーバから取得したくなったらどうするの?
aに連動してbも変更したくなったらどうするの?
正当な値だけ受け付けるようにしたくなったらどうするの?
aが更新されたことをBに通知してあげたくなったらどうするの?
将来行われる変更を全部見通すことができるの?
523デフォルトの名無しさん:2009/05/27(水) 02:31:06
>>519
そういう色んなことをする関数は単純なsetではなく、もっと意味のある名前を付けられるはず
なんかの大きさならresizeとか、通知するんだったらnoticeとか
その相方はgetとしか言い様がないこともあるだろうけどさ

両方とも本当にget,setとしか名付けようもないようなものは、その意味合いは内部的にも外部的にも
ただのpublicメンバ変数だと思うんだけどなぁ

>>522
排他制御はともかく、他はgetXXだのsetXXだのという名前を付けるべき操作ではない
524デフォルトの名無しさん:2009/05/27(水) 02:36:49
>>523
何を根拠に。
ちょっとした処理付きのgetXX/setXXなんて普通に使うぞ?
525デフォルトの名無しさん:2009/05/27(水) 02:41:39
お行儀の悪いプログラムってやつだな
526デフォルトの名無しさん:2009/05/27(水) 02:46:21
>>525
アホは黙ってろ
527デフォルトの名無しさん:2009/05/27(水) 02:54:33
もういいからsetしようとしたら強制的に例外投げろよ
528デフォルトの名無しさん:2009/05/27(水) 02:59:26
>>527
それもpublicメンバ変数じゃできないな。
アクセス違反がせいぜい。
529デフォルトの名無しさん:2009/05/27(水) 03:00:35
>>524
例えば「正当な値だけ受け付ける」ようにsetXXを変更したとしようか
そうなると不当な値が入ってきたらエラーなり例外なりを返すんだろうが、
旧バージョンのsetXXを使ったコードは当然そのエラーに対応する処理をしていないので問題が起こる

つまり、この変更はインターフェースの変更であって、全てのsetXXを使用するコードに修正を迫るものであるわけだ
素直にsetXXの呼び出しを全部修正してもいいし、旧setXXとは機能が違う新setXXを(機能に見合った名前で)
新しく別に作って適宜置き換えるのでもいいが、結局はsetXXの呼び出しは全てチェックする必要がある

でも、どうせset箇所を全部見直す必要がある変更なんだから
最初からpublic変数で書いて、必要になってからset関数を書いてもまったく同じだろ?
530デフォルトの名無しさん:2009/05/27(水) 03:05:45
>>529
確かに、エラーの追加はインターフェースの変更だ。
そこは全面同意。

でも1つしか答えてないぞ。
531デフォルトの名無しさん:2009/05/27(水) 03:56:00
> getとsetをpublicで公開するということは、
> 「いつでも誰でも見ていいし好き勝手に変えてもいい『何か』を持ってますよ」ということを
> 外部に向けて大っぴらに公開しているということです
この認識は間違い。
getとsetをpublicで公開するということは誰でも自由に行ってもいいのはただセッタゲッタの呼び出しだけで
その結果は呼び出し側の都合ではなくクラスの都合で決定されます。
クラスの都合を無視してクラスの状態の参照や変更を行うことはできませんということをいっている。

> 例えば「正当な値だけ受け付ける」ようにsetXXを変更したとしようか
> そうなると不当な値が入ってきたらエラーなり例外なりを返すんだろうが、
> 旧バージョンのsetXXを使ったコードは当然そのエラーに対応する処理をしていないので問題が起こる
こうした場合は実装の変更ではなく仕様の変更なのでセッタゲッタによるカプセル化(=実装の隠蔽)のメリットとは無関係。
532デフォルトの名無しさん:2009/05/27(水) 04:06:47
個人的には自由変数を1個インターフェースとして公開するごとに
そのクラスの内部設計の自由度が減るのがいやだな

あとは>>519と同じ意見でただ代入するってのはあまりない
たいていマルチスレッド用の排他処理がくっついたりする
533デフォルトの名無しさん:2009/05/27(水) 08:09:58
メソッドとメンバしかないC++が全て悪い。

object.set_value2( object.get_value0()->get_value1() );
こう書くより、

object.value2 = object.value0->value1;
こう書いた方が、見やすいものなぁ。
534デフォルトの名無しさん:2009/05/27(水) 08:13:32
>>533
operator =で見やすいほうの書き方にできるのでは?
535デフォルトの名無しさん:2009/05/27(水) 08:34:48
>>533
10年前に作られた言語だからな…

>>534
できなくもないけど結構面倒だよ
536デフォルトの名無しさん:2009/05/27(水) 08:51:13
C++知らない俺が言うのもなんだけど、set/getなんていう
低レベルのインタフェース作るのが間違ってるんだよ。
もっと抽象化された機能のメソッドを作るべき
537デフォルトの名無しさん:2009/05/27(水) 09:24:08
>>535
>10年前に作られた言語
wikipediaによると標準化からは10年だが、C++2.0から20年、前身のC with Classesから30年のようだ
D&Eなんかで示された考え方も今では古くなりつつあるのかと思うと少し寂しくなる
538デフォルトの名無しさん:2009/05/27(水) 09:28:03
何でさっき知ったばかりなのに寂しがってんだよw
539デフォルトの名無しさん:2009/05/27(水) 10:04:33
>>536
get/set全てが低レベルなインターフェースとも限らないけどね
2,3行目は俺も同じ意見だ
540デフォルトの名無しさん:2009/05/27(水) 12:02:18
結局、変数をpublicに置くような連中に何を言っても無駄ということが証明された様子。
>>515に対する反論はEffective C++にずばり書かれてる。
ちなみに、Effective C++の著者であるメイヤーは別の書物、
Effective STLの中でそういう連中とは距離を取れと書いている。
まさに>>507の予言どおりだ。
541デフォルトの名無しさん:2009/05/27(水) 12:26:20
ところで、メンバ変数をpublicにおく場合ももちろんある。
議論の冒頭、>>499はちゃんとそういう例外事項があることを認めている。
C++ Coding Standardsの第41項でも例外事項を設けているし、
setとgetの功罪(設計の過ち)についても言及している。

だから、「原理主義」でくくるのは議論の前提を無視している。
542デフォルトの名無しさん:2009/05/27(水) 12:36:27
C++ Coding StandardsはC++関係の本の中でも厚さが特に薄い本だが
内容は濃いな
543デフォルトの名無しさん:2009/05/27(水) 12:54:51
wikipediaのメソッドの記事にアクセサ論争って項目があるんだな
やっぱ昔から争ってる内容なのか
544デフォルトの名無しさん:2009/05/27(水) 13:34:11
boost::arrayはpublicにメンバ変数を置いてるけどなぁ・・・。
これもだめなのか?
545デフォルトの名無しさん:2009/05/27(水) 15:18:29
安全性を重視するか、高速性を重視するかは、設計者に委ねられてる
どっちが正解とかいうものではない
546デフォルトの名無しさん:2009/05/27(水) 15:31:38
ときどき「高速化するため」といって安全性をスポイルすることを正当化する人間が出てくるが
そういう人間もCoding Standardsを読むべきだな。
高速化が正当化されるには「時期」があることが説明されている。
アジャイルプラクティスとかもあわせて読んでおきたい。
547デフォルトの名無しさん:2009/05/27(水) 15:59:17
性的な意味で
548デフォルトの名無しさん:2009/05/27(水) 18:00:17
>>544
PODにするためだから仕方ない
549デフォルトの名無しさん:2009/05/27(水) 22:36:05
>>545
だから詳しく知らないなら断言するなよ。

getter/setterの速度がどうとか言ってる奴は
議論に参加する資格すらないから。
550デフォルトの名無しさん:2009/05/28(木) 00:07:33
なんじゃこりゃ。
>>485の質問からなんでこんな流れになるのかさっぱりわからん。
ここは聞かれてもいない知識をひけらかす似非回答者たちのオナニー相談室ですか?
551デフォルトの名無しさん:2009/05/28(木) 00:07:56
はいそうです
552デフォルトの名無しさん:2009/05/28(木) 00:25:57
>>550
申し訳ありません。
ここは質問に淡々と答えるだけの
ボランティアたちによる慈善スレでした。
以後気をつけます。


でいいですか?
553デフォルトの名無しさん:2009/05/28(木) 00:31:45
結局 >>485 に対する解答が1つも見当たらないんだが…
そもそも質問には、public なんて単語すら全く出てきてないよ?

>とてもサイズの大きなメンバ変数があったとき、
>「そのメンバ変数のポインタを返すようなメンバ関数を作る」か、
>「そのメンバ変数のコピーを返すようなメンバ関数を作る」か、
>どちらがオブジェクト指向としてはよろしいのでしょうか?

結局どうすればいいのよこれ?俺も知りたいよ
554デフォルトの名無しさん:2009/05/28(木) 00:40:02
たぶん、オブジェクト指向の観点からは「どうでもいい」。
実際には実行速度とかconstnessとかあるだろうが、オブジェクト指向の問題ではないかと。
555デフォルトの名無しさん:2009/05/28(木) 00:50:44
え、まじでいいの?
質問者の書き方だと、その巨大なメンバ変数は外部からは readonly にしたいんだと思うけど、
ポインタを返すと write できちゃうってのはオブジェクト指向からすると問題なんじゃないの?
俺の理解不足なのか…すまない
556デフォルトの名無しさん:2009/05/28(木) 01:08:45
問題な事もあれば問題でない事もある。全てのパターンに付いて書いていたらきりがない。
その場その場で最も適当(若しくは、それなりに妥当)な方法を選ぶのがC++。
557デフォルトの名無しさん:2009/05/28(木) 01:12:23
なるほどね

オブジェクト指向的には値を返すべきだが、
実行速度が必要な場合などは、オブジェクト指向に捕らわれるよりも処理速度を優先させてもいい

的な答えだと思ってた。そうでもないのか。さんきゅー。
558デフォルトの名無しさん:2009/05/28(木) 01:19:01
以後、大きなサイズのメンバ変数を持っているクラスをA、メンバ変数をaとする。
1. 本当にaを外部に晒す必要があるのかよく考える。
2. Aに処理を任せられないかよく考える。
3. Aの名前を変えてみて、やっぱりAに任せられないかよく考える。
4. aの要素をすべて晒す必要があるのかよく考える。

それでもだめなら、

返却するメンバ変数も安全に作られているなら、
constのポインタか参照を返すようにすればそれで十分。
呼ばれるたびに新たなオブジェクトの生成が必要なら躊躇せずコピーする。

悪意あるプログラムから保護する必要がある場合も躊躇せずコピーするが、
たいていはそれだけでは不十分だと思われ。


90点回答だ。おまいらひれ伏せ。
異論はオカマ言葉で行うこと。
559デフォルトの名無しさん:2009/05/28(木) 01:23:50
>>558
あたしの身体はひれ伏してるのに、あたしの息子が……どうしてくれんのよ! もう!
560デフォルトの名無しさん:2009/05/28(木) 07:46:40
>>553
>>486が答えだろ
それ以降は雑談
561デフォルトの名無しさん:2009/05/28(木) 09:38:38
参照するだけで値はいじらせない参照ができればいいんですよね
イテレータ的なものを使うという案は出ていないようですが
この方法はそれほどスマートな解決策ではないということでしょうか
562デフォルトの名無しさん:2009/05/28(木) 09:40:03
えっと、参照するだけで値をいじらせないなら、const参照を使えばいいわけだが。
563デフォルトの名無しさん:2009/05/28(木) 09:41:42
>>485って、例えば
class Person{
std::string name_;
public:
std::string *name() const { return &name_;} //A
std::string name() const { return name_;} //B
const std::string &name() const { return name_;} //C
const std::string *name() const { return &name_;} //D
};
みたいなのでAにするかBにするかってことだよね。
「とてもサイズの大きな」ってのが曖昧だけど、つまりコピーにコストがかか
るものってことだろう。
つまり回答は>>490だな(C,D)。
もちろんクラスやメンバの意味が変われば>>486もあるだろうけど、頭ごなしに
「問題外」というのは何か勘違いや思い込みがあるのだろう。
564563:2009/05/28(木) 09:43:56
ああ、constを打つクセが……
- std::string *name() const { return &name_;} //A
+ std::string *name() { return &name_;} //A
565デフォルトの名無しさん:2009/05/28(木) 11:37:19
>>563
そうかな
俺も
「データメンバAがあったとき、それを扱うメンバ関数Bはどう作ればオブジェクト指向っぽいでしょうか」
という質問はおかしいと思う

nameの例はあくまでnameがあってこそのname_でしょ?
566デフォルトの名無しさん:2009/05/28(木) 11:42:58
nameっていっぱい書くとなめなめみたいでいやだよね
567デフォルトの名無しさん:2009/05/28(木) 12:22:56
なるほどね
「とてもサイズの大きな」ってのが、そもそもおかしいよな。
大きかろうが小さかろうが、オブジェクト指向な振る舞いは同じはず。
568デフォルトの名無しさん:2009/05/28(木) 15:32:14
実用上の振る舞いに問題が出るだろう。
569デフォルトの名無しさん:2009/05/28(木) 15:46:30
タイ米はたいて買ったのに
古米に違いが出たら
悲しいやね
570デフォルトの名無しさん:2009/05/28(木) 16:51:43
うん
571デフォルトの名無しさん:2009/05/28(木) 18:31:51
ふ、古米・・・
572デフォルトの名無しさん:2009/05/28(木) 21:12:43
(環境はcygwin) Blitz++のインストールエラーについて質問。
http://island.geocities.jp/v_no11/programing/Blitzplusplus.html のページに従ってBlitz++をインストールしようとしたんだけど、

cygwinの場合
"blitz-0.9"フォルダで以下を実行
$ ./configure
$ make install

の最後の行のmake install をコマンドしたら、
延々インストール文流したあとにエラー吐いて止まるのよ。
で、最後のエラー文をググったら、Blitz++のメールサポートページ
http://www.oonumerics.org/MailArchives/blitz-support/2002/12/0599.php
にたどり着いてどうやら俺と同じエラーみたいなんだけど、
回答者は「gccのバージョン古いんじゃねーのー?」みたいなことしか答えてない。

誰か分かるひといたら助けてくれ
573デフォルトの名無しさん:2009/05/28(木) 22:24:39
cygwinのgccは3.45だっけ?
後何カ所止まるか想像もできないのに
全部この板で聞いて解決するつもり?

無駄な努力はやめてgccバージョンあげとけ。
あと質問の仕方の問題点について20字以内で述べなさい。
574デフォルトの名無しさん:2009/05/29(金) 01:51:39
環境依存で標準C++に何の関係もない。スレ違い
575デフォルトの名無しさん:2009/05/29(金) 05:03:48
Effective C++を買おうと思うんだが、原著三版ってやつで大丈夫?
576デフォルトの名無しさん:2009/05/29(金) 05:50:52
>>575
俺はそれ買ってみた。
とても良かった。
577デフォルトの名無しさん:2009/05/29(金) 07:09:15
vsいれたほうがいいんちゃうんかと
578デフォルトの名無しさん:2009/05/29(金) 13:43:45
じゃあ原著vs三版買うよ
改訂2版とか言うのがあるから、どっちにしたらいいのか迷ったんだけど
発売日で比べりゃ一目瞭然だったわ
サンクス
579デフォルトの名無しさん:2009/05/29(金) 14:37:17
俺は両方買った

というか最初改訂2版しかなくて買ったら次本屋に行ったら
第3版があって俺涙目orz
580デフォルトの名無しさん:2009/05/29(金) 21:23:58
Visual C++ 入れたいんだけど、Express Editionてやつだと
インスコ先にDドラ指定してもCドラを800MBぐらい食うのよ(今Cドラは1.5GBぐらいしか空きない)
スリム版みたいなのってないんですかね
581デフォルトの名無しさん:2009/05/29(金) 21:59:08
ないよ
582デフォルトの名無しさん:2009/05/29(金) 22:00:41
ぽいね
583デフォルトの名無しさん:2009/05/29(金) 22:01:49
Cドライブを空けろ
584デフォルトの名無しさん:2009/05/29(金) 22:14:07
新しくプロジェクトを作った後ソースやヘッダファイルを丸々コピーしてフォルダに移した後、既成項目の追加をして同じものを作ったつもりなのですが

アプリケーション更生が正しくないためアプリケーションの開始に失敗しました
マニフェストファイルを参照してエラーの原因を調べてください

と出ます、何がおかしいのでしょうか?DXUTを使っています
585デフォルトの名無しさん:2009/05/29(金) 22:14:46
了解、といっても残り1GBからCCleanerかけてやっと1.5GBなんだよね・・
正直もう消すものないんだけどね 使ってない付属ソフトでも消そうかな・・・

答えてくれた人ありがとう!
586デフォルトの名無しさん:2009/05/29(金) 22:25:14
>>585
Dドライブには空きがあるのなら、
ジャンクションやシンボリックリンク使ってDドライブにファイルを移せばいい。
587デフォルトの名無しさん:2009/05/29(金) 23:20:46
>>586
ジャンクションやシンボリックリンクって
もしかしてXPだと無理? ググったらなんかVistaで使用可能とかでてきたんだけど
588デフォルトの名無しさん:2009/05/29(金) 23:37:05
マウントのことなら別にWindows 2000でも出来てたが。
589デフォルトの名無しさん:2009/05/29(金) 23:57:22
590デフォルトの名無しさん:2009/05/29(金) 23:59:50
00?
591デフォルトの名無しさん:2009/05/30(土) 00:11:10
>>587
たしかできるはずー
EeePC901で容量稼ぐためにがんばったことがあった
592デフォルトの名無しさん:2009/05/30(土) 00:57:10
今、フリーのBCCでWindowsのコンソールのプログラム書いてたんだが、
アラインメント関係がわからない。
とりあえず、現状を書くとある大きい処理がmain関数中に埋まってたんだが、
やたら遅いから(まぁ、処理量もあるんだが)なんとなく関数化してソースの先頭に
移動させたら早くなって、アラインメントが原因だと思うんだ。

で、ものとしては
for(i = 0; i<32*32*32; i++)for(i2 = 0; i2<32*32*32; i2++);
だけなんだが、原因は何だろう?
(関数の位置なのか、変数の位置なのか。
アラインメントがどのように影響するか分からないので、
どの辺に注意したらいいかおしえてほしい)

へたくそな文章でごめんなさい。。。分かる人お願いします。
593デフォルトの名無しさん:2009/05/30(土) 01:26:05
本当にアラインメントなのか?
map出力して確かめてみたらどうよ(bcc32なら-M)
594デフォルトの名無しさん:2009/05/30(土) 01:49:07
>関数化してソースの先頭に
>移動させたら

レジスタ割付されただけじゃねーの
595デフォルトの名無しさん:2009/05/30(土) 03:11:59
このスレに書くべき話題かどうか分からないのだが、static_castってかなり誤解を受けてない?
俺もいくつかの入門向けサイトを見て「暗黙の変換を明示的に書くというだけの意味しかないのかな?」
と勘違いしていたが、実際には暗黙の変換が認められないいくつかのケースでもstatic_castができる。
このことってどれくらい知られてるんだろ。
596デフォルトの名無しさん:2009/05/30(土) 03:20:57
そうかな?俺はdynamic⇔staticで対称になってて
static_castはコンパイル時にキャストに問題がないか判断するもの、って覚えてたが

むしろ「暗黙の変換を明示的に書く」って解説してるサイトがあるのか?
それは問題がある解説に見えるなぁ
597デフォルトの名無しさん:2009/05/30(土) 03:24:33
自分は、static_castで可能なのは暗黙の変換とその逆向き、そしてユーザ定義変換と覚えていた。
598595:2009/05/30(土) 03:25:48
うーん、改めて見てみると、俺が初心者時代に変な思い込みしただけかもしれん。まあいいや。
599デフォルトの名無しさん:2009/05/30(土) 08:16:34
(なんかVC++から派生してC++の話と離れてきてる感じですいません・・・)
ttp://www.forest.impress.co.jp/article/2008/12/11/linkshellext.html ここによると、
>また、本ソフトは“ジャンクション”や“ハードリンク”なども作成可能。
>Windows Vistaでは多くの場合、シンボリックリンク以外を利用する必要はないが、
>Windows XP以下のバージョンのWindowsではシンボリックリンクが利用できないので、
>これらで代用しよう。
ってあるからシンボリックリンクはだめだけどジャンクションはいいみたいです

で、つまりCドラのファイルをDドラに移して、CドラにはDドラの移転先へのリンクだけ残しておけばいい
みたいな感じでいいんでしょうかね?

600デフォルトの名無しさん:2009/05/30(土) 09:47:49
std::vector<double> a;
std::vector<double> b = a;

この場合って、
コピーコンストラクタが呼ばれるのか、代入演算子が呼ばれるのか
コンパイラによって違うんだっけ?

どこかに書いてあった気がするんだが忘れてしまった。
601デフォルトの名無しさん:2009/05/30(土) 10:01:08
>>600
必ずコピーコンストラクタ。
602デフォルトの名無しさん:2009/05/30(土) 10:01:48
const_cast…cv修飾子を除去するのに使う。
reinterpret_cast…ポインタと整数型の変換に使う。
dynamic_cast…略。滅多に使わず事足りる。
static_cast…以上3つ以外

っていう認識でいるわ。
603デフォルトの名無しさん:2009/05/30(土) 10:04:10
>>600
カンチガイしているな

std::vector<double> a;//デフォルトコンストラクタ
std::vector<double> b = a;//コピーコンストラクタ
これらは「新しいオブジェクトを作る(construct)」なのだから
呼ばれるのは両方ともconstructor。
そして呼ばれるのは当然
前者はデフォルトコンストラクタ、後者はコピーコンストラクタ。

一方、
std::vector<double> x;//デフォルトコンストラクタ
このとき
x=b;
としたら、これは新しいオブジェクトを作るわけではないのだから
代入演算子operator =
が呼ばれる。
604デフォルトの名無しさん:2009/05/30(土) 10:15:58
>>601,603
ありがと!
605デフォルトの名無しさん:2009/05/30(土) 15:07:01
>>602
君はキャストしない方がいい。いつか死ぬ。
606デフォルトの名無しさん:2009/05/30(土) 15:15:03
>>605
どこが間違い?
607デフォルトの名無しさん:2009/05/30(土) 15:27:56
>>606
>>605ではないが、禿本のキャストに関する部分を読んでこい。
608デフォルトの名無しさん:2009/05/30(土) 15:40:16
>>607
禿本持ってないが、今度勉強してみるわ。

んで
>>605さん、>>602のどこが間違い?
609デフォルトの名無しさん:2009/05/30(土) 15:49:27
dynamic_castを多用するようになってきたら設計ミスを疑った方がいい。
610デフォルトの名無しさん:2009/05/30(土) 15:53:01
俺はクロスキャストの時だけdynamic_castを使っているけどな
611デフォルトの名無しさん:2009/05/30(土) 15:54:56
やむを得ない場合もあるけど、クロスキャストを多用するのも以下略
612デフォルトの名無しさん:2009/05/30(土) 15:58:07
クロスキャストは仮想関数では解決できないだろ
613デフォルトの名無しさん:2009/05/30(土) 15:59:31
そういう状況が多数生まれる時点で糞設計ってことを言いたかったんだけど。
614デフォルトの名無しさん:2009/05/30(土) 16:04:06
誰も「多数」とは言ってないわけだが
615デフォルトの名無しさん:2009/05/30(土) 16:07:31
>>614
>そういう状況が多数生まれる
の多数ってのは
>クロスキャストを多用する
の意味なんじゃないの?
なんで分からないの?w
616デフォルトの名無しさん:2009/05/30(土) 16:22:24
全くの初心者でお聞きしたいんですが、C++の講義ではTurboCというソフトを使って講義が進められるのですが
自宅のPCで同じことをするにはどういったソフトを使えば良いのでしょうか?
講義も全くわからずコンパイルという意味も全くわからずソフトを探すこともままなりません。どうかご教授ください。
617デフォルトの名無しさん:2009/05/30(土) 16:22:51
誰もクロスキャストを「多用する」とは言ってないわけだが
618デフォルトの名無しさん:2009/05/30(土) 16:26:17
>>617
>>612と同一人物?
そうだとしたら、>>612は誰に対するレス?
619デフォルトの名無しさん:2009/05/30(土) 16:27:30
何一人でエキサイトしてんの?
620デフォルトの名無しさん:2009/05/30(土) 16:30:20
>>619
お前は誰に対するレス?
安価つけてくれ、分からないから。
621デフォルトの名無しさん:2009/05/30(土) 16:32:15
>>620
断る
それ位自分で見抜け
622デフォルトの名無しさん:2009/05/30(土) 16:34:06
>>621
いや、それを明らかにしておかないと、
俺が論破してもはぐらかされるだろ。

そういうヤツが多すぎるから、はっきりさせないと不毛な書き込みになる。
623デフォルトの名無しさん:2009/05/30(土) 16:34:32
初めから不毛だと気づいてないのかこの馬鹿は
624デフォルトの名無しさん:2009/05/30(土) 16:36:34
2chで議論すること自体不毛だよな。
625デフォルトの名無しさん:2009/05/30(土) 16:41:11
まあせめてID付きの板でやるとか、コテハン付けるとかね。
626デフォルトの名無しさん:2009/05/30(土) 16:44:20
>>622
顔真っ赤
627デフォルトの名無しさん:2009/05/30(土) 16:47:07
>>626
鏡見て言ってるんだよね?
628デフォルトの名無しさん:2009/05/30(土) 17:02:09
鏡?ディスプレイで十分なのに鏡?なぜに?
629デフォルトの名無しさん:2009/05/30(土) 17:02:51
dynamic_castよりconst_castやreinterpret_castの方が多用したらまずいと思うんだけどどうだろうか
const_castなんかいまだに使いどこがわからん
630デフォルトの名無しさん:2009/05/30(土) 17:08:12
const_castはsetの要素を変更するのに使う
631デフォルトの名無しさん:2009/05/30(土) 17:09:15
>>630
そりゃまずいんじゃね?
木構造が壊れそうだが
632デフォルトの名無しさん:2009/05/30(土) 17:18:40
>>629
const_castを使う主なケースは、糞なCのライブラリ関数の引数に
constな変数を渡すときだな。例を挙げるとこんな感じ。

void stupid_func(char *filename); // prototype

void Foo::some_method(const std::string& filename)
{
stupid_func(const_cast<char*>(filename.c_str()));
}
633デフォルトの名無しさん:2009/05/30(土) 17:22:24
>>631
もちろん比較に影響及ぼすような変更はダメだぞ
構造体とかを入れたsetで、メンバの一つをキーに使ってるような場合があるだろう
そういう時にキー以外のメンバを変更するために使う
634デフォルトの名無しさん:2009/05/30(土) 17:30:54
>>632
なるほど、ライブラリに渡すときなんかに使うのか
いくら糞でもライブラリ側を修正するわけにいかないもんな
635デフォルトの名無しさん:2009/05/30(土) 17:55:27
volatile、組み込みでは見かけるがそれ以外では見かけたことがないんだが
おまいらはvolatileってどんな時(除く組み込み用途)使っている?
あと、const_castでvolatileを取るとる時ってどんな時?
636デフォルトの名無しさん:2009/05/30(土) 17:55:44
>>633
俺はそういうのはmutableでやるなぁ。
const_castでやると、keyも含めて全て変更可能な「状態」になってしまうし。
637デフォルトの名無しさん:2009/05/30(土) 18:09:49
>>583
aliceとかいう名前の開発ツールがたくさん入ってるから_
638デフォルトの名無しさん:2009/05/30(土) 18:27:09
>>635
デバイスドライバを書く時には当然使う必要あるよね。

あとは、インラインアセンブリでローカル変数を上書きする時とか。
こんなことめったにやらないが。
639デフォルトの名無しさん:2009/05/30(土) 18:48:24
>>636
mutableにすると、本当にキー以外もconstにしたいときに困るだろう
あくまでsetに入れたときの制約であって、そのためにmutableにするのは乱暴すぎる
640デフォルトの名無しさん:2009/05/30(土) 19:11:35
キーがあるようなのはmapを使うなぁ
setの要素を変更とかやったことないな
今度やってみるか
641デフォルトの名無しさん:2009/05/30(土) 21:11:30
>>635
VC++ではマルチスレッド対策の効果を独自に付加している。
http://msdn.microsoft.com/en-us/library/12a04hfd.aspx
Unixだとマルチスレッドでvolatileなんて使うなボケらしいが。

const_castで外したくなる状況は分からない。
642デフォルトの名無しさん:2009/05/30(土) 22:40:15
誰も答えてやらない>>616のために
Visual C++ Express Editionでぐぐれ
643デフォルトの名無しさん:2009/05/30(土) 22:44:10
Visual C++ Express Editionを知った後にTurbo Cを使うなんて、、、地獄だ。。
644デフォルトの名無しさん:2009/05/30(土) 22:45:14
>>638, >>641
どうも、ほとんどアプリ系じゃ使わんということですな

>>641 の例じゃ普通はmutexやクリティカルセクション使うんじゃないの
それでvolatileを使うメリットがよく分らん,orz. コードが簡単になるがメリット?
645デフォルトの名無しさん:2009/05/30(土) 23:24:24
Effective C++でconst_castはoperator[]の定義で使うことがあるみたいに書いてあったよね?
ttp://ritaz.blog64.fc2.com/blog-entry-66.html
より引用。

class sample
{
public:
...;
const char& operator[](unsigned int position) const
{
...;
return dat[position];
}
char& operator[](unsigned int position)
{
return const_cast<char&>(static_cast<const sample&>(*this)[position]);
}
...;
};
646デフォルトの名無しさん:2009/05/30(土) 23:32:43
>>645
blogにも書いてあるが、やりすぎな工夫の一例だな
647デフォルトの名無しさん:2009/05/30(土) 23:44:12
>>644
どちらかというと、そういう排他制御の仕組みを自分で作るときに使う。

例えば下のコードをコンパイラが最適化した結果、
ロック確保する前や解放した後にhogeへ読み書きするコードが生成されたらシャレにならない。
MS仕様では、volatileなデータに読み書きするとそこを境界として、それより前後に読み書き処理が
ずらされないように最適化を抑えると言っている。

void f(hoge_t* hoge) //hogeを使うには排他制御でロックが必要とする
{
// ...
ロック確保

hogeを使う

ロック解放
// ...
}
648デフォルトの名無しさん:2009/05/30(土) 23:48:16
>ロック確保する前や解放した後にhogeへ読み書きするコードが生成されたらシャレにならない。

意味が分からん。

最適化によって、「hogeを使う」に相当するコードが、「ロック確保」の前や「ロック解放」の後に配置されたらシャレにならないってこと?
649デフォルトの名無しさん:2009/05/30(土) 23:50:52
>>648
ああ、ごめん。そういうこと。
携帯から打つのが面倒でいろいろ略した。
650デフォルトの名無しさん:2009/05/31(日) 00:34:14
>>642
ありがとうございます。探してみます。
651デフォルトの名無しさん:2009/05/31(日) 00:44:58
>>645
それ第何版の何節に書いてあるの?
652デフォルトの名無しさん:2009/05/31(日) 01:30:20
>>644
そういう用途にも使えるってだけでWindowsでもマルチスレッドでvolatileなんて使わない
mutexなりクリティカルセクションなりInterlocked-系関数なり使えばそこでフェンス張られるし
(Interlocked-系関数でvolatile使われてるけどね。間接的には使うことになるのかな)

やっぱり組み込みとかドライバ以外で使うことはないと思うな
653デフォルトの名無しさん:2009/05/31(日) 17:24:40
>>647, >>652
どうも、どうも

>>647
>そういう排他制御の仕組みを自分で作るときに使う
ずばり、自分でそういう仕組みは作ることないです
654645:2009/05/31(日) 20:04:50
>>651
忘れた。
原著第3版に書いてあった。
確か、最初の方の章に。
655デフォルトの名無しさん:2009/05/31(日) 21:20:51
改訂2版にはどこにも書いていないんだが、
第3版には本当に書いてあるのか?


第4版まであと2年はかかりそうな気がするし、
第3版買ってくるか・・・
656645:2009/05/31(日) 21:28:28
>>655
第3版には本当に書いてある。
厳密に同じコードかどうが覚えてないが、
const版をnon-const版にて呼び出してconst_castでconst属性を外す
という方式であることは本当。
俺もそんなことして良いの!?と思ったから信じられなくても無理はない。
657645:2009/05/31(日) 21:31:01
わざわざ引っ張ってきて確かめみた。
原著第3版(日本語翻訳されているもの)で
15ページから始まる項目にある。
658デフォルトの名無しさん:2009/05/31(日) 21:48:18
2版の21項「使えるときは、必ずconstを使おう」に
対応するんじゃないかなと思うけど、
そこではmutableをサポートしてないコンパイラのための苦肉の策として
「みっともないけど」と前置きした上でconst外しをしている。

これのことじゃないよな?
659デフォルトの名無しさん:2009/05/31(日) 22:06:17
>>658
じゃないってば。
少しは俺を信じろ(笑)

他の人も誰か証言してくれ。
660デフォルトの名無しさん:2009/05/31(日) 22:08:18
ようやっと見つけたが、
さっぱり読めなくて意図が分からん。
http://books.google.co.jp/books?id=d-2Im_Ox7qMC&pg=PA24&as_brr=3&source=gbs_toc_r&cad=0_0#PPA41,M1

俺の英語力も落ちたな・・・
661デフォルトの名無しさん:2009/05/31(日) 22:10:32
ああ、これって王家の血を引く者にしか読めないよ
662デフォルトの名無しさん:2009/05/31(日) 22:10:40
>>659
すまんwww
明日買ってくる。
663645:2009/05/31(日) 22:12:21
>>660
メンバ関数foo()のconst版とnon-const版の定義が
同じようなものになることは多々あるじゃない。
同じような定義を繰り返し書きたくない、そんなあなたにconst_cast

って言うような主旨。
const版をうまく定義することで、non-const版の定義は
それを呼び出してconst性を除去するだけ
で良くなる。
664デフォルトの名無しさん:2009/05/31(日) 22:13:17
>>661
俺読めたw
・・・そろそろ天の啓示が来る頃だろうか。
665デフォルトの名無しさん:2009/05/31(日) 22:14:26
>>664
もしかして、お兄様なの!
こんなところで巡り合えるなんて。。
666デフォルトの名無しさん:2009/05/31(日) 22:16:24
おまえか
しょせん、暇をもてあました神々の遊び
667デフォルトの名無しさん:2009/05/31(日) 22:20:04
理解した。解説thx

感覚的にconst側で非constのコードを
再利用したくなりそうなものだけど
それも理由があるのかな。

とりあえず第3版買ってくるよ。
生き別れた妹はいなかった気がするし。
668645:2009/05/31(日) 22:23:19
>>667
俺もそう思ったが、
理由としては
const側で非constメンバ関数を呼び出すというのはダメ
ってことらしい。
たとえ実際にはオブジェクトが変更されないとしても。

まあ買ってくる価値はあるかと。
何てったって名著だし、無駄な出費ではないと思う。
669デフォルトの名無しさん:2009/05/31(日) 22:41:23
#define UNICODE
#define _UNICODE
で定義されたソースコードがあるとします。

それを
#define UNICODE
#define _UNICODE
と定義してはエラーになってしまう、つまりANSI版のソースに混ぜて使いたい場合どの
ようにすればいいのでしょうか?

たとえば


int WINAPI WinMain(…){
    …(ANSIソースコード)
   sub();
}

int sub(){
#define UNICODE
#define _UNICODE
   …(UNICODEソースコード)
}


みたいなことはできるでしょうか?
670デフォルトの名無しさん:2009/05/31(日) 22:49:30
できます。
671デフォルトの名無しさん:2009/05/31(日) 22:52:12
いまいち質問内容がよく分からんが、

#define UNICODE
#define _UNICODE
したあと
#undef UNICODE
#undef _UNICODE
すればdefineは消える。

でもWIN32なら、
UNICODE版、ANSI版両方そろってるはずだが。
672デフォルトの名無しさん:2009/05/31(日) 23:25:45
CreateWindow("aaa",....
とかやってるんだろ
673デフォルトの名無しさん:2009/05/31(日) 23:59:32
>>670 >>671
いやできなかった
結論からいうと
原理からいうとその方法でできるのは確かなんだが
UNICODEと_UNICODEは最初の最初で定義しておかなければならならないみたいだ
先にwindows.hとか読み込まれてるからその関係で動作がおかしくなる

>>672
アホすぎ



てか解決法をいうと単純にソースファイルをわければ解決できる
最初からやればよかったけど
674デフォルトの名無しさん:2009/06/01(月) 00:14:01
本筋とは全く関係ないが、>>669を見ると_tWinMainにしろと言いたくなる。
675デフォルトの名無しさん:2009/06/01(月) 01:15:41
もうこれから書くコードは全部_UNICODEでいいかもと思ってしまうがな。
676デフォルトの名無しさん:2009/06/01(月) 04:06:41
なに、いいってことよ┏( ^ω^)┛
677デフォルトの名無しさん:2009/06/01(月) 14:32:49
下の様な感じで合成関数を作ろうと思ったのですが、
error C2678: 二項演算子 '*' : 型 'composite_impl<result_type_,arg_type_>' の左オペランドを扱う演算子が見つかりません
とエラーが出ます。どうやって回避すればいいのでしょうか?
678デフォルトの名無しさん:2009/06/01(月) 14:33:55
struct composite_type{};
template<typename result_type_, typename arg_type_>
struct composite_impl{
typedef result_type_ result_type; typedef arg_type_ arg_type; typedef result_type (*fn_type)(arg_type);
static fn_type &fn_holder(){ static fn_type fn; return fn; }
result_type operator ()(arg_type a) const{ return (fn_holder())(a); }
};
template<typename result_type_a_, typename result_type_b_, typename arg_type_b_>
struct composite_impl<result_type_a_, composite_impl<result_type_b_, arg_type_b_> >{
typedef result_type_a_ result_type; typedef arg_type_b_ arg_type; typedef result_type (*fn_type)(arg_type);
static fn_type &fn_holder(){ static fn_type fn; return fn; }
result_type operator ()(arg_type a) const{ return (fn_holder())(composite_impl<result_type_b, arg_type_b_>()(a)); }
};
template<typename result_type, typename arg_type>
inline composite_impl<result_type, arg_type> operator *(composite_type, result_type (*fn)(arg_type)){
composite_impl<result_type, arg_type> a; a.fn_holder() = fn; return a;
}
template<typename result_type_a, typename result_type_b, typename arg_type_b>
inline composite_impl<result_type_a, composite_impl<result_type_b, arg_type_b> > operator *(composite_impl<result_type_a, result_type_b> a, result_type_b (*fn)(arg_type_b)){
composite_impl<result_type_a, composite_impl<result_type_b, arg_type_b> > a; a.fn_holder() = fn; return a;
}
composite_type composite;
#include <iostream>
#include <cstring>
int fn_a(int a){ return a * a; }
char *fn_b(int a){ static char str[0xFF]; std::sprintf(str, "%d", a + 1); return str; }
int main(){ std::cout << (composite * fn_a * fn_b)(2) << std::endl; return 0; }
679デフォルトの名無しさん:2009/06/01(月) 14:42:39
>>668
> const側で非constメンバ関数を呼び出すというのはダメ
> ってことらしい。
これって、単純にconstメンバ関数内で非constメンバ関数を呼び出すと
コンパイルが通らないって話。
680デフォルトの名無しさん:2009/06/01(月) 15:00:03
>>679
const_castで*thisからconstを外すって話だよ。
681デフォルトの名無しさん:2009/06/01(月) 15:12:45
>>680
あーそういうことね。
でも*thisのconst外しが駄目なのも当たり前の話だな。
682デフォルトの名無しさん:2009/06/01(月) 20:59:19
*thisのconstは外してないぜ
むしろconstメンバ関数を呼ぶために*thisにconstを付けてる
外してるのは戻り値のconst
683デフォルトの名無しさん:2009/06/01(月) 21:04:09
>>682


>>667-668
>>679-681
を読みかえしくれ。

684デフォルトの名無しさん:2009/06/01(月) 21:13:26
???
>>645のことだろ?
static_cast<const sample&>(*this)は明らかに*thisにconstを付けてる
何か間違ってるのか
685デフォルトの名無しさん:2009/06/01(月) 21:15:12
>>684
> >>645のことだろ?
否。
>>667-668の事。
それに対し>>679-681というやりとりが行われている。
皆は>>645は理解している。
686デフォルトの名無しさん:2009/06/01(月) 21:18:48
なるほど理解した
687デフォルトの名無しさん:2009/06/01(月) 22:34:32
いろいろあるよ。
http://www.sengoku.co.jp/CategoryIndex/wire.htm

個人的には極細より線と鈴メッキ銅線が好きだけど (どうせ趣味だし)、
信頼性からジュンフロン線使う人のほうが多い。
このシリーズのより線はストリッパー必須。

ジュンフロンは苦手です。ええ。
688デフォルトの名無しさん:2009/06/01(月) 22:36:18
ご、誤爆・・・
689デフォルトの名無しさん:2009/06/01(月) 22:43:04
どんまい、
というかハードとソフト両方いけるとかうらやましい
690デフォルトの名無しさん:2009/06/01(月) 22:45:09
>>687
全然 なんだかわからないwww
すごいな。
691デフォルトの名無しさん:2009/06/02(火) 01:02:51
とりあえずイミフだからストリッパーってあたりに反応しとこうぜ
692デフォルトの名無しさん:2009/06/02(火) 01:44:25
ストリッパーくらい分かるだろ
線の被覆を剥ぐための工具だろ
693デフォルトの名無しさん:2009/06/02(火) 02:19:34
struct A{A();virtual void fun() = 0;};
struct B:A{B();fun();};
struct C{C(A&b); C problem(A&b);};

C c(B());
c.problem(B()); // no-match function になるのは何故?

C::problem(一時オブジェクト参照)を弾くならコンストラクタでも弾くべきだと思うんだけど
694デフォルトの名無しさん:2009/06/02(火) 02:57:23
>>692
しらんがな(´・ω・`)
695デフォルトの名無しさん:2009/06/02(火) 03:51:45
ドラクエなどで登場する戦士や魔法使いを意味するFighterクラスと Mageクラスがあったとして、
そのクラスのインスタンスが持つHPやMP,攻撃力などのステータス一覧を表示する関数を作るとき、
クラス自信にその関数を持たせるのか、あるいはクラスとは関係のない部分で作るのか、どちらがいいんでしょう?
クラス設計の考え方がまったくわかりません・・。
696デフォルトの名無しさん:2009/06/02(火) 06:17:21
>>695
その場合はカプセル化を優先する。

まず、HPやMP,攻撃力などのステータスを格納する変数(intだったりstd::size_tだったりするだろう)のアクセス指定子がどう宣言されているかによって考えを分ける。
1.
もしprivateで宣言されていて、そのステータスをpublicなメンバ関数h_point()で取得するような仕組みにしている場合(むろんそれが望ましい)は、「クラスとは関係のない部分で作る」が正解。
つまり別の関数show_status(〜)を作り、〜の部分にキャラクタのインスタンスを渡すようにする。
2.
もしpublicで宣言されているならば、「クラス自身にその関数を持たせる」ないし「friend指定して外部関数を作る」が正解。しかしステータスを格納する変数がpublic指定されていること自体、そもそも望ましくないことだが。
697デフォルトの名無しさん:2009/06/02(火) 06:23:39
>>693
private継承しているからだろ
698デフォルトの名無しさん:2009/06/02(火) 08:07:42
>>693
そのコンストラクタで本当に動くか試した?
699デフォルトの名無しさん:2009/06/02(火) 17:56:43
C c(B());

C c(B (*)());
という関数宣言に解釈される。
B b0;
C c(b0);
c.problem(b0);
とするとできましたが。
関数の引数のリファレンスの型にconstをつけて
"const B&b"、"const A&b"のようにすると
C c = C(B());
c.problem(B());
でもいけました。
なぜかは僕には分かりませんのでどなたか解説お願いします。
コンパイラはgcc4.2.1で確かめました。
700デフォルトの名無しさん:2009/06/02(火) 19:02:59
const参照型のインスタンスは、呼び出す側が値渡しと同じ感覚で扱えるように、
一次オブジェクトで初期化できることになっている。
701693:2009/06/02(火) 20:13:27
実コードはstruct Bにtemplate特殊化やらvirtualメンバやらなんやら絡んで魔窟状態で実は
C c(static_cacst<A&>(B())); に成ってますた。

>>699
C c((B())); でも逝けますね。
702デフォルトの名無しさん:2009/06/02(火) 21:44:52
>>701
Effective STL の第1章第6項「C++の最も奇妙な解析に注意しよう」に書かれてるね。
(この本自体はSTLの解説本だけど…)
でも、すべてのコンパイラで成功するとも書かれていない・・・おそろしや。
703デフォルトの名無しさん:2009/06/03(水) 17:16:04
#include <stdio.h>

void main(void)
{
char data[3465300]
int idata[3465300];
int KOTAE[3465300/2];
int data1[12032/2][300];
int idata1[300][300];
int i,j,id,a,b,No,day,LDAY,d;
char fnamein,fnameout;
FILE *fin,*fout;
#define LDAY 30 //月ごとに変える
//No=1→ステータス;No=2→交通量;No3=速度;No4=オキュパンシー
#define No 2
for(day=0;day<LDAY;day++){
d=day+1;
printf("%d/%d\n",d,LDAY);
sprintf(fnamein,"D:\\/torakan-Y/R_barashi/Ku0409/Ku0409%02d.dat",d);
sprintf(fnameout,"D:\\/torakan-Y/R_barashi/Ku04/Q_Ku0409%02d.txt",d);
fin = fopen(fnamein,"rb");
fread(&data,1,3465216,fin);
fclose(fin);
if((fout=fopen(fnameout,"w"))==NULL) printf("Cannot open output file\n");
704デフォルトの名無しさん:2009/06/03(水) 17:17:18
>>703
なんだこの凶悪なのはっ!!
705703:2009/06/03(水) 17:19:00
703のプログラムですが、コンパイルは通る一方で
出力される結果が同じ数字の繰り返しになってしまいます。

エラーの原因としては、以下の4行が怪しいと思っています。
詳しい方、よろしくお願いします。
sprintf(fnameout,"D:\\/torakan-Y/R_barashi/Ku04/Q_Ku0409%02d.txt",d);
fin = fopen(fnamein,"rb");
fread(&data,1,3465216,fin);
fclose(fin);
706デフォルトの名無しさん:2009/06/03(水) 17:23:44
>>705
あんたが勝手に”エラー”って呼んでいるものを,具体的に書き表してごらんよ
少なくとも”出力される結果が同じ数字の繰り返し”になることは具体的に書け
707デフォルトの名無しさん:2009/06/03(水) 17:29:33
変数宣言で嫌になるものは久しぶり…
708デフォルトの名無しさん:2009/06/03(水) 17:32:39
スレの住人の中におエスパー様はおられませんか?
709デフォルトの名無しさん:2009/06/03(水) 17:34:40
>>703
とりあえず変数を#defineで上書きしているのが分かった
710703:2009/06/03(水) 17:42:02
≫>705様
レスありがとうございます。
出力されたファイルを開くと
526855268552685といった感じで同じ数列がただ繰り返されたファイルが
出力されます。

このプログラムはもともと、膨大なデータの中から
一部分を抽出するプログラムとなっています。
また、その莫大なデータにはそのような数列は見られないので
勝手にエラーと判定してしまいました。

>709様
ありがとうございます。
さっそく そこを修正したいと思います。
711デフォルトの名無しさん:2009/06/03(水) 17:52:30
>>710
かんじんのファイルに出力している部分が・・・ねぇwwwwwwさすがにESPじゃない俺にはむり
712703:2009/06/03(水) 17:57:36
for(i=0;i<3465216;i++){
idata[i]=int(data[i]);
if(idata[i]<0){
idata[i]=256+idata[i];
}
}
id=0;
for(i=0;i<3465216;i=i+2){
a=idata[i]/16;
b=idata[i]%16;
KOTAE[id]=a*16*16*16+b*16*16+idata[i+1];
id=id+1;
}

id=0;
for(j=0;j<288;j++){
for(i=0;i<12032/2;i++){
data1[i][j]=KOTAE[id];
id=id+1;
}
}
713703:2009/06/03(水) 18:00:29

/*区間データの抜き出し*/
id=0;
//////6号三郷JCT‐江戸橋JCT間////////////
for(j=0;j<288;j++){
for(i=0;i<17;i++){
idata1[id][j]=data1[4*i+(8+4*501+No-1)][j];
id=id+1;
}
id=0;
}

for(j=0;j<288;j++){
for(i=0;i<2;i++){
idata1[id+17][j]=data1[4*i+(8+4*772+No-1)][j];
id=id+1;
}
id=0;
}

714703:2009/06/03(水) 18:02:01
for(j=0;j<288;j++){
for(i=0;i<15;i++){
idata1[id+19][j]=data1[4*i+(8+4*542+No-1)][j];
id=id+1;
}
id=0;
}

for(j=0;j<288;j++){
for(i=0;i<34;i++){
fprintf(fout,"%d",idata1[i][j]);
}
fprintf(fout,"\n");
}
}
}
715デフォルトの名無しさん:2009/06/03(水) 18:02:27
>>712
> for(j=0;j<288;j++){ 
> for(i=0;i<12032/2;i++){ 
この辺で悪意を感じた

あと,もし仮に名前を付け替えるのが許可されているなら,ぜひデータ構造と名前を変えるべきだとおもふ
716デフォルトの名無しさん:2009/06/03(水) 18:10:48
まずマジックナンバーが多過ぎるから定数で宣言して分かりやすい名前を付けるべき

それと、
>char fnamein,fnameout;
ここはファイル名格納するバッファじゃなかろうか
717703:2009/06/03(水) 18:11:01
>712

すいません。まったく悪意はないです。
もうしわけないです。

名前は変更できます。

718デフォルトの名無しさん:2009/06/03(水) 18:16:08
なげぇwww
codepad
ttp://codepad.org/
せめてここに貼るとかさあ。。
719デフォルトの名無しさん:2009/06/03(水) 18:19:07
そもそも何の目的で作られた何をするためのプログラムで
どうなれば成功なんだよ
そこが分からないのに何も答えられるわけがないだろ

どうせ宿題なんだろうけど
720703:2009/06/03(水) 18:26:59
>719様

説明不足ですいません。
トラカンデータといわれる交通量や平均速度といった
情報が網羅されているデータから
一部分を抽出して、自分たちが調べたい路線の
交通量を抜き取るプログラムです。

数列が同じ数字の繰り返しにならなければ、ほぼ成功だと思います。

宿題ではないです。申し訳ないです。

>718様
さっそく、張ってみようと思います。
721703:2009/06/03(水) 18:30:03
http://codepad.org/jC9g9phJ

さっそく貼ってみました。
722デフォルトの名無しさん:2009/06/03(水) 18:32:15
ふむふむ
ひどすぎて目眩がしてきた

一つ言えるのは、これはCであってC++ではないということだ
だからスレ違い
723デフォルトの名無しさん:2009/06/03(水) 18:32:56
と思ったらnew使ってるからC++かよ
なんだこれは
724デフォルトの名無しさん:2009/06/03(水) 18:52:09
読むのに時間かかりそうだ…
725デフォルトの名無しさん:2009/06/03(水) 19:03:32
管理番号とかファイルのパスとか
危険な香りのする文字列がたくさんあるけど大丈夫なのか
726デフォルトの名無しさん:2009/06/03(水) 19:09:39
>>703
とりあえず
fread(&data,1,3465216,fin);

fread(data,1,3465216,fin);
727デフォルトの名無しさん:2009/06/03(水) 19:12:43
プログラムに間違いらしきものはなし。
データ解析部分でデータの構造が合致していないような感じだが?
728703:2009/06/03(水) 19:18:54
>726様

あなたは神様です。
あなたのおかげで無事解決しました。

なんてお礼をいえばいいのかわかりません。
729デフォルトの名無しさん:2009/06/03(水) 20:18:52
すげえうれしくない感謝の言葉だなぁ
730デフォルトの名無しさん:2009/06/03(水) 20:22:20
You are God.
I solved the problem, thank you.
What it only has to say the reward is not understood.
731703:2009/06/03(水) 20:27:36
と思ったら、まだ解決していませんでした。
申し訳ないです。
732デフォルトの名無しさん:2009/06/03(水) 20:39:13
<stdexcept> と <exception> って、
どっちをインクルードするほうが望ましいの?
733デフォルトの名無しさん:2009/06/03(水) 20:41:32
<stdexcept>で定義されている例外を使いたければ<stdexcept>
734デフォルトの名無しさん:2009/06/03(水) 20:42:12
>>731
書き直してもいい?

要するにファイルの内容は unsigned short 型のデータが
ビッグエンディアンで 6016x288 個格納されているのを
data1 に代入すれば data も idata も KOTAE も必要ないよね
735デフォルトの名無しさん:2009/06/03(水) 20:53:56
>>703
社内で使ってる(であろう)コードをこんなところに晒して、
ただで済むと思ってるのか?
オープンソースじゃないだろうし、上司に知られたらやばいんじゃねーの。
736デフォルトの名無しさん:2009/06/03(水) 21:21:08
スタックオーバーフローエラーを直してくれた先輩には
もう見限られたのか?
737デフォルトの名無しさん:2009/06/03(水) 21:58:15
>>731
なにが解決してないの?
738デフォルトの名無しさん:2009/06/03(水) 22:40:43
ほんとプロが作るソースって
ゴミクズだよな。
どこもかわらねえなぁ。
739デフォルトの名無しさん:2009/06/03(水) 22:48:19
え?>>703の話なら、プロのコードじゃないっしょ。

社内でコンピュータにちょっと詳しい人(事務職とかバイトのお兄ちゃんとか)に
アホ課長が「エクセルで計算するのめんどいからお前プログラム書けよ」って
仕方なくしこったんじゃない?

どうみてもCで書いたコードを、その人がやめちゃって保守要員がいなくなったので
これまたその辺のちょっとコンピュータ詳しい奴にむりくりやらせてるってところでは。

すごいエスパー。昔、エスパドリューはエスパーが身につける特別な装備だと思っていたのを思い出した。
740デフォルトの名無しさん:2009/06/03(水) 23:49:15
ふと思ったんだが↓↓

C++では関数が返せる変数の型は1つだけである。
(その型と継承関係によってはその子クラスの型でも返せることもあるが。)
ところが、例外処理におけるthrowは関数から外へ任意の型の例外を投げることが可能である。
これをその関数の返り値(戻り値)とみなして
プログラミングをするという面白い技法が
この世に存在していてもおかしくないのではないか

と思ったのだが、誰か知っている人いない?
例外を使ったプログラミングの話をしている訳じゃ無くて
あくまでthrowによる例外を戻り値として利用するスタイルってことで。
741デフォルトの名無しさん:2009/06/03(水) 23:55:54
テンプレートクラスを使えば戻り値の型なんて自由自在ですよ。
無茶しないでください。
742デフォルトの名無しさん:2009/06/03(水) 23:57:22
そのアイデアに「catchされなければ呼出元へ伝播する」という例外の特徴も考慮した?
していないならboost::any返せばいいでしょという話だと思う。
743デフォルトの名無しさん:2009/06/03(水) 23:57:35
>>740
実用してる奴がいたら絶対に近づきたくないが
ネタとしてはおもしろそうだな。

はたして意味のあるプログラムを作ることができるのか・・・
744デフォルトの名無しさん:2009/06/04(木) 00:04:54
もしうまいことやったとしても、Schemeなんかの継続のきわめて限定的なまねごとになるのではと思う。
どういう形か想像もつかないが。
745デフォルトの名無しさん:2009/06/04(木) 00:10:33
継続ねえ。
じゃあお題は例外でC#で言うところのyield()を作る
でどうよ。
746デフォルトの名無しさん:2009/06/04(木) 00:17:20
_


さっそく自分で否定しちまった・・・
747デフォルトの名無しさん:2009/06/04(木) 00:39:24
>>740のは面白いな
何か可能性を感じる
748デフォルトの名無しさん:2009/06/04(木) 01:27:32
variantでいいじゃん
戻り値の型として使いたいものの集合がコンパイル時に決まっていないと
例外使う方法も結局何もできないわけだし
749デフォルトの名無しさん:2009/06/04(木) 02:00:23
変態プログラミングの可能性と聞いて
750703:2009/06/04(木) 02:02:54
>734様

先程、プログラミングを回してみた結果
無事解決しました。
727様のおっしゃるとおり
データ解析部分でデータの構造が合致してないことが
原因でした。
もし、お時間があるなら、書き直してくださったプログラムを
見せていただきたいです。
751デフォルトの名無しさん:2009/06/04(木) 02:36:54
>>740
そういうのはイベント駆動型とかいうやつじゃないか
752740:2009/06/04(木) 06:28:37
>>741
え?
どういうことだい?
よく分からないんだが。。。

みんなありがとう。
俺も絶対やらないと思うけど、
>そのアイデアに「catchされなければ呼出元へ伝播する」という例外の特徴も考慮した?
一応考えてる。
boost::anyやvariantは頭をよぎったが忘れることにした。

うーん、むずかしいよねぇ。
少なくとも俺はやらないけど、きっと誰かが何かすごいことを
やってくれるんじゃないかと思った。
753デフォルトの名無しさん:2009/06/04(木) 11:11:57
やらないのかよ
754デフォルトの名無しさん:2009/06/04(木) 11:52:00
>>752
c#でもやっていてください
とくにLINQ
755デフォルトの名無しさん:2009/06/04(木) 14:00:53
>>752
例外のキャッチってコストかかるんでパフォーマンス劣化が激しいと思うぞ
756デフォルトの名無しさん:2009/06/04(木) 14:02:25
アゲ
757732:2009/06/04(木) 17:05:22
>>733
ありがとう!
758デフォルトの名無しさん:2009/06/04(木) 17:20:46
>>740
むやみやたらにthrow使うのはgotoと大して変わらないので、
普通やらん。
やめとけ。
759デフォルトの名無しさん:2009/06/04(木) 17:51:57
普通に関数オブジェクトでも引数として渡せばいいだけやん。
760740:2009/06/04(木) 17:57:29
もちろん俺だって普通はやらんさ。

でもまあどこかの変態級のプログラマがうまくこれを生かして…(ry
761デフォルトの名無しさん:2009/06/04(木) 20:32:06
試しに
#define return assert(0)
して、throw以外で関数から出るのを禁止してプログラム書いてみたらいい
何かが見えてくるかもしれんぞ
762デフォルトの名無しさん:2009/06/04(木) 20:42:01
C++の関数を全部こう書き換える

retType func(/* ... */){
  /* ... */
  return foo;
}



function func(/* ... */) throw(retType){
  /* ... */
  throw foo;
}

そして
class function{private:function();~function();};
と定義すれば、めでたく例外指向プログラミング言語の出来上がり

使うのは遠慮します
763740:2009/06/04(木) 21:00:49
>>761-762
ありがとう。
うーん、なんとも気持ち悪い物が出来上がりそうだw
764デフォルトの名無しさん:2009/06/04(木) 23:10:07
三値論理の関数型言語?で似たような事が出来たような?
よくわからんが
765デフォルトの名無しさん:2009/06/04(木) 23:20:59
boost::any を使えば受け取る側は関数側から何が返ってくるか知らなくてもいいけど
例外の場合は、帰ってくる型が何であるかは知っておく必要があるよね?

間違ってるかしら・・・
766デフォルトの名無しさん:2009/06/04(木) 23:47:52
>>765
一応catch(...)で、何でも受けれる。
受けられるだけだが。

戻り値返しにない例外の機能として、
安全な中間すっとばしがある。

funcA() -> funcB() -> funcC() -> 例外発生
↑-----------------------------」

これを使えば、非常に柔軟な逆フロー制御が実現できる。
つまり、メインルーチンを例外のcatch()ブロックに書くのだ。
これを使って何が出来るかというと、それは次の人どうぞ。
767デフォルトの名無しさん:2009/06/05(金) 00:11:17
一方ロシアはgotoを使った。
768デフォルトの名無しさん:2009/06/05(金) 00:16:15
anyだろうと何だろうと型を知らないと何も出来ないから、
結局そのままどっかに転送するしかないよな
throw;で同じ事が出来そうな気はする
769デフォルトの名無しさん:2009/06/05(金) 00:19:15
VC9だと落ちるんだけどw
#include <iostream>
void fib(int n) {
  if (n < 2) { throw 1; }
  else {
    try { fib(n-1); } catch (int r1) {
      try { fib(n-2); } catch (int r2) {
        throw r1 + r2;
      }
    }
  }
}
int main() {
  try { fib(20); } catch (int ret) {
    std::cout << ret << std::endl;
  }
  return 0;
}
770デフォルトの名無しさん:2009/06/05(金) 00:21:40
あーそうだ、多重例外は未定義だったな

標準C++の範囲で例外指向プログラミングはできないようです
771デフォルトの名無しさん:2009/06/05(金) 00:29:57
うーん、
変態Chain Respinsibility?

void discover() {
 switch (random) {
 case 0:
  throw Chair;
 case 1:
  throw Human;
 case 2:
  throw Orange;
 case 3:
  throw Truth;
 }
}

void loop() {
 while (1) {
  Sitter(Killer(Eater(Philosopher(discover))));
 }
}

どうすんだこれ・・・
772デフォルトの名無しさん:2009/06/05(金) 00:31:46
綴りひでぇorz
773デフォルトの名無しさん:2009/06/05(金) 00:45:36
いいかんじに変態的だな
774デフォルトの名無しさん:2009/06/05(金) 02:23:18
775デフォルトの名無しさん:2009/06/05(金) 05:26:42
多重例外って何ですか?
アクティブな例外が2つ以上同時に発生することですか?
それともtry・catchブロックの中にtry・catchブロックがあることですか?
776デフォルトの名無しさん:2009/06/05(金) 09:32:40
例外ハンドラで例外が出ること
777デフォルトの名無しさん:2009/06/05(金) 11:12:55
テンプレートクラスで自身を返す場合、書き方としてどっちが正しいのでしょうか。
1も正しいなら今後1で書こうと思ってます。

template<class T> class X
{
public:
X &Func() // 1
X<T> &Func() // 2
{
return *this;
}
}
778デフォルトの名無しさん:2009/06/05(金) 11:33:33
C++を1から学習しようかと思うのですが、参考書は何がおすすめでしょうか?
visual C++を使おうかと思っているのですが。
分厚くてもよいので、一冊で応用まで深く学習出来るのはありませんかね?
779デフォルトの名無しさん:2009/06/05(金) 11:52:54
>>777
2、テンプレート引数を省略しないといけないのはコンストラクタだけ
780デフォルトの名無しさん:2009/06/05(金) 12:03:14
>>778
禿本を買っておけば間違いは無い
781デフォルトの名無しさん:2009/06/05(金) 13:44:02
>>780
禿本とは何ですか?
782デフォルトの名無しさん:2009/06/05(金) 13:53:12
softbank
783デフォルトの名無しさん:2009/06/05(金) 13:54:12
そういう時に真っ先に「C++ 禿本」で検索しない精神がよくわからん。
784デフォルトの名無しさん:2009/06/05(金) 14:47:44
検索したのですが、出てきませんでした。
ていうより、59件ヒットしてその全てがただ禿本とC++を含んでるやつのみで
何の略かも書いてありませんでした。
その本の正式名称がわかりません。
すいませんが、本の正式名称で書いていただけませんか?
785デフォルトの名無しさん:2009/06/05(金) 15:01:04
C++ 禿

でぐぐったら一番上におっさんの名前出てきたわw
786780:2009/06/05(金) 15:04:39
確かにC++ってググるときに引用符を付けないと駄目なんだよな。

正式名称はThe C Programming Language(邦訳はプログラミング言語C++)
著者はC++の設計者である禿ことBjarne Stroustrupだ。
http://www.research.att.com/~bs/ に写真があるからよく拝んでおくように。

日本語訳については色々言われているみたいだが、俺は原著しか使ったことが
ないので分からん。英語に問題ないなら原著をすすめておく。
787デフォルトの名無しさん:2009/06/05(金) 15:07:13
一番、二番目に出てくるならまだしもそれ以外でググレとか言う奴の精神が分からん。
素直に教えて感謝されればいいのに
788デフォルトの名無しさん:2009/06/05(金) 15:12:09
>>786
禿本とはそういう意味だったのですか。
教えてくださってどうもありがとうございました。参考にします。
789デフォルトの名無しさん:2009/06/05(金) 15:37:25
確かに"禿本"だけであとググれってのはちょっとひどいなw

英語に問題ないならTC++PL(禿本)よりも先にProgrammingを読んだほうがいいかも
同じようなこと書いてあるけどProgrammingのほうが分かりやすい
TC++PLにしか書いてないこともあるからどのみちTC++PLは読むんだけどね
790デフォルトの名無しさん:2009/06/05(金) 15:39:18
途中で送信しちまった…
TC++PL(禿本): http://www.research.att.com/~bs/3rd.html
Programming:  http://www.research.att.com/~bs/programming.html
791780:2009/06/05(金) 15:42:31
>>876
自己レススマソ。原著名間違えた。K&Rじゃないっての。

>>787
まあ2chだから仕方ないね。
禿本ってこのスレでは良く知られてると思ってたけど、意外とそうでもないのかな。
792777:2009/06/05(金) 15:44:42
>>779
ありがとう。コンパイル通るからいいのかと思ったけど
やっぱり基本的には全部書かないとだめなのね。
793デフォルトの名無しさん:2009/06/05(金) 15:45:04
禿本と書いてても意味がわからんからスルーしてた
スルーで正解だった
794デフォルトの名無しさん:2009/06/05(金) 16:20:14
>>787
> 一番、二番目に出てくるならまだしも
Googleを使わせるか否かを考えるのに「一番、二番目に出て来るかどうか」を基準にする、
怠惰な人間をつけあがらせる使命でもあるかのような考え方は理解不能だし、
悪いけど二番目の結果(環境依存OKスレの2スレ目)にこういう文章が出て来るぞ。
> 「プログラミング言語C++」は禿本と呼ぶ。

あ、"C++"と"禿本"をダブルクォーテーションで括る発想に至らないバカは考慮してないけど。
795デフォルトの名無しさん:2009/06/05(金) 16:27:12
質問です。どうしてこのスレには捻くれた奴が湧くんですか?
796デフォルトの名無しさん:2009/06/05(金) 16:30:53
たとえばどのレスのことなのか例を挙げてくれないと、
本当にそういう傾向があるのか、自分のバカさを指摘されたバカが
必死にそう見ようとしてるだけなのか判断つかず、回答できないです。
797デフォルトの名無しさん:2009/06/05(金) 19:26:31
>>792
2でもいいんだけどね。テンプレートパラメータは
宣言された範囲(テンプレートのスコープ)内では省略していいことになっている。
クラス定義の冒頭で template が宣言されていて、その範囲内に入っているので、
この場合のメンバ関数宣言のテンプレートパラメータは省略できる。
(Accelerated C++ p.197などを参照)

template < class T > class foo {
 template < class T > foo &bar( foo<T> &t );
};

のような紛らわしい宣言も可能な様子。
798デフォルトの名無しさん:2009/06/05(金) 19:26:34
>>795
捻くれものは大抵、過去に何らかの形で虐げられた経験がある
あとはわかるな?
799デフォルトの名無しさん:2009/06/05(金) 19:29:36
>795
C++自体が捻れた言語だからです。
800デフォルトの名無しさん:2009/06/06(土) 15:12:48
>>797
全然別人なんだけど割り込んで聞いて良い?

template < class T > class foo {
 template < class T > foo &bar( foo<T> &t );
};
ってのは要するに
template < class T > class foo {
 template < class U > foo<T> &bar( foo<U> &t );
};
ってことだよね?
801デフォルトの名無しさん:2009/06/06(土) 20:23:43
>>798
わかります。
現実の現在で叩きのめされたので、架空の過去を夢想して脳内逆襲ですね?
802デフォルトの名無しさん:2009/06/06(土) 20:26:59
>>800
最初の方はgcc 4.2.1ではエラーになった。
803デフォルトの名無しさん:2009/06/06(土) 21:46:37
(・3・) エェー。ぼじゅあるくっぷぷ(Visual C++)では問題なしだYO

>>800
Yes。
804デフォルトの名無しさん:2009/06/06(土) 22:04:24
以下の変態プログラムでテンプレートパラメータの挙動についてご確認ください
#include <iostream>
using namespace std;

template < class T > class foo {
public:
foo() : x( 0 ) {};
foo( foo *p ) : x( p ) {};
template < class T > foo &bar( foo<T> &t ){
cout << t.member << endl;
return *x;
}
T member;
foo *x;
};

int main() {
foo< int > base;
base.member = 1000;

foo< int > i(&base);
foo< char > c;
i.member = 1;
c.member = 'a';

foo< int > r = i.bar( c );
cout << r.member << endl;
}
805デフォルトの名無しさん:2009/06/07(日) 05:02:33
危うく騙されそうになったが
return *xだから挙動自体は普通だな
806デフォルトの名無しさん:2009/06/07(日) 05:28:11
r.memberが初期化されない…と思ったがコピーコンストラクタじゃないのか。
807デフォルトの名無しさん:2009/06/07(日) 12:07:05
>>804
読むだけで疲労した。
barメンバ関数が何をやりたいのか意図が分からない
(練習プログラムだから仕方ないことだが。)
のに理解をじゃまされた。

分かって良かった。
808デフォルトの名無しさん:2009/06/07(日) 12:38:25
>>807
>>797の再現じゃないの?
809807:2009/06/07(日) 12:56:34
>>808
ああそうなのか、ここのところこのスレ見てなかったから
全然流れを読んでなかったわ。
810デフォルトの名無しさん:2009/06/07(日) 13:58:30
下のように、クラスAAのインスタンスを、メモリーに割り当てたときに。
コンストラクタとデストラクタをどうやって起動したらいいのでしょ?

class AA { int i1,i2; AA(); ~AA(); }
void func()
{
 char dat[100];
 AA *dat;
 dat = (AA *)dat;
}
811デフォルトの名無しさん:2009/06/07(日) 14:02:17
コンストラクタ
new(dat) AA();
デストラクタ
dat->~AA();
812デフォルトの名無しさん:2009/06/07(日) 14:11:53
AA * dat = new AA[100];
delete[] dat;
813デフォルトの名無しさん:2009/06/07(日) 14:38:59
上の例、バッファーとポインターが同じでした、ミスすみません
>>881 下記のようにうにエラーになります  >>812 100個のインスタンスを作るわけではないです
class AA
{
 int a1,a2;
public:
 AA() { printf("AA コンストラクタ\n"); }
 ~AA() { printf("AA デストラクタ\n"); }
};
int _tmain(int argc, _TCHAR* argv[])
{
 char buf[100];
 AA *datp;
 datp = (AA *)buf;
 new(datp) AA(); // ここがエラーになる…
 datp->~AA();
 return 0;
}
エラー 1 error C2660: 'operator new' : 関数に 2 個の引数を指定できません。
814デフォルトの名無しさん:2009/06/07(日) 14:39:55
#include <new> が抜けてるだろ
815デフォルトの名無しさん:2009/06/07(日) 14:41:49
816デフォルトの名無しさん:2009/06/07(日) 14:55:53
>>814 できました、ありがとうございます。
817デフォルトの名無しさん:2009/06/07(日) 15:12:11
ローカル変数に対するplacement newって、アラインメントを気にする必要がなかったっけ?
818デフォルトの名無しさん:2009/06/07(日) 15:16:19
気にする必要があると思います。
実際のプログラムは、sizeof で確認をしています
819デフォルトの名無しさん:2009/06/07(日) 16:27:09
std::vector のようなコンテナを作ろうと思うんだが、
要件について詳しくまとまってるページない?
820デフォルトの名無しさん:2009/06/07(日) 16:49:49
規格を読め
821デフォルトの名無しさん:2009/06/07(日) 16:55:54
別にinterfaceクラスを継承してるわけでもないし、
要件なんて無いぞ。
822デフォルトの名無しさん:2009/06/07(日) 17:05:30
要するに value_type なんかの必須 typedef や
領域確保時の用件とかを知りたいんじゃろ?

領域確保に new を使っちゃらめとか、
知らないとはまる部分もあるしー。
823デフォルトの名無しさん:2009/06/07(日) 17:09:05
>>819
http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2008/n2798.pdf
の23.2.6をしっかり読むこと。

SGIのドキュメントはまとまっていて良かったんだが、最新の仕様と乖離してるのかな。
http://www.sgi.com/tech/stl/Vector.html

>>821
馬鹿か?
824デフォルトの名無しさん:2009/06/07(日) 17:17:18
>>820-823
トンクス
825デフォルトの名無しさん:2009/06/07(日) 17:21:58
>>821
ちょwww
826デフォルトの名無しさん:2009/06/07(日) 19:02:35
>>769-770
>>775-776
このレスで出てきている多重例外「例外ハンドラで例外が出ること」についてですが、
try
{foo();}//適当な例外を投げる関数
catch(const std::exception& ex)
{throw 42;}//ここが多重例外
ってことですよね?
では
try
{foo();}//適当な例外を投げる関数
catch(const std::exception& ex)
{throw ex;}//ここは?
この様に例外を再送する場合も多重例外となり未定義の動作ですか?
また、再送する場合{throw;}と書いても未定義になりますか?
827デフォルトの名無しさん:2009/06/07(日) 19:33:06
>>826
>770や>776は何か勘違いしているような・・・。
例外ハンドラ(catch節)で例外を投げるのは正当。

多重例外というのはもっと異常な事態で、
例外によるスタックの巻戻し中にデストラクタがさらに例外を投げたとか、
値渡しのcatchへ例外をコピー中にコピーコンストラクタが例外を投げたとかのことを言い、
そういう時でも未定義ではなく、terminate()が呼ばれるんじゃなかったっけ?
828==775==826:2009/06/07(日) 20:20:29
とりあえず例外の再送出は問題ないと分かれば当面は解決です。ありがとうございます。

>>827
>例外によるスタックの巻戻し中にデストラクタがさらに例外を投げた
は、
私(>>775)の言う
>アクティブな例外が2つ以上同時に発生すること
ってヤツですよね。
この場合は未定義だとEffective C++で紹介されています。
しかし
デストラクタからの例外送出::実装技術
ttp://cppemb.blog17.fc2.com/blog-entry-31.html
ここによると
>デストラクタから例外を送出するクラスAのオブジェクトを自動記憶域で宣言し、
>その生存期間内で他の例外が発生した場合、A::~A()が呼び出されて、
>その中でまた例外が送出されます。これは二重例外と呼ばれ、
>問答無用でstd::teminateが呼び出されます。
>次に、デストラクタから例外を送出するかもしれないオブジェクトを
>静的記憶域期間で宣言した場合を考えてみてください。
>静的記憶域のオブジェクトを監視ブロック(try〜catchの制御文)で囲む構文を
>記述することはできません。すなわち、こちらはデストラクタから例外が発生した
>時点で(std::terminateの呼び出しではなく)未定義の動作になります。
と書いてありますが、果たして何がどうなんでしょうね。
829デフォルトの名無しさん:2009/06/07(日) 21:16:02
catch節で例外を受けた場合、受け取った例外を再送するか、
受け取った例外を破棄して別の例外を送出するしかなくて、
結局、伝播する例外は1つだけになるので問題ない。
それ以外で例外伝播中に他の例外が発生すると、
2つの例外を伝播させなければならなくなるけど、
それはできないことになってて、かわりにstd::terminate()が呼ばれる。
830828:2009/06/07(日) 22:14:01
>>829
・・・としますと
Effective C++の未定義だという記述の方が誤りで、
デストラクタからの例外送出::実装技術
ttp://cppemb.blog17.fc2.com/blog-entry-31.html
の方が正しいと言うことでしょうか?
831デフォルトの名無しさん:2009/06/08(月) 03:03:48
多重例外が未定義動作だなんてどこに書いてあった?
832デフォルトの名無しさん:2009/06/08(月) 05:20:46
デストラクタで例外を投げてもちゃんと動作は定義されている
意味のある(まともな)動作をさせるのが困難というだけ
833828:2009/06/08(月) 06:59:07
>>831
Effective C++ 原著第3版
p39末行
〜p40頭の数行
にかけて、はっきりと未定義と書かれています。

>>832
それもEffective C++で上と同じ節に書いてあります。
834デフォルトの名無しさん:2009/06/08(月) 08:03:12
>>830
静的記憶域期間を持つオブジェクトがデストラクタで例外送出したらterminateじゃなかったっけ

と思ったら「staticでnon-local」はterminateらしい
「staticでlocal」は記述が見当たらねぇ…
835828:2009/06/08(月) 16:14:44
そしてまあ困ったことに、たしかVC2008とかの有名どころですら
複雑な例外処理の仕様は、正確には実装されていないと聞いたことがあります。

結局は多重例外になるという状況を作らないように気をつけていくしかないのでしょうかね。
836デフォルトの名無しさん:2009/06/08(月) 21:14:03
>>833
そこは仕様書を持ち出すべきだろ。
837828:2009/06/08(月) 21:15:40
>>836
私は仕様書を持ってないんですよ。
趣味グラマなもんでして。
838デフォルトの名無しさん:2009/06/08(月) 21:22:44
例外処理の実装を詳しく説明している書籍は何がありますか?
839デフォルトの名無しさん:2009/06/08(月) 21:26:27
more exceptional C++
840デフォルトの名無しさん:2009/06/08(月) 21:55:50
>>837
興味があるならタダで見られる、日本語で。
http://www.jisc.go.jpから規格番号X3014
841837:2009/06/08(月) 21:58:59
>>840
ありがとうございます。
なんとかDLしたいものですが、ガードされているようですね。

必要に応じてWEBで見るようにします。
842デフォルトの名無しさん:2009/06/08(月) 23:40:41
FDISでよければこことか
ttp://www.kuzbass.ru/docs/isocpp/

15.5.1に
>when the exception handling mechanism,
>after completing evaluation of the expression to be thrown but before the exception is caught,
>calls a user function that exits via an uncaught exception,
>...
>In such cases, void terminate(); is called.
とあるから、terminate()が呼ばれるのは間違いないと思うのだが、
Effective C++には確かに未定義っぽいことが書いてあるし…
英語版でもそうなのかなあ
843デフォルトの名無しさん:2009/06/09(火) 00:25:07
しかし、デストラクタで例外なげるようなプログラムなんて書く訳無いし、あんまり気にしすぎても仕方ないよ。
いえ、ごめんなさい。
844デフォルトの名無しさん:2009/06/09(火) 20:20:17
関数テンプレートがインスタンスを指定することによって実体化できるのに対し、
クラステンプレートは型名を指定しないと実体化できないところに不便さを感じます(boost::rangeとか特に)。
何かいい方法はないですかね?
845デフォルトの名無しさん:2009/06/09(火) 20:26:59
そのためのtypedefだろ?
846デフォルトの名無しさん:2009/06/09(火) 20:27:22
クラステンプレートは、型を引数に取って型を返す関数
847デフォルトの名無しさん:2009/06/09(火) 21:35:16
>>846
TMPか。
848デフォルトの名無しさん:2009/06/09(火) 21:40:37
>>844
std::make_pairやboost::make_iterator_rangeのように関数テンプレートでラップすればいい。
849デフォルトの名無しさん:2009/06/09(火) 21:41:43
>844
関数テンプレートもインスタンスで指定しているわけじゃないぜ。単に引数の型を推論しているだけ。
#動的な型は対応できない

どうしてもというなら関数テンプレートでラッパー作ればよろし。
850デフォルトの名無しさん:2009/06/09(火) 22:05:43
>>845
型指定するのが手間に思えます。型推論してくれないかなと。
>>846
関数の引数をテンプレートに変更してもそのまま使えるのに、クラスのメンバ変数をテンプレートにすると使う側に手間が増えるのが不便に感じます。
>>848
makeXXXの戻り値を受け取るところで結局型指定が必要になってしまいます。
>>849
書き方が悪かったです。

template<class T>
void F(T t);
template<class T>
class C {
  T t_;
public:
  C(T t):t_(t){}
};
F(hoge);// hogeを簡単に渡せる
C<Hoge> c(hoge);// 型を指定しないと渡せない
この違いを埋めることってできないですか?
rangeを渡す時、後者はめんどくさく感じて仕方ないです。
851デフォルトの名無しさん:2009/06/09(火) 22:13:14
>>850
> F(hoge);// hogeを簡単に渡せる 
> C<Hoge> c(hoge);// 型を指定しないと渡せない 
どう書ければうれしいの?
852デフォルトの名無しさん:2009/06/09(火) 22:31:30
>>851
Hogeを書かなくてよくなればうれしいです。
言語の仕様上、Cを非テンプレートクラスにするしかないですかね。
boost::any使っても値を取り出すことができないし、うーん・・・。
853デフォルトの名無しさん:2009/06/09(火) 22:49:02
class B{public:virtual B&fn()=0;};
template<T>class A:B{public:T t_;A(T t);B&fn();};
class C{A&a;public:template<T>C(T t):a(C<T>(t)){};B&fn(){return a.fn();}};

実現しようと思えば物凄く面倒。
854デフォルトの名無しさん:2009/06/09(火) 22:53:56
>>852
つまりこういうこと?
 C<> c(hoge);
855デフォルトの名無しさん:2009/06/09(火) 23:04:50
>850
F(hoge)のhogeはどのみち静的な型になってるだろ。
C<Hoge>とするのに比べてそんなに汎用性が高くなっているわけじゃないよ。

型を推論してくれるから面倒なことは少ないけど。まあ、素直にC++0xのauto待ちでいいんじゃね?
856デフォルトの名無しさん:2009/06/09(火) 23:40:44
>>853
頭がクラクラしてきます。
>>854
そのコードが許されれば大満足です。
>>855
単純に入力の手間の問題ですね。
boost::range使っていて、コードを書いてる時に型を意識しないといけないのはつまらないなーと思いました。
857デフォルトの名無しさん:2009/06/09(火) 23:54:20
100万回呼ばれるメソッドがあったとして

Hoge * f(...)

Hoge & f(...)

ってどっちがお得なのでしょうか?
858デフォルトの名無しさん:2009/06/10(水) 00:00:24
コンパイラしだいだけど、大体、どっちもいっしょ。
859デフォルトの名無しさん:2009/06/10(水) 00:02:27
100万回程度ならどっちも同じ。
860デフォルトの名無しさん:2009/06/10(水) 01:17:43
>>859

じゃあ1無量大数回なら?
861デフォルトの名無しさん:2009/06/10(水) 01:24:23
呼び出しの時間なんて気にするなってことだろjk
マイクロ秒で競ってどうするんだよ…
862デフォルトの名無しさん:2009/06/10(水) 02:06:29
呼び出し側にも依るが、参照とポインタだけの違いならまったく同じバイトコードになる可能性が高い
参照なんてのは結局ただのポインタだからね
863デフォルトの名無しさん:2009/06/10(水) 02:11:09
参照の場合はコンパイル時のチェックがかかるだけで、バイナリは同じものになるって話を聞いたことがあるが・・・
ホンマかいな
864デフォルトの名無しさん:2009/06/10(水) 02:12:05
コンパイルの時間まで考慮するならHoge*f(...)の方が早くなる可能性があるな
865デフォルトの名無しさん:2009/06/10(水) 05:24:40
>>863
絶対じゃないだろうが、その可能性はあるでしょうな。

参照はどう実装しても良いわけで、
別に参照はポインタを用いて実装されているという保証はない。
だが普通ポインタを用いて実装するので、。
866デフォルトの名無しさん:2009/06/10(水) 18:13:43
TCP/IPのソケット通信プログラムなのですが

connectを実行し、接続確認にsendとrecv
を行っているのですが、recvでソケットエラー
が発生し、GetLasterrorでエラーコード
を取得すると「既に使われている(183)」でした。

何故こんなエラーになるのか分からず
困っています。どなたか教えて下さい。
867デフォルトの名無しさん:2009/06/10(水) 19:08:03
環境がわからないし、エラーは正確に書くべき。
868デフォルトの名無しさん:2009/06/10(水) 19:09:46
WSAGetLastError呼べよ
869866:2009/06/10(水) 19:33:58
>>867
送信先:Windows2003Server
送信元:WindowsXP
開発:VC2005

recv()の戻り値が-1
WSAGetLastErrorでエラーコードを取得したら
183だった。
ということですm(_ _)m

>>868
すまん、WSAGetLastError使ってた。
870デフォルトの名無しさん:2009/06/10(水) 20:26:54
wineをみるとWSAGetLastErrorとGetLastErrorは同じものです。
recvのすぐ後でミューテックスをロック/アンロックなどを
しているんではないですか?
871デフォルトの名無しさん:2009/06/10(水) 23:06:23
class MyClass {
protected:
struct foo_t{
struct bar_t{

}foo;

};
872デフォルトの名無しさん:2009/06/10(水) 23:10:14
すみません。途中で書き込んでしまいました。
class MyClass {
protected:
 enum {NUM = 5};
 struct foo_t{
  struct bar_t{
  }bar[NUM];
 }foo;
};
VC6で上記コードをコンパイルすると、NUMにアクセスできないというエラーが出ます。
NUMをpublicで定義すると大丈夫です。
構造体の入れ子になった場合はpublicでないとアクセスできないのでしょうか?

class MyClass {
protected:
 enum {NUM = 5};
 int foo[NUM];
};
ちなみにこちらは問題ありませんでした。
873デフォルトの名無しさん:2009/06/10(水) 23:13:49
bar_tを外で宣言するか
foo_tに適切なコンストラクタを用意すれば良い
874デフォルトの名無しさん:2009/06/10(水) 23:20:09
gcc4.2.1なら大丈夫
875デフォルトの名無しさん:2009/06/10(水) 23:20:18
レスありがとうございます。

fooはPOD型であってほしいので、コンストラクタを用意するのは望ましくないです。
後出しですみません。

bar_tを外で宣言するというのはどういうことでしょうか?
876デフォルトの名無しさん:2009/06/10(水) 23:21:33
>>874
VC6なのでenumハックを使っています。
877デフォルトの名無しさん:2009/06/10(水) 23:39:37
VC6なんて窓から投げ捨てろ
878デフォルトの名無しさん:2009/06/10(水) 23:40:35
>>876
VC6はもうVC6言語だと思った方がいいくらい、標準と違う。
そんなクソ環境、捨ててしまえ。
879デフォルトの名無しさん:2009/06/10(水) 23:48:19
eclipseとgccにすればっ
880デフォルトの名無しさん:2009/06/10(水) 23:52:01
VCのお手軽感捨てたくなければ最新のExpressって手もあるな
VC6はリソースの編集専用にすればよろし
881デフォルトの名無しさん:2009/06/10(水) 23:52:07
全く持ってその通りなんですが、納品先がVC6で開発してるものでorz
882デフォルトの名無しさん:2009/06/10(水) 23:54:53
納品先を捨ててしまえ!、え?、違うって(ry
883デフォルトの名無しさん:2009/06/10(水) 23:59:41
publicにすればビルドできるのでそうしときます
884デフォルトの名無しさん:2009/06/11(木) 00:06:36
gccってfriendつけないでも平気なんだ 知らなかった
885デフォルトの名無しさん:2009/06/11(木) 00:11:06
今、双方向のリスト構造のテストプログラム組んで思ったんだけど

int main{
  // hpはノードのポインタ型
  //--上・省略--
  hp = hp->next;
  //--下・省略--
}

っていう風にやったら普通にうまくいくんだけど、
これを関数かしてやって
void gotoNextNode(Node* pnode){
  pnode = pnode->next;
}

int main{
  // hpはノードのポインタ型
  //--上・省略--
  gotoNextNode(hp);
  //--下・省略--
}

ってやったら「pnode = pnode->next;」の部分が効かないみたいなんだけどなんでだろorz?
886デフォルトの名無しさん:2009/06/11(木) 00:14:28
それは、ローカル変数に入れても、なにもならん
887デフォルトの名無しさん:2009/06/11(木) 00:15:48
gotoNextNode(&hp);
888885:2009/06/11(木) 00:18:06
ノードのポインタ型は下のようになってて
typedef struct _Node{
    int num;
    struct _Node *next;
    struct _Node *back;
}Node;
ポインタ渡してるからいけるんじゃね?・・・って思ったんだけどさ
889デフォルトの名無しさん:2009/06/11(木) 00:19:12
*pnode = pnode->next;
じゃなくて?
890885:2009/06/11(木) 00:20:06
んで、hpはNode* hpで定義してます
891デフォルトの名無しさん:2009/06/11(木) 00:20:53
void gotoNextNode(Node* &pnode){
892デフォルトの名無しさん:2009/06/11(木) 00:22:51
C++ならポインタのリファレンスが使えるから

gotoNextNode(Node*& pnode)
893885:2009/06/11(木) 00:27:08
うは、確かに*の横に&付けたらうまくいったわサンクスコ
*&なんて使い方初めて知ったわ
894デフォルトの名無しさん:2009/06/11(木) 00:29:27
void gotoNextNode(Node**pnode){
*pnode = (*pnode)->next;
}

型 & hoge
だから別に特殊なことやってる訳じゃないよ
895デフォルトの名無しさん:2009/06/11(木) 01:40:37
なんで二重ポインタやポインタ+リファレンスを使わないといけないんだろう・・・?
ポインタが仮想変数になったときにポインタじゃなくて値として扱われてしまうとか?
896デフォルトの名無しさん:2009/06/11(木) 01:46:44
int i = 5;
myFunc(i);
void myFunc(int a)
{
 a = 1;
}

ってやって、iの値が変わらないんだけど!って言ってるのと同じであることはわかった上で、
不満だと言っている?
897デフォルトの名無しさん:2009/06/11(木) 01:47:44
単純に「ポインタで受け取れば引数の変更が呼び出し元に反映される」と考えてはいけない。
引数に対する変更が呼び出し元に反映されるためには、
変更したいものを指すポインタを受け取るとか、変更したいものを参照で受け取るとか
しないといけない。

>>855の hp = hp->next; というコードは、ポインタの値を変更してるよね。
「変更したいもの」がポインタなんだ。
だから、ポインタのポインタとか、ポインタの参照を受け取らなければならない。
898897:2009/06/11(木) 01:48:37
>>855じゃなくて>>885だった。分かると思うけど。
899デフォルトの名無しさん:2009/06/11(木) 01:52:06
void myFunc(int a)
{
 a = 1;
}
の例はすぐに関数抜けた時点でaが開放されて値が消えるってのは分かるけど・・・
その例と同じってのは分かってないわ・・・スマン
900デフォルトの名無しさん:2009/06/11(木) 01:59:13
typedefしたら分かりやすいか?

typedef Node* PNode;
PNode hp;

void gotoNextNode(PNode pnode){
  pnode = pnode->next;
}

int main{
  // 略
  gotoNextNode(hp);
  // 略
}

hpは変更されない。これはほぼ>>896と同じ。
受け取ったPNode値への変更が呼び出し元に反映されるには、PNode* や PNode& で受け取らないと。
901デフォルトの名無しさん:2009/06/11(木) 01:59:44
int型の変数である、iの値を変更したい場合に、
int型を指すことができるポインタ(int*)、もしくは参照(int&)で受けなければならない
というのはわかっているってことね?

だったら、こう置き換えてみたら?
Node*型の変数である、hpの値を変更したいのであれば
Node*型を指すことができるポインタ(Node**)、もしくは参照(Node*&)で受けなければならない
902デフォルトの名無しさん:2009/06/11(木) 02:06:48
あー、typedefで何を言いたいかって考えたらなんとなく分かってきたわ。
単にポインタで受け取る時は値を変更する時にも使うから、
それと同じ状態になって関数を抜けるから無効になってるということで
ポインタを変更したいときはPNode* や PNode& で受け取らないといけないって感じでおk?
903デフォルトの名無しさん:2009/06/11(木) 02:17:44
ポインタを代入したいから >895
904デフォルトの名無しさん:2009/06/11(木) 02:24:21
>>902
まあ、そういう理解でおk。
typedefなんか持ち出して余計混乱させたらどうしようかと思ったが、たぶんちゃんと通じてると思う。
905デフォルトの名無しさん:2009/06/11(木) 16:09:30
K&Rでは構造体をうまく使ってわかりにくいダブルポインタを回避していた
C++ならイテレータクラスを作ってポインタのやり取りそのものを回避(中は結局ポインタだけど)

ダブルポインタを使う時点でもしかしたら設計に問題が^^
906デフォルトの名無しさん:2009/06/11(木) 20:45:54
pimplで使うスマートポインタって皆さんどうしてます?
ディープコピー方式のoperator=を持つshared_ptrがあれば便利だと思うんですが、どうもなさそうです。
907デフォルトの名無しさん:2009/06/11(木) 20:54:12
>>906
shared_ptrは浅いコピーだからこそpimplイディオムは生きるのだよ。

でもまあディープコピーにしたいこともあるのかもね。
ディープコピーにしたいってどんな状況?
class MyClass;
class MyClass_impl;
だとして、MyClassのコピーコンストラクタを適切に定義すれば
boost::shared_ptrで十分じゃないかと思うよ。
908デフォルトの名無しさん:2009/06/11(木) 21:07:50
>>907
pimplイディオムを使わないでMyClassを実装した場合と同じ挙動にしたいです。
コピーコンストラクタやoperator=を書かない事(コンパイラまかせ)はよくあるので、
そういった場合にpimplで実装した事によって挙動が変わるのは嫌だなと思います。
909デフォルトの名無しさん:2009/06/11(木) 21:30:54
pimpl使う版と使わない版のMyClassが必要で、その挙動を変えないためってこと?
何のためにそんなことするのかは知らないけど、同じようなクラス2つ書いてコード重複するくらいなら
pimplなんか使わない方がいいよ
910デフォルトの名無しさん:2009/06/11(木) 22:01:04
>>909
pimpl版と非pimpl版の2つがあるわけではないです。
pimplイディオムで実装することによって、注意しなければいけない事を増やしたくないという意味です。
MyClassのコピーコンストラクタやoperator=を書き忘れて(pimplじゃなければ書かなくてもOKだから忘れやすい)
バグが発生したりしないために自動でディープコピーになってくれた方が便利だと思います。
911デフォルトの名無しさん:2009/06/11(木) 22:14:55
>910
boost::any使いなされ。あれは値のセマンティクスになってるよ。
>774みたいに突っ込むコンテナによってセマンティクスを変える手もあるけど。
912907:2009/06/11(木) 22:17:10
>>910
あー、言いたいこと分かった。
要は君自身、今のところは問題無くpimplイディオムを使えてはいるけど、
いつかうっかりしそうだからディープコピーなshared_ptrがあったら
いいなぁ
ってことだよね?

でも
>自動でディープコピーになってくれた方が便利だと思います。
いやいやそりゃ困るよ。
浅いコピーだからこそ生きるpimplイディオムの状況ってかなりあるのだよ。
例えばoperator=で浅いコピーにすることにより超高速なコピーが出来るわけ。
913デフォルトの名無しさん:2009/06/11(木) 22:29:39
デフォでshallow copyで
deep copyは明示的にclone()を使うっていう決まりを作るとか
914デフォルトの名無しさん:2009/06/11(木) 22:38:07
デフォはdeep copyで
shallow copyは明示的にdangerous_clone()を使う決まりの方がいいです
915デフォルトの名無しさん:2009/06/11(木) 22:57:35
>>911
pimplにboost::anyを使うというのは初めて知りました。
確かに便利ですね。
弱点をあげるなら、速度が若干遅くなりそうなところでしょうか。

>>912,913
>>914の方が私は直感的にわかりやすく感じます。

ありがとうございました。
916デフォルトの名無しさん:2009/06/11(木) 23:07:55
直感的にわかりやすいかどうかよりも、間違いが起こりにくいという点で>>914の方がいいなあ。
間違えてデータ壊れるか、間違えて処理が遅いか、なら後者の方がいい
917デフォルトの名無しさん:2009/06/12(金) 00:48:51
C++はヒープの無い環境でも使えるようになっていて、
組み込みでも実際使われている。
それをデフォでdeep copyなんかにされたらたまったものじゃない。
918デフォルトの名無しさん:2009/06/12(金) 01:09:30
deep copyだとまずい理由がある時は明示的にshallowにすればいいじゃん。
deepで困るケースは少ないんだからデフォはdeepでOK。
つーかshallow copyによる高速化とpimpl関係なくない?たまたま一石二鳥になっているだけで。
919デフォルトの名無しさん:2009/06/12(金) 01:19:44
そもそも、pimplで深いコピーにするのが不可能でも特別面倒でもないでしょ。
ほかのメンバ関数と同じ調子で、コピーコンストラクタとoperator =を定義するだけのはず。
920デフォルトの名無しさん:2009/06/12(金) 01:25:56
だからコピーコンストラクタと代入演算子を定義し忘れるから
Pimplはdeep copyをデフォにして欲しいと言ってんの

もしかしてアフォ?
921デフォルトの名無しさん:2009/06/12(金) 02:22:00
shallow copyをする気がないなら、そもそもshared_ptrにしなくていいのでは。
auto_ptrやscoped_ptrにすれば、コピーコンストラクタと代入演算子を定義し忘れることはない
(定義し忘れるとコピーがコンパイルエラー)。
922デフォルトの名無しさん:2009/06/12(金) 03:05:27
>>921
auto_ptrもscoped_ptrも不完全型には使えない。
ttp://d.hatena.ne.jp/Cryolite/20060108 (不完全型によるコンパイラファイアウォールとスマートポインタの両立(その1)以降を参照)

空のデストラクタを書くのも手間だし、コピーコンストラクタと代入演算子を書くのも手間。
deep copyにしたくてshared_ptrを使いたいなんて言ってるやつはいない。pimplにぴったりのスマートポインタないっていう話。
923デフォルトの名無しさん:2009/06/12(金) 04:03:21
うーん。明示的にデストラクタ書かなきゃいけないのがそんなにデメリットだとは思ってなかったんだが
まあ、気にする人も結構いるのか。
924デフォルトの名無しさん:2009/06/12(金) 04:13:30
unique_ptrがoperator=でdeep copyしてくれればいいのに。
925デフォルトの名無しさん:2009/06/12(金) 06:54:12
当然じゃねーの?てな部分に疑問を呈す >>922 の様な人が声高に暴れて言語やライブラリのカオス度が濃くなるんだよな
科学技術とか未踏の分野の開拓なら役に立つかもしれんけど邪魔な存在だな
926デフォルトの名無しさん:2009/06/12(金) 07:35:04
しかしpimpl_ptrは何回もrejectされている…
927デフォルトの名無しさん:2009/06/12(金) 08:26:46
pimpl自体、きもいイディオムだから、あんなの使わなくて済むようななにかを追加して欲しい
928デフォルトの名無しさん:2009/06/12(金) 08:27:37
何の話をしているのかいまいちわからないが
ポインタ型があったとして

A a, b;
A *pa=&a, *pb=&b;
pa = pb;

こうしたら、aがbの値に上書きされるってこと?
なんだがおかしいね。
*pa = *pb; だよね普通。
929デフォルトの名無しさん:2009/06/12(金) 09:52:42
個人的にpimplを使うようなでかいクラスは大体コンストラクタとかも
全部ソースで定義するのでscoped_ptrで問題なし
930デフォルトの名無しさん:2009/06/12(金) 10:44:45
ちょいとしつもんだんですが、

30,000x30,0000x4程度のbool配列と、30,000x30,0000のint配列を使いたいという思いでいっぱいです。

しかし単純に配列を作ってしまうと、やはりout of memoryです。

どうにかして要素数を減らすのが一番だとは思うんですが、

一般的に、このように膨大な要素の配列を扱わざるをえない場合にはどのような方法を用いるのでしょうか?
931デフォルトの名無しさん:2009/06/12(金) 10:49:51
>>930
疎なデータならその部分だけを保持する
932デフォルトの名無しさん:2009/06/12(金) 10:51:08
>>930
速度が滅茶苦茶遅くていいならファイルをメモリと見なし
operator[]をオーバーロードするとか
933デフォルトの名無しさん:2009/06/12(金) 11:09:18
>ちょいとしつもんだんですが、

質問団?w
そのくらいの量なら、64bitOSで普通にnewでもvectorでも持てると思うけど。
まぁ、swapされるのは覚悟する必要があるな。
処で、それ本当に必要なの? 疎行列として扱うとか、boolではなくcharかbitで保持するとかできない?
934デフォルトの名無しさん:2009/06/12(金) 11:29:57
>>933
>64bitOSで普通に
さらっと、OSレベルで条件付け加えんなw
アフォか
935デフォルトの名無しさん:2009/06/12(金) 11:32:54
>>934
2バイト整数を3万掛ける3万なら、32bitOSでも普通にOK。
今時、Windowsでも2GB位積んでるのが当たり前だしね。
936デフォルトの名無しさん:2009/06/12(金) 11:38:47
> 30,000x30,0000x4程度のbool配列と、30,000x30,0000のint配列を使いたいという思いでいっぱいです。

30,0000?
937デフォルトの名無しさん:2009/06/12(金) 11:41:11
うお、それは気づかなかった。30万なのか?w
938デフォルトの名無しさん:2009/06/12(金) 11:43:13
2G程度あっても無駄無駄無駄ーなのです
939デフォルトの名無しさん:2009/06/12(金) 11:58:11
ごめんなさい!3万x3万です!ちなみに768MBしか積んでません><クズです!
>>931-933
0or1のフラグとして使うつもりでboolを使いました。

やろうと思っていることは、「生物学で使うDNA塩基配列のアライメント」で
int 3マンx3マンを隅から数値を埋めていく一方で、
その数値を確認しながら条件に従って、その要素に対応するboolの配列の要素1-3に1or0を入れていく。

ということを行っています。

intの配列array[i][j]については[i+1][j+1]まで処理した時点で破棄できるのでもっと少なくできると思うんですが、

bool配列についてはすべて埋め終わった後に、もう一度フラグの確認をしていくのですべて残しておく必要があります。


ちなみにbool型が一番サイズが小さいと勝手に思い込んでいました。
940デフォルトの名無しさん:2009/06/12(金) 12:05:43
なんだか良くわからないけど,計算用の鯖用意すれば解決するんじゃないかな^^;
パソコンでやるなら>>933とか.

でも
> int 3マンx3マンを隅から数値を埋めていく一方で、 
> その数値を確認しながら条件に従って、その要素に対応するboolの配列の要素1-3に1or0を入れていく。
これって注意深く行うとすると,今状態[3万×3万]と次状態[3万×3万]が必要になるんじゃないかい?
軽くめんどくさい
941デフォルトの名無しさん:2009/06/12(金) 12:26:39
int配列やbit配列の要素間で、相互参照がないなら
ストレージに対して、逐次読み出し、逐次書き込みで
いいんじゃねーの。
942デフォルトの名無しさん:2009/06/12(金) 12:31:29
塩基配列なら AGTC の4種
30kx30k 900M
1bit データなら 900M/8 = 112MB
塩基配列なら4種2bit 900M/4 = 225MB

メモリに載せるのは可能っぽい
943デフォルトの名無しさん:2009/06/12(金) 12:35:52
>>939
768MBでも仮想記憶があるから屑だなんて言っちゃイヤ!

と言うのはさておいて。

>intの配列array[i][j]については[i+1][j+1]まで処理した時点で破棄できるのでもっと少なくできると思うんですが、
これは、相互参照があるってことなのかな?
だとしても、1行3万点として前後1行ずつで併せて3行がメモリにあれば事が足りるよね。
後は、ディスクをぶん回すことになるけどなんとかなりそうだ。
# 最初は1000x1000くらいに絞って作らないとデバッグの段階で死ねるね。
944デフォルトの名無しさん:2009/06/12(金) 12:51:27
連続領域で取ることができないだけなので、int**にして3万を3万回動的確保すればいけるんじゃないの?
945デフォルトの名無しさん:2009/06/12(金) 15:17:36
今メモリ安いのに。。。
768MB しかないと CPU も辛そうじゃね?
946デフォルトの名無しさん:2009/06/12(金) 15:34:02
安物ネットブックでも1GBは積んでる時代だしな。
947デフォルトの名無しさん:2009/06/12(金) 17:27:13
みなさんありがとおおO!!!!!

bool → bit  につめて、
array → 3行 にしたら、

なんとかなりそうです!!
948デフォルトの名無しさん:2009/06/12(金) 22:28:11
なんとかなってるといいな
949デフォルトの名無しさん:2009/06/12(金) 22:35:29
A案
MyClass hoge;
for (…) {
 hoge = func();
 …
}

B案
for (…) {
 MyClass hoge = func();
 …
}

C案
{
 MyClass hoge;
 for (…) {
  hoge = func();
  …
 }
}

あなたはどれ?
950デフォルトの名無しさん:2009/06/12(金) 22:45:17
ほとんどAかなー
時々Bと同じスコープで宣言位置がforの中に入れてるときがある
ただしjava
951デフォルトの名無しさん:2009/06/12(金) 23:17:12
Aだなあ。
Cはわからなくもない(スコープ制限つけたかっただけだよね?)
Bってコスト高くつかない?そうでもないのかな?
952デフォルトの名無しさん:2009/06/12(金) 23:38:28
MyClassの大きさによるけど、大体C。
MyClassが小さいならB
953デフォルトの名無しさん:2009/06/12(金) 23:52:18
おれは基本BでMyClassがでかければA。
ただこの例くらいなら気の利いた最適化してくれてコスト気にする必要はなさそうな気もするな。
954デフォルトの名無しさん:2009/06/13(土) 00:14:02
B以外は池沼
955デフォルトの名無しさん:2009/06/13(土) 00:18:57
普通に大きいだけならコストA>BはあってもB<Aはありえん。
B一択。jk
956デフォルトの名無しさん:2009/06/13(土) 00:20:04
ここには書いてないが MyClass のデストラクタは処理に1000時間かかるんだよね。
957デフォルトの名無しさん:2009/06/13(土) 00:30:16
これまた書いていないんだがコピー演算子には
ブラジルに電話をかける処理が含まれているんだ。
958デフォルトの名無しさん:2009/06/13(土) 00:32:30
けどコピーコンストラクタは超速いんだ
959デフォルトの名無しさん:2009/06/13(土) 00:40:53
なぁにstaticにすればもんだいない
960デフォルトの名無しさん:2009/06/13(土) 06:09:15
ループ中にfunc()の戻り値が変化するならB、しないならA
961デフォルトの名無しさん:2009/06/13(土) 06:51:57
struct{
MyClass&hoge;
unsigned begin,end;
operator X(){for (…) {hoge = func();…};return X;}
}OBJ={hoge,BEGIN,END};
return OBJ;
962デフォルトの名無しさん:2009/06/13(土) 08:00:42
>>960
言ってることおかしいだろ

>ループ中にfunc()の戻り値が変化しないならA
そんな条件なら誰だってA案じゃなくて
D案(新案)
MyClass hoge;= func()
for (…) {
 …
}
にするわ。
func()の戻り値が変化することはもう皆空気を読んで分かっていることだ。
963デフォルトの名無しさん:2009/06/13(土) 08:07:27
あ、そりゃそうだな…なんかボケてるな俺
964962:2009/06/13(土) 08:23:54
>>963
意外に素直だな
965デフォルトの名無しさん:2009/06/13(土) 10:15:50
pimpleで画像検索してみい
966デフォルトの名無しさん:2009/06/13(土) 10:57:44
>>949
A 案 : 自主的にこう書く事はない。
B 案 : 基本的にこの方法にする。
C 案 : ループ後に hoge が必要な場合に限定。

A 案のコードは、状況に応じて B、C に直す事もある。

hoge の生成コストが予測不能だから A 案が安全、という主張もあるだろうが、
それは「早すぎる最適化」なので、コストが問題になるまでは、参照範囲を狭
める方向で実装したいな。
967デフォルトの名無しさん:2009/06/13(土) 11:54:04
>>964
自分の間違いを素直に認められる奴が一番賢いんだ。
だからお前も自分の間違いを認めて俺と結婚しろ。
968964:2009/06/13(土) 15:32:30
>>967
それはまた新たな過ちを犯しているのでは?(笑)
969963:2009/06/13(土) 16:48:18
>>968
ちょw>>967は俺じゃないw
男と結婚なんて、あさおんでもしない限りありえないお
970デフォルトの名無しさん:2009/06/13(土) 17:59:26
operator << って英語で何て言う?
標準出力演算子とか?
971デフォルトの名無しさん:2009/06/13(土) 18:01:10
bitwise left shift operator
972デフォルトの名無しさん:2009/06/13(土) 18:39:28
stream output operator
double angle brackets
973970:2009/06/13(土) 20:57:55
>>971-972
ありがとうございます。
974デフォルトの名無しさん:2009/06/13(土) 21:00:56
グローバルなオブジェクトはパフォーマンスや初期化順序の問題等で出来る限り避ける
べき、ということで自分のコードを修正しているのですが、
どの程度避けるべきか、避けるとしたら既存のコードをどう変更すべきか悩んでいます。

具体的な話だと、例えば文字列定数は、使っている文字列クラス(string等)の定数
オブジェクトで定義しておきたかったりします。
この場合にグローバルオブジェクトを避けるとしたら、どうしますかね?

例えば「定数文字列はCの文字リテラルで宣言しておいて、使うときに文字列オブジェクト
を生成.」なんてのがありでしょうが、安直にやると毎回オブジェクトを生成することになり
ますよね。かといって一旦生成したオブジェクトは破棄せず再利用、なんて考える
と、コードが煩雑になるような...
似たようなことは文字列以外のオブジェクトでもありまして... いやはや。
975デフォルトの名無しさん:2009/06/13(土) 21:04:04
static const std::string ConstantString = "I am hoge.";

これじゃダメなん?
976975:2009/06/13(土) 21:05:42
static const std::string ConstantString("I am hoge.");
でも同じ。
977デフォルトの名無しさん:2009/06/13(土) 21:58:02
グローバルを避けろというのは、必要もないのに広く晒すことを戒めてるんであって
不変なデータとか、本当にプログラムの広い範囲から参照が必要なものをグローバルにするのは問題ない
978デフォルトの名無しさん:2009/06/13(土) 22:10:29
初期化順序の問題は?
979デフォルトの名無しさん:2009/06/13(土) 22:16:56
std::vector<double*>* から
std::vector<const double*>* に変換するにはどうしたらいい?

全体をコピーする方法以外でたのむ。
980デフォルトの名無しさん:2009/06/13(土) 22:20:14
>>979
std::vector<double*>*

std::vector<const double*>*
には継承関係とかが全然ないけど、全コピ以外でやる方法なんて存在しうるのだろうか?
981デフォルトの名無しさん:2009/06/13(土) 22:26:40
reinterpret_cast< std::vector<const double*>* >
982デフォルトの名無しさん:2009/06/13(土) 22:28:15

hoge->getval()->getval()->getval()->setupdate();
(getvalでメンバ変数として定義されたインスタンスのポインタを呼び出します)

とかいうアホな実装を直すいい方法ないですか?
983デフォルトの名無しさん:2009/06/13(土) 22:31:37
>>981
動きそう
984デフォルトの名無しさん:2009/06/13(土) 23:14:08
>>982
別にいいじゃん。
ツリーとかそうなるっしょ。
985デフォルトの名無しさん:2009/06/13(土) 23:17:18
constオブジェクトを格納しても、結局イテレータで値書きかえられちゃうんだよね、VCの場合。
986デフォルトの名無しさん:2009/06/14(日) 04:28:21
>>982
1回しか呼ばないならそのままで構わないと思う。
何度も呼び出すようなら
void Hoge::setupdate() { getval()->getval()->getval()->setupdate(); }
を定義して、
hoge->setupdate();
とするのは?
987デフォルトの名無しさん:2009/06/14(日) 08:31:29
hoge->getval()->getval()->getval()->setupdate();
これって速度的にどうなんだろ?空の関数でも
呼び出し遅くないのかな?
988デフォルトの名無しさん:2009/06/14(日) 08:46:33
インライン展開関数なら、インデックス引き1回。そうでないなら重い。
しかしそれ以前に、こんなことをしなければいけない設計に問題がある。
989デフォルトの名無しさん:2009/06/14(日) 09:21:33
えっ
なんで?
990デフォルトの名無しさん:2009/06/14(日) 09:27:06
>>987
>>988の通りだが、ループ中で読んでなければ無視できるレベル。
991デフォルトの名無しさん:2009/06/14(日) 09:30:09
>>982
継承
992デフォルトの名無しさん:2009/06/14(日) 09:39:30
>>989
>なんで?
なんでって、俺ならそんなこと無くてもいい設計が普通に簡単に書けるから
993デフォルトの名無しさん:2009/06/14(日) 09:48:52
>>992
どんなの?どんなの?
書いてみて?書いてみて?
書けこらぁ
994デフォルトの名無しさん:2009/06/14(日) 09:53:56
お前システム設計したことあるのか? 無いだろう?
直接プログラム打ち込んでるだけじゃないのか?
995デフォルトの名無しさん:2009/06/14(日) 10:03:45
>>992
そういうのは書いて叩き台作ってから話してね!ゆっくりしてないよ!
996デフォルトの名無しさん:2009/06/14(日) 10:06:26
設計の話をたたき台にと言っているお子様には、笑いがこぼれます。
997デフォルトの名無しさん:2009/06/14(日) 10:11:39
日曜おほほほ
998デフォルトの名無しさん:2009/06/14(日) 10:12:01
そうだな、設定のたたき台を出しても良いが。
その前に、設計するための目的の仕様をキッチリ出してもらおうか。
その仕様書がしっかりしてて、暇があったら設計のたたき台を出そう。
今から出かけるから、それまでに出すんだぞ。
999デフォルトの名無しさん:2009/06/14(日) 10:12:28
次スレ立てる
1000デフォルトの名無しさん:2009/06/14(日) 10:13:13
>>998
# 俺ならそんなこと無くてもいい設計が普通に簡単に書けるから 
はあ?できないならできないって言えよ

ところでスレオワタ
10011001
このスレッドは1000を超えました。
もう書けないので、新しいスレッドを立ててくださいです。。。