【初心者歓迎】C/C++室 Ver.35【環境依存OK】at TECH
【初心者歓迎】C/C++室 Ver.35【環境依存OK】 - 暇つぶし2ch167:デフォルトの名無しさん
07/02/25 22:06:14
そういえば昔、
system("dir > hoge.txt")して、fopen("hoge.txt","r")...みたいなことを
やってた連中が居た。

168:デフォルトの名無しさん
07/02/25 22:11:16
>>164
環境依存

>質問者は必ず、環境を書きましょう。

169:デフォルトの名無しさん
07/02/25 22:13:08
>>167
十分アリだと思う dir /b ほうがイイと思うが

170:デフォルトの名無しさん
07/02/25 22:15:15
popenの事たまには思い出してあげてください

171:164
07/02/25 22:16:58
VisualC/C++
WindowsXP
フォルダ内のファイル名をstd::stringの配列に格納したいのです

172:デフォルトの名無しさん
07/02/25 22:32:34
>>171
FindFirstFile
FindNextFile

あたりでどうかな

173:デフォルトの名無しさん
07/02/25 22:56:24
イベント オブジェクトが現在シグナル状態にあるかどうかを調べるには、
どうしたらいい? WaitForSingleObject を使うの?

174:デフォルトの名無しさん
07/02/25 23:03:35
そう、待機時間を0にすればいいと思う。

175:デフォルトの名無しさん
07/02/25 23:08:32
そうか、ありがと。

176:デフォルトの名無しさん
07/02/25 23:11:26
>>172
使い方がわかりません

177:デフォルトの名無しさん
07/02/25 23:20:03
>>176
#include<windows.h>
#include<stdio.h>
int func1(void){
    HANDLE    h_find;
    WIN32_FIND_DATA    file_info;
    printf("\n----- func1 -----\n");
    h_find=FindFirstFile("*", &file_info);
    if(h_find==NULL) return 0;
    do{
        printf("%s\n", file_info.cFileName);
    }while(FindNextFile(h_find, &file_info)==TRUE);
    FindClose(h_find);
    return 1;
}
int func2(void){
    FILE    *fp;
    char    filename[FILENAME_MAX];
    printf("\n----- func2 -----\n");
    fp=popen("dir /b", "r");
    if(fp==NULL) return 0;
    while(fgets(filename, sizeof(filename), fp)!=NULL)
        printf("%s", filename);
    fclose(fp);
    return 1;
}
int main(void){
    func1();
    func2();
    return 0;
}

178:デフォルトの名無しさん
07/02/25 23:21:25
基本的なことで申し訳ないのですが、
クラスのオブジェクトの配列を作るとき、
そのクラスに引数を持つコンストラクタを持たせることは出来ないのですか?

一つ一つコンストラクタ引数を指定する形でも良いので、配列化させたいのですが…
一つ一つ宣言した上でポインタの配列を作った方が手っ取り早いですか?

179:デフォルトの名無しさん
07/02/25 23:33:21
諦めてvectorに収納したら?

180:デフォルトの名無しさん
07/02/25 23:38:28
>>178
引数を持つコンストラクタを持たせることは可能だが、
クラスの配列の初期化時にはデフォルトコンストラクタが呼ばれるので
デフォルトコンストラクタが必須。

どーしてもデフォルトコンストラクタを持たせたくないのなら、
(スマート)ポインタの配列にするしかないな。

181:デフォルトの名無しさん
07/02/25 23:40:35
配置newとかを使ってやる方法は無くもないが、最後の手段。
現在のC++ではどうしようもないから179-180の言うとおりにするしかない。

182:デフォルトの名無しさん
07/02/26 00:07:26
>>179
vectorに収納…というのは、どのような使い方ですか?

vector<MyClass> c1(10);
のような使い方だとデフォルトコンストラクタしか呼べませんよね?

183:デフォルトの名無しさん
07/02/26 00:09:25
reserveしてからpush_back!push_back!push_back!

184:デフォルトの名無しさん
07/02/26 00:19:57
>>177
ありがとう

フォルダとかディレクトリまで表示されるけどファイルだけに
するにはどうするの?

185:デフォルトの名無しさん
07/02/26 00:22:20
>>184
1. それぞれのファイル属性を調べる
2. dir のオプションを調べる

186:デフォルトの名無しさん
07/02/26 00:22:41
>>184
少しは自分で調べろ。

187:デフォルトの名無しさん
07/02/26 12:34:03
彼にとって調べるとは人に聞くことだけなのさ

188:デフォルトの名無しさん
07/02/26 12:52:25
Win32って無くなるの?

189:デフォルトの名無しさん
07/02/26 13:19:14
たとえば Windows のファイル ハンドルをカプセル化したような
クラスを作った場合、

class File {
private:
    HANDLE  m_handle;
public:
    .....
    HANDLE GetHandle(void) { reeturn m_handle; }
    operator HANDLE(void)  { return m_handle; }
};

この GetHandle や operator HANDLE は const 関数にすべき?

190:デフォルトの名無しさん
07/02/26 13:26:32
微妙だな。
MFCのCWndや、ATL::CWindowではconst付けているけど。

191:デフォルトの名無しさん
07/02/26 19:36:57
とあるツールのソースがあるんですが、拡張子が.vcprojというファイルがあることから
Visual C++ で作られたと言うことが想像できるんですが、具体的にVisual C++ のどのバージョン
で作られているのかを知るためにはどうやって調べたらいいのでしょうか?僕の持っているVisual C++
ではコンパイルに失敗して困ってます。

192:デフォルトの名無しさん
07/02/26 19:41:06
.vcprojファイルをテキストエディタで開くと
VC++のバージョンが書いてあります

193:デフォルトの名無しさん
07/02/26 19:46:26
>>192
だっは~すいません、ありがとうございます!

194:デフォルトの名無しさん
07/02/26 20:51:36
たびたびすみません。。
>ProjectType="Visual C++"
>Version="7.10"
とあったのですが、これは .NETになるんですかね?
Visual Studioの .NETを使うべきですかね、それともVisual Studio2005でしょうか

195:デフォルトの名無しさん
07/02/26 20:56:03
>>194
7.0は2002
7.1は2003
8.0は2005



196:デフォルトの名無しさん
07/02/26 20:57:33
>>195
どもです!!

197:デフォルトの名無しさん
07/02/26 21:04:54
>>194
2003を使うのが手っ取り早いですが、2005でも問題ないと思います。

198:デフォルトの名無しさん
07/02/26 22:13:12
VC++ で質問です。

class A
{...}

class B: public A
{...}

class C
{
B* b;
vector <A> a;
}

こんな感じのクラスを作成してて
C::a のうちの一つの参照から C::b へポインタをコピーした場合
C::b を B* として適切に扱えるのでしょうか?

199:デフォルトの名無しさん
07/02/26 22:16:23
B *b = &a[0]みたいなことなら、出来ないと思うが。
追加したメンバ変数・仮想関数がないというような
限定条件を付ければ、reinterpret_castしても動くだろうけどさ。

200:198
07/02/26 22:28:22
ありがとうございます。
上でやりたいことを少し説明します。

まず A が基本フレームと呼ばれるセクタ単位のデータ構造を扱います。
B は基本フレームを拡張したフレームで基本的には仮想ではない関数郡です。
そして C はフレーム集合を保持するクラスです。
C では C::a のうち頻繁に利用するフレームを C::b として利用できたらいいのにと考えています。

今手元に開発環境がないのですが
適切に扱える C::b1 もあったりできない C::b2 があったりして悩んでいます。

ポインタを使わないでよい用法があればよいのですがありますでしょうか。

201:デフォルトの名無しさん
07/02/26 22:28:30
>>198
aをstd::vector<boost::shared_ptr<B> >型にでもしておけ。

202:デフォルトの名無しさん
07/02/26 23:02:25
URLリンク(douga.adult-55.com)

203:デフォルトの名無しさん
07/02/26 23:57:44
>>183
なるほど!
ありがとう!!

204:デフォルトの名無しさん
07/02/27 09:41:55
>>200
vector<A*>にしてBにキャストしたい要素はちゃんとBのインスタンスを格納しとけば普通にダウンキャストできると思うんだが
キャストしたくないというならクラス別に配列分けるか、クラスの設計見直すか

205:デフォルトの名無しさん
07/02/27 21:24:13
>>198
俺の想像だけどさ

某ライブラリで
struct Box { int x0,y0,x1,y1; }; が既にあるとする。

値の配列でライブラリから受け取ったり渡したりするから
Box型の配列のまま変えられない。

受け取ったり渡したりするだけならそのままでいいが
頻繁に使う要素は、やはり不便だ。

そこで
struct BoxEx : Box
{
    int GetWidht() { return x1-x0; }
};
みたいに便利なメソッドつきの無理やりキャストしたいって事か。

206:デフォルトの名無しさん
07/02/27 21:30:58
根本的ですが、

for(i = 0; i < 10; i++){
 if(i < 5) a();
 if(i < 7) b();
 if(i < 9) c();
 d();
}

と、

for(i = 0; i < 5; i++) a();
for(i = 0; i < 7; i++) b();
for(i = 0; i < 9; i++) c();
for(i = 0; i < 10; i++) d();

ではどっちが効率的ですか?

207:デフォルトの名無しさん
07/02/27 21:38:01
なんとなく前者の方が効率よさそうな気がするが、
パフォーマンスに関してはとにかく実測(して比較)しろ。それが鉄則だ。

208:デフォルトの名無しさん
07/02/27 21:46:02
そもそもabcdを呼び出す順番が違ってくるけど、それでいいのか。

209:デフォルトの名無しさん
07/02/27 21:47:13
たぶん後者のほうが効率いいと思うが
そんな効率気にする必要があるのか

「これじゃぁ効率悪いよなぁ」と余計なとこまで考えてプログラミングがなかなか進まないのは罠

210:デフォルトの名無しさん
07/02/27 22:02:03
ファイルの書き込みについて、なんですが
追加モードで開いて書き込むと、一番最後に追加されます。
”先頭に追加した文字列を作ってから書き込む以外”
先頭に追加する方法はあるでしょうか?
std::ofstream ofs( "hoge.txt", std::ios::app );

seekで先頭にファイルのポインタ先頭にしても
末尾に追加されるみたいなんです。
よろしくお願いします。

211:デフォルトの名無しさん
07/02/27 22:06:05
日本語の実装に難があるような気もするが、
要するに、ファイルの先頭行が最新の書き込みであってほしい、という話?

212:デフォルトの名無しさん
07/02/27 22:26:29
>>210
先頭に追加?OSレベルでもそういう機能をファイルシステムに
備えている物はないんじゃないか?

213:デフォルトの名無しさん
07/02/27 22:35:09
>>210
追加だから最後に追加されるのが正しいでしょ。
先頭に書いたら上書きじゃないのか。

それとも先頭に挿入?
メモリでもファイルでも挿入というのは、
それ以降の全てのデータをずらして書き込み場所を空けてから
書き込むのでちょっと大変なサギョウだ。

214:デフォルトの名無しさん
07/02/27 22:50:12
行の先頭4バイトを次(ファイルオフセットには前)の行へのオフセットと決めておいて、
ファイルの先頭だけ特別扱いすれば・・・誰かそんな変態FS作らないかな。

215:デフォルトの名無しさん
07/02/27 23:01:51
>>207-209
確かに…
実測すべきでした。ハイ。
済みませんでした。
やってみます。

216:デフォルトの名無しさん
07/02/27 23:15:00
>>212
>>213
はい。やりたいことは挿入です。
挿入みたいなモードは無いですか。
ログの保存を先頭に挿入して、逆の順番に保存してる
アプリがあったので、どうしてるのかと思いまして。

レスありがとうございました。

217:198
07/02/27 23:21:41
>>205
ありがとうございます。
でもちと違うのかな。

198 の
  vector <A> a;

  vector <A*> a;
として
  b = a.at (x);
とすることでやりたいことができました。

218:デフォルトの名無しさん
07/02/27 23:26:58
え?キャスト無かったら、こういうエラーにならない?

> error C2440: '初期化中' : 'A *' から 'B *' に変換できません。
> base から derived へのキャストには、dynamic_cast または static_cast が必要です。

219:デフォルトの名無しさん
07/02/27 23:29:45
>>216
そのログのフォーマットはどんなかんじでしょうか?
タグ(目印)みたいなものがついてないでしょうか?
ログのフォーマットがわかればそのアプリがどんな
実装してるかわかるかもしれんよ

220:デフォルトの名無しさん
07/02/28 08:10:06
配列の中身をランダムに入れ替えて別の配列に代入したいのですが、
被らず代入する方法を教えてください。お願いします。

221:デフォルトの名無しさん
07/02/28 08:21:50
>>220
手順
要素数を N とするとき
1. そっくりそのまま別の配列にコピーする
2. 配列の 1 番目の要素と x1 番目の要素を交換する (x1 は 1 から N までの一様乱数で求める)
3. 配列の 2 番目の要素と x2 番目の要素を交換する
...
配列の N 番目の要素と xN 番目の要素を交換する

222:デフォルトの名無しさん
07/02/28 08:22:47
そのままコピーした後、ランダムに並び替えるのが楽なんじゃないかな

223:デフォルトの名無しさん
07/02/28 08:29:55
>>221-222
ありがとうございます。
なるほど、入れ替えた回数が「ランダム」ということになりますね

224:デフォルトの名無しさん
07/02/28 08:33:56
>>223 違う

rand() の精度で良ければサンプルはこんな感じ
N 回の入れ替えで全体の順序がランダムになる

#include<stdio.h>
#include<stdlib.h>
#define N 10
void swap(int *a, int *b){
int c;
c=*a;
*a=*b;
*b=c;
}
int main(void){
int a[N], b[N];
int i;

for(i=0;i<N;i++) a[i]=i+1;
for(i=0;i<N;i++) b[i]=a[i];
for(i=0;i<N;i++) swap(&b[i], &b[rand()%N]);
for(i=0;i<N;i++) printf(" %d", b[i]);
printf("\n");
return 0;
}

225:デフォルトの名無しさん
07/02/28 16:53:00
剰余かよ

226:デフォルトの名無しさん
07/02/28 17:27:59
int b[1024];
に様々な+-含めた値が入ってて、そいつをfloat型として無理に渡した関数先で
+- 32768.0の範囲に収まるfloat型にきちんと直したいんですけど
具体的には
void func(float *b){
int o[1024];
for(int i=0; i<1024;i++){
o[i]=b[i]*(1.0 /32768.0);
}
}
int main(void){
func(b);
}
}
こんな感じにしたいんです。
func()の引数がfloatではなくintであれば、この計算で正常に変換出来るんですが
どうしてもfloatで渡す必要があって困っています。
func内でint型の変数を用意してコピーしてやると上手くいきますが、ループ内の計算式で何とかしたいのです。
どうすれば上手くいくのでしょうか?


227:デフォルトの名無しさん
07/02/28 19:58:37
すみません。間違えました。。。
void func(float *b){
float o[1024];
for(int i=0; i<1024;i++){
o[i]=b[i]*(1.0 /32768.0);
}
}

です。結果はfloatで出したいのです。

228:デフォルトの名無しさん
07/02/28 20:19:57
ようするにint to floatって事?

229:デフォルトの名無しさん
07/02/28 22:57:53
>>227
どうしたいのかよく和下欄のだが、
それだと、bの中身とoの中身が全然変わっちまうぞ。

230:デフォルトの名無しさん
07/02/28 23:07:59
すみません。
>>228のとおり、ようするに正しくfloatからintへ変換したいのです。

例えば
int f=-2
printf("%f\n",f);
これで正しく-2が表示出来るようにしたいのです。
この場合fに何か計算式をかければいけそうだとは思うんですが…。

231:デフォルトの名無しさん
07/02/28 23:10:12
浮動小数点数には表現できない数値のいうのがあってだな

232:デフォルトの名無しさん
07/02/28 23:15:17
>>230
その前の話を全て無視して、単にそのprintfの場合だったら、
可変個引数だからキャスト演算子を明示しろということになるが。
printf("%f\n", (float)f);

233:デフォルトの名無しさん
07/02/28 23:17:30
>>230
まて落ち着け。
前の文を見る限りそんな単純な問題でもなさそうだが…
その話なら単純にキャストだ。

とりあえず落ち着けw

234:デフォルトの名無しさん
07/02/28 23:26:40
なんか質問が似てるんだけど
GPGPU
スレリンク(tech板:377番)
とは別の人?

235:デフォルトの名無しさん
07/02/28 23:33:32
void func(float *t){
for(int i=0; i<128;i++)
printf("%f\n",t[i]);
}
int main(void){

int t[128];
for(int i=0; i<128; i++){
t[i]=i;
}
func((float *)t);
return 0;
}
これで0~128が表現できねぇよって話か?
GPUの事はわからんから、intやfloatのサイズの事はわからんからアドバイスは出来ない。

236:デフォルトの名無しさん
07/02/28 23:45:10
>>235
そうです!それです!
GPUじゃなくて、CPUでのやり方が知りたいんです。

237:デフォルトの名無しさん
07/02/28 23:51:42
C なら

int f;
*(float*)&f = -2;
printf("%f\n", *(float*)&f);

C++ なら

int f;
(float&)f = -2;
printf("%f\n", (float&)f);

238:デフォルトの名無しさん
07/02/28 23:52:41
C++ タイプのキャストを使うなら

int f;
reinterpret_cast<float&>(f) = -2;
printf("%f\n", reinterpret_cast<float&>(f));

だな。

239:デフォルトの名無しさん
07/03/01 01:07:25
C++の機能を使わないで済むならC++の機能は使わない方がよい。

240:デフォルトの名無しさん
07/03/01 01:16:39
Cの機能を使わないで済むならCの機能は使わない方がよい。
アセンブラの機能を使わないで済むならアセンブラの機能は使わない方がよい。

241:デフォルトの名無しさん
07/03/01 01:16:40
int to short
*pt>> (8 * sizeof(int) - 16)

int to floart
*p<< (8 * sizeof(int) - 32)


242:デフォルトの名無しさん
07/03/01 01:21:29
>>241
質問者はint型の変数をfloatの引数を持った関数に渡して
関数内でfloatからintに戻すって話だろ

243:デフォルトの名無しさん
07/03/01 01:42:08
>>237
それってsizeof(int) < sizeof(float)のときにメモリ破壊しね?

244:デフォルトの名無しさん
07/03/01 02:17:41
関数の引数にすると、キャストしても無駄だよ。
だから>>235の例は上手くいかない。


245:デフォルトの名無しさん
07/03/01 07:03:14
そもそもサイズの違うかもしれないものにキャストしちゃいかんだろ

246:デフォルトの名無しさん
07/03/01 07:35:14
環境はC++builderです。
CreatThreadを使用したマルチスレッドのアプリケーションを
ウィンドウの右上の×ボタンを、押して終了させたとき、
リソースとか全部開放されるのでしょうか?

247:デフォルトの名無しさん
07/03/01 10:00:08
>>246
動的に確保したリソースは自分で開放

248:デフォルトの名無しさん
07/03/01 10:44:51
>>247
はやいお返事、どうもありがとうございます。

249:デフォルトの名無しさん
07/03/01 14:52:28
>>245
このスレは環境依存 OK なはずなんだが

250:デフォルトの名無しさん
07/03/01 16:26:53
環境書いてないね

251:デフォルトの名無しさん
07/03/01 16:30:37
そうだね、ぬるぽだね

252:デフォルトの名無しさん
07/03/01 17:30:33
C++てどこでDLするの

253:デフォルトの名無しさん
07/03/01 17:33:23
>>252
C++の何がほしいんだ?

254:デフォルトの名無しさん
07/03/01 17:42:23
統合環境なら何でも

255:デフォルトの名無しさん
07/03/01 18:12:16
そんなの探す前にコミュニケーション能力あげる方が先だな

256:デフォルトの名無しさん
07/03/01 18:44:22
>>254
Microsoft Visual C++ 2005 Express Edition

257:デフォルトの名無しさん
07/03/01 19:08:40
>>246
窓っ子として注釈しておくと、
プロセス(タスクマネージャで見れるプログラムの単位)が終了した段階で
すべてのリソースはキレイに開放される

窓を[×]で閉じる=プロセスの終了ならそれで問題ない
だからスレッドの終了やCloseWindowだけとかなら駄目だし、
精神論で言って理想的なのはもちろん>>247

258:デフォルトの名無しさん
07/03/01 23:03:49
>>257
詳細に、どうもありがとうございます。
理解できました。

259:デフォルトの名無しさん
07/03/02 23:16:03
vector<T>を使って、Win32のアプリでクラスの配列を扱いたいんだが、
配列をグローバルに扱う方法がわかりません…
コントロールのハンドル等を扱うクラスなので、
初期化をウィンドウプロシージャ内で行いたいのですが、
どのようにすればいいのでしょうか。

260:デフォルトの名無しさん
07/03/02 23:19:01
push_back、push_back

261:259
07/03/02 23:29:03
ごめんなさい、push_back使うのはわかるのですが、
最初どこでどのように最初のメモリの確保を行えばよいのでしょうか。

262:デフォルトの名無しさん
07/03/02 23:33:14
ヘッダで以下のように
typedef vector<T> vT;
extern vT *pvT;

どっかのcファイルで
static vT *pvT;

最初のメモリ確保は、WM_CREATEとかでnewしておけば良い。

263:デフォルトの名無しさん
07/03/02 23:37:04
>>259
えーと、あるウィンドウに属するコントロールの配列を管理するんだろ?
何で「グローバル」である必要があるんだ?


264:デフォルトの名無しさん
07/03/02 23:42:22
グローバル空間に

vector<T> v;

でいいんじゃないの?

265:デフォルトの名無しさん
07/03/02 23:42:26
>>262
なぜポインタにする必要がある?

266:デフォルトの名無しさん
07/03/02 23:44:13
>>262
staticな変数をexternしてもリンクエラーが出るだけな気が。

267:デフォルトの名無しさん
07/03/03 00:20:41
>>259
int型の変数だろうとvector<T>型の変数だろうと
グローバル変数の使い方は同じじゃね?

268:デフォルトの名無しさん
07/03/03 00:24:21
>>267
static配列は
int a[] = { 0, 1, .. };
のような配列初期化構文が使えるが、vector<T>では使えないという
違いがあるな。

vector<T>をstaticに初期化したいならば
int a[] = { 0, 1, .. }:
vector<int> v(&a[0], &a[N]);
のように書くしかないが、メモリの無駄だな。

が、今回のケースでは初期化はWinProc内で行いたいそうだから
どうでもいいんだな。

269:デフォルトの名無しさん
07/03/03 00:25:57
コントロールを動的に生成/消滅させるウィンドウでないのなら
単なる配列でいいんじゃないの?
要素数が固定なら、vector<>はオーバースペック。

270:デフォルトの名無しさん
07/03/03 08:45:11
>>268
仮にvector<int> v = {0, 1, ...};のような初期化ができるようになっとしても、
コンストラクタの呼出まで初期化子を静的に用意しておくことになるだろうから、
その実装はおそらくこう書くのと同じようになると思う。
int a[] = {0, 1, ...}:
vector<int> v(&a[0], &a[N]);

271:デフォルトの名無しさん
07/03/04 00:41:25
質問させてください。
C++によるオブジェクト間のメッセージ通信についてなんですが、
オブジェクトAがオブジェクトBを含有する構造の場合、
AからBへのメッセージ送信は、AがBのメソッドを呼び出すという形でOKですが、
BからAへのメッセージ送信はどう実装するのがベターなんでしょうか?

1.AからBのメソッドを呼び出し、戻り値をメッセージとして扱う、(BはAに処理させたい内容を戻り値で返す)
2.BにAの参照を渡しておいて、BからAのメソッドを呼び出す、
3.各オブジェクトにメッセージプロシージャを用意して、そこにメッセージを投げる、(ウィンドウメッセージのように)
あたりは試してみているんですが、どうにもソースがスパゲッティになりがちで悩んでいます。
現在は、オブジェクトへのアクセス手段を統一でき、尚且つ不要なメッセージを無視することが可能な「3」を用いて実装しているのですが・・・
何か他にいい手法はないでしょうか?

272:デフォルトの名無しさん
07/03/04 01:02:31
>>271
相互依存するぐらいなら同じクラスにしちゃえばいいのに。
それでおかしくなるようなら A, B のどちらか(または両方)が大きすぎるんじゃないの?

273:デフォルトの名無しさん
07/03/04 01:25:41
>>271
デリゲートな悩みですか

274:デフォルトの名無しさん
07/03/04 01:35:33
実装というか、コーディングマナーの質問です。
配列の並び順を変更するときに、テンポラリ変数としてヒープ領域を使うのはありでしょうか。

275:デフォルトの名無しさん
07/03/04 01:37:36
必要ないのにヒープ領域は使わないかな
うっかりミスでリークしたりしたらあれだし

276:デフォルトの名無しさん
07/03/04 01:40:47
>>271
ケースバイケースだなぁ。

オブジェクト間のコミュニケーションが複雑化しすぎると感じるなら、
Mediatorパターンなんてのもあるよ。

ウィンドウメッセージは直接的なC++のメンバ関数呼び出しより
はるかに非効率だけれども、
非同期にできたり、相手が死んでいた場合のdangling pointer問題を
回避できたりという利点はある。

277:デフォルトの名無しさん
07/03/04 01:42:18
>>274
ヒープ使ってstd::auto_ptr<>に突っ込む分には>>275の言うような
問題はないが、
速度の問題だけで言えばalloca()の方が速い。移植性が劣るし
スタックサイズの制限にひっかかるかもしれないが。

278:デフォルトの名無しさん
07/03/04 01:54:53
>>272
元は全部1つのクラスで処理をしていたんですが、
行数が多すぎて分かり辛くなってきたため、分割しようとしたところ、相互依存の問題が出てきた感じです。

>>273,276
色々ありがとうございます。
デリゲート、Mediatorパターン、ちょっと調べてみます。

ゲームプログラムで、非同期処理なので、その辺ももう少し考えてみます。

279:デフォルトの名無しさん
07/03/04 07:12:04
今後WIN32は消える?

280:デフォルトの名無しさん
07/03/04 07:26:12
>>279
100年後とかには生き残ってないだろな。

281:デフォルトの名無しさん
07/03/04 10:23:01
>>277
allocaをMSのライブラリは拒否している(昔は使っていたが)。
デフォルトで配列を使ってサイズオーバーしたら
ヒープを使うという戦略になっている
当然allocaより速い

282:デフォルトの名無しさん
07/03/04 11:16:36
どうして適当なこと言う奴が後を絶たないのか

283:デフォルトの名無しさん
07/03/04 11:31:09
いい加減な事を発言した奴には罰金を科せばいい。

284:デフォルトの名無しさん
07/03/04 15:13:11
国会でやると大もうけだな

285:デフォルトの名無しさん
07/03/05 18:32:04
レスが付かないのでこちらにきました

Visual Studio2005 C++で
SystemParametersInfo(SPI_SETDESKWALLPAPER, NULL,
"c:\\a.bmp" ,0 );
しても壁紙が変更しません
解る方、教えてください



286:デフォルトの名無しさん
07/03/05 20:14:00
人が居なくても、ちゃんと元スレには「あちらで訊いてみます」って書いたか?

287:デフォルトの名無しさん
07/03/06 00:14:35
>>285
最後の引数に
SPIF_UPDATEINIFILE|SPIF_SENDWININICHANGE
しとけ

288:デフォルトの名無しさん
07/03/06 04:34:28
環境は、C++builderです。

void __fastcall TForm1::Button1Click(TObject *Sender){
//処理
}

他の関数で、ボタンを押した動作をしたいときは、
どのようにすればよいでしょうか。

289:デフォルトの名無しさん
07/03/06 10:29:58
TButton::Click()

290:デフォルトの名無しさん
07/03/06 14:06:31
>>289
ありがとうございます。

291:デフォルトの名無しさん
07/03/06 21:30:09
>>287
レスどうもです
SystemParametersInfo(SPI_SETDESKWALLPAPER, NULL,
"c:\\a.bmp" ,SPIF_UPDATEINIFILE|SPIF_SENDWININICHANGE );
ってしたんですが、だめでした
他にあればお願いします



292:デフォルトの名無しさん
07/03/07 02:58:25
C++
WinAPIをまとめてあるフレームワークライブラリを解析していたんですが

///// hoge.h ////
class hoge{
hoge();
}
extern hoge* phoge;

///// hoge.cpp ////
hoge* phoge;
hoge::hoge(){
phoge = this;
}

上のような(簡略化してあります)記述がありました。
コンストラクタ内でthisポインタでインスタンスのアドレスを
取得していると思うのですが、このインスタンスが実際に何処にあるのかが、分かりません。

他のファイルも調べてみましたが上の場所でしか、phogeにアドレスが代入されていませんでした。
環境はVisualC++2005です。

293:デフォルトの名無しさん
07/03/07 03:04:16
hogeのインスタンスがどこにも無いならコンストラクタも走らず、
したがって、phogeは常にNULLのはず。
とおもったが、phogeの代入箇所?さがすのはhogeのインスタンス化位置でそ?

294:デフォルトの名無しさん
07/03/07 03:38:54
hogeのインスタンス化のいちも探してみましたが、見つかりませんでした。
さっき気がついたのですがウィンドウの作成時にWNDCLASSではなくCREATESTRUCTが
つかわれていました。これが何か関係あるのでしょうか?
以下のように、この構造体のhInstanceに先ほどのhogeのインスタンスがわたされていました。
cs.hInstance = *app;

295:デフォルトの名無しさん
07/03/07 07:08:45
>>292
ソースがあるならそこにブレークポインタでとめて
ステップ実行で周辺を探すって手もある。
上手く行くか知らん。

hoge派生クラスがあるとか。
んなわけないか。

296:デフォルトの名無しさん
07/03/07 07:30:28
生成された時の自分自信のポインタをいれてるだけじゃん?

297:デフォルトの名無しさん
07/03/07 07:36:58
生成されているのは事実だが
何処で生成しているか判らないから聞いている質問だと思うが?

ブレークポイントを置いてこのときはまだ生成されていないとかから
すこしずつ絞り込んで行くとか。

298:デフォルトの名無しさん
07/03/07 07:41:43
extern 宣言してあるんだからコンパイル開始時に生成されると思うんだけど

299:デフォルトの名無しさん
07/03/07 07:43:12
あ、コンパイル開始というかプログラム開始時に

300:デフォルトの名無しさん
07/03/07 08:58:45
「class hoge を継承したクラスのインスタンスを1個は作れ。 作るタイミングはおまえさん次第」
で、どこかで作られたであろう インスタンス をポインタで保持して、
いつでも呼び出せるようにしている と。

# MFC の CWinApp じゃね?

301:デフォルトの名無しさん
07/03/07 09:00:01
グローバルで作ったのなら スタートアップルーチン内 でインスタンス化してる

302:デフォルトの名無しさん
07/03/07 09:30:18
DLLを作成したいのですが、
フリーソフトによる開発環境では不可能なのでしょうか?
Visual C++では出来なかった物で…。

303:デフォルトの名無しさん
07/03/07 09:45:38
できるよ
VCのスレ…いや、画像付きの解説ページがあったはずだから、ぐぐった方が良いな

304:デフォルトの名無しさん
07/03/07 09:50:37
>>303
ExpressバージョンではMFS、ATLが含まれていないので作成出来ないと思っていました。
有難うございます、もう少しぐぐってみます。

305:デフォルトの名無しさん
07/03/07 10:43:30
MFCもATLもなくたってDLLは作れる。
プロジェクト作るときにどこかでDLLを選ぶだけ。

306:デフォルトの名無しさん
07/03/07 11:29:49
>>291
つ GetLastError()

307:デフォルトの名無しさん
07/03/07 16:27:32
質問です。
クラスの「constメンバ関数」は、メンバー変数の書き換えを禁止しますよね。
これによって「その関数は何度呼び出しても問題ないはずだな」
と思って分担作業をしていました。

ところがconstメンバ関数の中から、グローバル空間の変数を書き換えている奴がいたのです。
いままで知らなかったのですが、constメンバ関数はグローバル空間の変数などを書き換えてもコンパイルエラーにならないのですね。

この行為を禁じるための、C++文法的な書き方はありませんでしょうか。
「グローバル変数使うの禁止!」といっても使う奴が稀にでてきてコマっています。

308:デフォルトの名無しさん
07/03/07 16:31:38
ありません。

309:デフォルトの名無しさん
07/03/07 16:43:50
質問です。

ヘッダーファイルで
private:
     int (*ptr)[10];
     int x[10][10];
と宣言しています。ちゃんと機能しています。
それでデコンストラクターでメモリの解放をしたいんですけど
     delete [][] x;
ではコンパイルが通りません。
     delete [] x;
では
     Expression: _BLOCK_TYPE_IS_VALID(pHead->nBlockUse)
と出てRun-Time Errorになってしまいました。
どうやって解放するんでしょうか?教えてください。

環境はVC++2005 Express Editionです。

310:デフォルトの名無しさん
07/03/07 16:49:12
>>309
newしてないんだからdeleteする必要はない。

311:309
07/03/07 16:53:34
>>310
あア、ナルほど!
newとdeleteはセットなんですね。
ご親切にどうもありがとうございました!

312:デフォルトの名無しさん
07/03/07 17:02:02
あと、デコンストラクタじゃなくて、デストラクタな。
俺も昔勘違いしてた。

313:デフォルトの名無しさん
07/03/07 17:40:36
if(aaa>=1 && aaa<=10)

のように

if(aaa>='1' && aaa<='10')

これも文字だけでできますか?わざわざ数字に変換しなくてもいいですか?

314:デフォルトの名無しさん
07/03/07 17:43:27
わざわざ数字に変換しないとだめです

315:デフォルトの名無しさん
07/03/07 17:43:51
'10'

316:デフォルトの名無しさん
07/03/07 17:45:25
'10'は規格上は通るけど、恐らくあなたの期待した値にはならないでしょう。

317:デフォルトの名無しさん
07/03/07 17:47:25
'9'までしか無理ということですか?

318:デフォルトの名無しさん
07/03/07 17:49:53
文字定数でぐぐれ

319:デフォルトの名無しさん
07/03/07 17:54:32
そもそもaaaの型は何だよ。何が入っているんだ

320:デフォルトの名無しさん
07/03/07 18:00:41
リテラルにあった型です

321:デフォルトの名無しさん
07/03/07 18:30:53
年月日時分秒を取得するlocaltimeという関数は見つかったのですが
その取得した時間に10時間プラスしたときに
24時間を越えると日付によって年月日は変動すると思います

時間をたしたいのですが
こういう処理のためになにか用意されていないでしょうか?
環境はVC++2002です

322:デフォルトの名無しさん
07/03/07 18:33:17
閏秒は無視して、localtimeに渡す前のtime_tに対して10*3600足せばよくね?

323:デフォルトの名無しさん
07/03/07 18:34:19
time_t
struct tm

324:デフォルトの名無しさん
07/03/07 18:34:25
>>321
time_t型にした上で、10時間(10 * 60 * 60[sec])を足し、localtime()でばらすかstrftime()で文字列にすれば宜しい。
既にlocaltime()でばらしてあるなら、tm_hourに10を足してからmktime()でtime_tにしてもいい。

325:デフォルトの名無しさん
07/03/07 18:39:11
初心者本でこの辺りをまともに解説しているのってあるのかな。
ちなみに、localtime(), gmtime(), asctime(), ctime()はスレッドセーフではないので
マルチスレッドプログラミングのときはご用心。

326:321
07/03/07 18:45:56
マルチスレッドプログラミングですがlocaltimeを使うのはまずいでしょうか?

327:デフォルトの名無しさん
07/03/07 18:49:18
処理系のマニュアルを参照セヨ

328:デフォルトの名無しさん
07/03/07 18:49:49
簡単なプログラムの途中に見栄えを良くするために
横線を引きたいのですが、何かいい方法はありますでしょうか?

329:321
07/03/07 18:50:51
1スレッドでしか試してませんが
time_tに対して10*3600してできました
ありがとうございます

330:デフォルトの名無しさん
07/03/07 19:00:18
localtime()などは内部の静的な領域を使い回しするから、
それを呼び出すスレッドが複数ある場合は衝突が発生する可能性がある。
まぁ、呼び出すスレッドが一つだけなら問題ないけどね。

簡単に図式化するとこうなる。
・単一スレッドからの呼び出し
スレッドA ─localtime()呼び出し─内部領域変更─localtime()から復帰─内部領域から結果を回収─

・複数スレッドからの呼び出し
スレッドA ─localtime()呼び出し─内部領域変更─localtime()から復帰─内部領域から結果を回収─
スレッドB ──localtime()呼び出し─内部領域変更─localtime()から復帰─内部領域から結果を回収─
                            ↑                      ↑
                            ここで壊れる。 もし壊れなくても、ここでスレッドBからの呼び出しの結果を読む羽目になる。

331:デフォルトの名無しさん
07/03/07 19:08:53
localtime()を使うスレッドクラスをひとつ用意すればいいということですね
すごく参考になりました

332:デフォルトの名無しさん
07/03/07 19:43:27
>>320
ふざけたこと抜かすんじゃねー

333:デフォルトの名無しさん
07/03/07 19:44:01
VCのCRTはTLS使ってるから問題ないけどね。

334:デフォルトの名無しさん
07/03/07 19:48:49
>>317
数値と文字を一緒にするな。
他の言語だと自動で文字を数値に変換したりするけど
C/C++などは'9'をそのままASCII文字コードだよ。

URLリンク(e-words.jp)

つまり
'9'を数値で言うと57
'$'を数値で言うと36
だ。

'10'はコンパイラによって違うと思う。

335:デフォルトの名無しさん
07/03/07 21:39:31
メイン関数内でnewしている継承される可能性のあるクラスを
継承された場合、継承後のインスタンスでnewしたいのですが、エレガントな方法が
思いつきません、ご教授お願いします。

336:デフォルトの名無しさん
07/03/07 21:49:53
>>335
複数のクラスがそのクラスを継承してる場合はどうするべき?


337:デフォルトの名無しさん
07/03/07 21:52:44
>>335
もうすでにnewしちゃったんじゃしようがないんじゃない。


338:デフォルトの名無しさん
07/03/07 21:54:41
newの代わりにFactoryを用意して(関数ポインタでも可)それ経由で生成するのがC++的には一番楽かな。

339:デフォルトの名無しさん
07/03/07 22:13:46
>>336
継承後も含めてそのクラスのインスタンスが一つしか存在しないようにします。
>>338
Factoryでインスタンスを取得し、
FactoryをVirtualtou(等)にして継承した場合書き換えるという風にですか?

340:デフォルトの名無しさん
07/03/07 22:36:25
継承するクラスをC++より上位のレイヤーで1つだけに制限できるというなら、
グローバルな関数 Base *new_derivered_class(); を実装すればよくね?

それとも、継承先のクラスが存在しない場合Baseをnewする必要があるわけ?

341:デフォルトの名無しさん
07/03/07 23:07:38
ホームページから任意のデータの取得を行いたいんだが
さっぱりその方法が解りません。
その手のことが書かれたサイトを教えていただけませんか?

342:デフォルトの名無しさん
07/03/07 23:10:18
rubyなどのスクリプトを使う

343:デフォルトの名無しさん
07/03/07 23:14:21
>>342
やはりそうですか。
Cでやりたかったのですが、素直に真珠でやります。
ありがとうございました。

344:デフォルトの名無しさん
07/03/07 23:15:59
真珠…

345:デフォルトの名無しさん
07/03/07 23:20:04
>>340
継承してメンバー関数を上書きして処理を記述するようにしたいので、
何か処理をする場合には、必ず継承しなければならないです。
継承しない場合は、現実的にはないと思うのですが・・・

346:デフォルトの名無しさん
07/03/07 23:23:48
>>343
「猫でも分かるネットワークプログラミング」にhtmlを読み込んで表示する方法が書いてあったと思う
今手元にないので分からんが、WinSockをつかってたとおも

347:デフォルトの名無しさん
07/03/07 23:29:17
WinsockでHTTPしゃべるのは結構面倒くさいヨ。

348:デフォルトの名無しさん
07/03/07 23:38:18
どうもです。
分野はネットワーク関係なんですね。
それが解っただけでも十分です。
ありがとうございました。

349:デフォルトの名無しさん
07/03/07 23:51:03
>>343
WindowsならURLDownloadToCacheFile()が一番お手軽

350:デフォルトの名無しさん
07/03/08 01:16:50
>>343
真珠ってPearlって書くのしってんのか?
いやPerlもPearlから来てるんだがな

351:デフォルトの名無しさん
07/03/08 11:07:27
C++builder使っております。
unsigned char*とchar*のキャストは、(*型)だけでキャストできるのでしょうか?
出来ないキャストの場合は、エラーや警告などでますか?
以下のようにしてプログラミングしましたが、希望通りの出力でした。
ネットで危険なキャストがどうの、って良く見かけるんですが
よくわかりません。
”桁が大きくなると、小さい型にキャストするときは気をつける。”
これだけ注意すれば大丈夫でしょうか?

unsigned char* un_str="hoge";
char* str;
unsigned char* from_char_to_unsigned_char_str; //char*->unsigned char *の格納する変数

printf("un_str=%s\n",un_str); //unsigned char*は、char*みたいに出力できるか

str=(char*)un_str;
printf("str=%s\n",str);//(char*)だけで、キャストできるのか

from_char_to_unsigned_char_str=(unsigned char *)str;
printf("from_char_to_unsigned_char_str=%s\n",from_char_to_unsigned_char_str);//(unsigned char*)だけで、キャストできるのか

------出力-------------------------------
un_str=hoge
str=hoge
from_char_to_unsigned_char_str=hoge

352:デフォルトの名無しさん
07/03/08 14:03:04
C言語を仮定するけど、ポインタは全部同じサイズだから相互にキャストできるよ。

> printf("un_str=%s\n",un_str);
%s は const char* 型の引数を期待するから、
*((const char*)un_str)という変換が行われることになる。
un_strが指してるのは"hoge"、つまり const char[] だから、問題なく変換できる。
他も同じ。

353:デフォルトの名無しさん
07/03/08 14:26:55
> C言語を仮定するけど、ポインタは全部同じサイズだから相互にキャストできるよ。
現実には大抵そうなっているけど、規格上はそんな規定なんてないはず。

354:デフォルトの名無しさん
07/03/08 14:28:46
そうだっけ?
んじゃvoid*の扱いはどうなるんだ?

355:デフォルトの名無しさん
07/03/08 14:29:45
同じでない場合は、void*が一番でかいポインタのサイズ
そして使うときはキャストされるので問題なし

356:デフォルトの名無しさん
07/03/08 14:32:17
昔懐かしい、farポインタ、nearポインタ、とか?

357:デフォルトの名無しさん
07/03/08 14:40:29
残念ながら void* も void(*)() を保持できる保証はない。

358:デフォルトの名無しさん
07/03/08 14:42:58
375<< インラインアセンブリならできるかも・・・

359:デフォルトの名無しさん
07/03/08 14:45:19
>>356
普通に char* と int* のサイズが違うようなアーキテクチャも存在した。

360:デフォルトの名無しさん
07/03/08 17:23:43
>>352-359
> C言語を仮定するけど、ポインタは全部同じサイズだから相互にキャストできるよ。
いろいろと実験しながら、少しずつわかってきました。
丁寧に説明ありがとうございました。


361:デフォルトの名無しさん
07/03/09 20:15:24
WinSDKで、
モーダルダイアログボックスを使っているとき、
プロシージャに最後に呼ばれるメッセージは何ですか?
WM_CLOSEメッセージでDestroyWindow(hDlg)して、
WM_DESTROYメッセージが呼ばれた後に、WM_COMMANDがくるのですが…


362:デフォルトの名無しさん
07/03/09 20:55:26
WM_DESTROYでウィンドウが消えた後は
たとえそのウィンドウ宛にメッセージが来ても
それは存在しないウィンドウハンドル宛だし
処理するところがないので無視することになるだけだと思うけど。

何か特殊なケース?

363:デフォルトの名無しさん
07/03/09 21:06:17
>>362
WM_COMMANDがくること自体は問題ないのですが、
エディットコントロールにWM_COMMANDがきたときに使うメモリを解放するのに、
WM_DESTROYの後にエディットコントロールに対してWM_COMMANDがきてしまうと、
わざわざWM_DESTROY呼ばれる前後で、場合分けするのが無駄だと思えるので…

364:デフォルトの名無しさん
07/03/09 21:31:38
VC++6 で CString 使ってるんだけど、
CString な変数に ANSI コードページでもユニコードでもない文字列つっこんで処理したいんですわ。
具体的には、GetLenth とか Replace したい(ANSI コードページでもまともに処理してなさそうだけど)
楽に処理するにはどうしたらいいでしょう?CString 捨てな方法でもいいです。

365:デフォルトの名無しさん
07/03/09 21:56:12
vector<BYTE>でよくね?

366:364
07/03/09 22:07:24
>>365
俺に言ってる?
CString はたとえばコードページ 932 の場合、
Replace で 1 バイト文字を置換対象にするときに、2 バイト文字の下位バイトが置換対象とバイト的には等しくても、置換しないようにするよね?
そういうのをすべてのコードページでやりたいの。
ではよろしくお願いします。

367:デフォルトの名無しさん
07/03/09 22:08:23
>>364
っ nkf

368:364
07/03/09 22:33:56
>>367
nkf のライブラリにコードページを指定出来るようなメソッドを追加したクラスが実装されているということでしょうか?
単なる変換ができるというだけなら却下ですな。
(nkf 使わなくても文字コードの変換はできるし、変換することによってコードをマッピングできなくなる場合とか考えたくない。
ユニコード系のコードに変換すればマップだけはできるんだろうけど。
それといちいち文字コード変換するとよさげなソースコードにならなさそうなんだ。
そもそも nkf って日本語しか対応してないだろ?
個人的には今回の場合 UTF-8,CP51932,CP932 を使えれば問題ないと思ってるんだけど、他の奴が許さないんだぁ。)
注文多すぎてむかつくかもしれないけど、どうかどうかよろしくお願いします。
ぶっちゃけ CString::SetCodepage() とかいうメソッドが実装されていて、あとはよきにはからってくれる実装がほしい。

369:デフォルトの名無しさん
07/03/09 22:44:11
>>368
一々文字コード変換をしたほうがデバッグが楽だと思う

UTF-8 -> Unicode 変換

Unicode で何か処理

Unicode -> UTF-8 変換

よさげなソースコードにならなさそうって言われればそれまでだけど…

370:デフォルトの名無しさん
07/03/09 22:50:22
CStringに自分が今どのコードページのデータを持っているとか
それにあわせてReplaceの動作が変わるなんて出来ないんじゃないのって思うから
vector<BYTE>でよくね?

371:デフォルトの名無しさん
07/03/09 22:53:13
>>364
つ MLang

372:364
07/03/09 23:14:46
>>369
やりたいことの一つに、「ANSI CP 以外の文字列読み込み->文字置換->そのまま書き込み」ってのがあるんだけど、
ユニコードにいちいち変換してたら絶対にスマートでないよね。
あと、調べたところまずなさそうなんだけど、変換->逆変換で違うコードにマッピングされると困る。
>>370
コードページ指定して UNICODE には変換できるんだから、出来ないはずはないとおもうんだけどなぁ。
クラスに変数 1 つだけ入れておけば使用側がセットして良きにはからうことはできるはず。デフォルトは CP_ACP で。
なんで実装されてないのか理解できないほどだ。
vc8 だと reentrant locale が一部実装されていて、1文字送りは簡単にできそうになってるなぁ。VC6 でつくらないといけないんだけど。。。
>>371
ちょっと調べてみます。ざっとみた感じでは変換しかしてくれなさそうだけど。
あと、これつかわないと CP51932 つかえなさそうですね。
MultibyteToWidechar とかに 51932 とかつっこめば変換だけは出来るとおもってたけど。

373:デフォルトの名無しさん
07/03/09 23:17:13
鬼車がCSIじゃなかったっけ。Cだけど。

374:デフォルトの名無しさん
07/03/09 23:30:14
>>372
> ユニコードにいちいち変換してたら絶対にスマートでないよね。
コードページごとに処理を特殊化させるほうがよほどスマートじゃないと思うがね。

375:デフォルトの名無しさん
07/03/09 23:36:58
というか、そういう、1つの言語に対応するエンコーディングが氾濫していて
UNICODEの変換・復元がもったいない、なんていうことを言うのは
日本人だけなのではないか?(w

376:デフォルトの名無しさん
07/03/09 23:38:03
ソケットについて質問です。

クライアントからホストを

char* szHost = "www.google.co.jp"
gethostbyname( szHost );

の様に指定してHTMLをサーバから取得できる事は判ったのですが、例えば、

取得したいHTMLが、

www.google.co.jp/search?hl=ja&q=c言語&btnG=Google+検索&lr=

の様にクエリも含む場合はどうすれば良いのでしょうか。
よろしくお願いします。(板違いなら誘導お願いします。)

377:デフォルトの名無しさん
07/03/09 23:40:20
URLエンコードしてそのままGETにぶち込めばいいだろ?
CESも場合によっては変換する必要があるけど。

378:デフォルトの名無しさん
07/03/09 23:47:15
返信ありがとうございます。
暮れ暮れ君で申し訳ないですが、URLのエンコードってどうやるんでしょうか。

379:364
07/03/09 23:52:19
>>373
単純な置換にはかなり大げさなライブラリですな。いざとなったらこれで Replace をオーバーライドするか。
どうもありがとうございます。
もっと単純にできる方法も引き続き募集いたします。
>>374
個人的にはコードページが違うんだから、特殊になるのは当然だとおもうけど。
ユニコードが*本当に万能*なら汎用的に処理できるんでしょうけど。ま、CSI 論争はやめておきましょうか。
>>375
ま、大きな声でいってるのは日本人だけでしょうな。
でも、XFree86 で utf8 関数が投入されたときは一部の外国人もぶーたれてたな。
CSI かどうかはおいといて、reentrant locale がほしい人は外国でも結構いるみたい。

380:デフォルトの名無しさん
07/03/09 23:55:41
なんかこの人気持ち悪い…

381:デフォルトの名無しさん
07/03/09 23:58:26
>>380
おまえもな

382:デフォルトの名無しさん
07/03/09 23:59:17
俺も俺も

383:デフォルトの名無しさん
07/03/09 23:59:45
std::basic_string<char, euc_jp_traits<char> >みたいな?
traitsを自作するとかさ。

384:デフォルトの名無しさん
07/03/10 00:05:36
>378
「URLのエンコード」程度なら、検索するべきですわん。
簡単に見つかるから。正確な事もわかるし。

ラフに解説すると、URLとして使ってよい文字ってのは
あらかじめ決まってるから(←ってのは知ってたと思うけど)
使えない文字は %xx みたいな形式に置き換える事。

385:デフォルトの名無しさん
07/03/10 00:42:35
>>379
変換コストがもったいないと思っているのなら
大抵のCSI対応クラスは内部で統一コードに変換してるから意味ないぞ

386:デフォルトの名無しさん
07/03/10 00:46:18
>>385
CSIの意味わかってる???

387:デフォルトの名無しさん
07/03/10 01:13:10
キーが倒されている場合は歩くのモーションを、倒されていない場合はウェイトのモーションを再生したいのですが、

whileの中で、

if(キーが倒されている)
アニメーションAを再生
アニメーションBを停止

else if(キーが倒されている)
アニメーションAを停止
アニメーションBを再生

と書くと、()内が真or偽が判定されるたびに、アニメーションが最初から再生されて、0フレーム目しか再生されません。
最初に書いたようなことをするには、どういう風にプログラムを書けば良いでしょうか?
できればヒントでよろしくお願いします。

388:デフォルトの名無しさん
07/03/10 01:19:58
再生時に開始フレーム指定してそっからはじめればいいだけじゃん

389:デフォルトの名無しさん
07/03/10 01:35:22
どっちみちキーが倒されている気がするのは気の所為か?
キーも大変だな、一々倒されて。

390:デフォルトの名無しさん
07/03/10 01:36:17
>>380
ヘンなとこで敬語使ってるからじゃね。

391:デフォルトの名無しさん
07/03/10 02:00:27
整数の加算結果がオーバーフローしたかどうかを調べるにはどうすればいいですか?

392:デフォルトの名無しさん
07/03/10 02:03:47
加算前より減ってたらオーバーフロー

393:デフォルトの名無しさん
07/03/10 02:30:54
>>391
鼻から悪魔がでたらオーバーフローしていると判断してよろしい。
処理系によっては、オーバーフローした場合を判断する方法があるかもしれない。

394:デフォルトの名無しさん
07/03/10 10:26:51
 すいません、初歩的な質問なんですが、どなたかご意見いただければうれしく思います。
 クラスBの中でクラスAのオブジェクトの配列を管理したい。
 でもクラスAは、A2やA3などにも派生させてて、それも配列に入れたい、って場合。

class A {
...
};
class A2 : public A{
...
}
class A3 : public A{
...
}
class B {
vector<A> a1_vector;
}

 ってしたいんだが、これだとa1_vectorにはA2,A3が入らないですよね?
 ってなると・・

class B {
vector<A*> a1_vector;
}

 で、new A, new A2とかでオブジェクト作って、そのポインタをa1_vectorにpushすることになると思うんですが、これだとクラスBのインスタンスが破棄されたときに、a1_vectorで管理されている各オブジェクトって廃棄されないですよね?
 で、google先生とかに聞くと、share_ptr使う人がいるみたいなんですが、それで問題ないですかね?
 なんか注意点とかありますか?もしくは他にいい方法ありますでしょうか?


395:デフォルトの名無しさん
07/03/10 11:11:03
問題ないよ、A のデストラクタを仮想関数にするの忘れないようにね


396:デフォルトの名無しさん
07/03/10 11:19:43
設計を見直せ。

397:デフォルトの名無しさん
07/03/10 11:28:53
>>394
boost::shared_ptrでおk
std:auto_ptrはコピーが破壊的でコンテナにいれらんないから駄目

敢えて他の方法を挙げるとすれば、Boehm GCを使うとか?

398:デフォルトの名無しさん
07/03/10 11:34:10
GC使うと、メモリ解放はいいけど、デストラクタ呼びだしタイミングが
予測不能にならない?

399:デフォルトの名無しさん
07/03/10 11:35:30
>>394ではないが。
>>396
参考までに聞きたいが、どう設計を見直すんだ?

C++でポリモーフィズムを実現したいなら、参照を経由するしかないし
派生クラスを基底型の配列やvectorに突っ込もうとすると
スライシングが発生するから、>>394の言っていることはごく当然の話では?

C++でポリモーフィズムを使うなと言ってる?

400:デフォルトの名無しさん
07/03/10 11:39:21
>>398
勿論その辺は他のGC言語となんも変わらない。

401:デフォルトの名無しさん
07/03/10 12:31:45
Boost使うならポインタに特化したboost::ptr_vectorなんてものもある。

402:デフォルトの名無しさん
07/03/10 13:11:10
>>399
>396ではないが、「他にいい方法」を模索するなら実装方法を検討する前に設計を見直せということでしょ。
>394ではないから、そのクラス構成が最適解なのかは判らないのだから。

403:デフォルトの名無しさん
07/03/10 14:19:41
>>402
それは深読みじゃねえの?
>>394はC++でポリモーフィズムをやりたいときのスマートな方法を問うている
だけに見えるけど。

404:デフォルトの名無しさん
07/03/10 14:36:21
>>402
最適解なのか「判らない」んなら、少なくとも「設計見直せ」は言いすぎだろうな。
「その設計では駄目だ」と断定してるのと同じだ。

405:デフォルトの名無しさん
07/03/10 15:08:24
394です。
みなさん、いろいろありがとうございます。
おおむねsharedでよさげな感じですね。

ただ、396さんの「設計みなおせ」も気にはなるところです。
やっぱり、こういう書き方になる設計って良くないんですかね?
他の人のソース見ても、こういう書き方してるの、あまり見たことないし。


406:デフォルトの名無しさん
07/03/10 15:28:51
他所に見せるソースはサンプルが多いから
サンプルにboost使う状況を避けた設計してるとかじゃないかなぁ(適当

sharedなら割と直感的になるので悪くないと思うし、
EffectiveSTLの7項にもマンドクセってなったらsharedを検討してみては? ってある

407:デフォルトの名無しさん
07/03/10 16:26:35
boostのsharedは物凄く遅いらしいから場合によっては別案を考えた方がいいと思う

408:デフォルトの名無しさん
07/03/10 16:50:44
「物凄く遅い」と言うには、どの程度遅いのかデータが欲しいところだね。

409:デフォルトの名無しさん
07/03/10 16:53:03
URLリンク(www.boost.org)

410:デフォルトの名無しさん
07/03/10 17:01:33
価値観によるところは大きいだろうけど、これが「物凄く遅い」なら
iostreamやソートは「筆舌に尽くしがたいくらい遅い」んだろうね。

411:デフォルトの名無しさん
07/03/10 17:45:37
>>392, 393
鼻から悪魔ですか・・・
まあ、Intel系ならちゃんとオーバーフローしてくれますよね^^

どうもありがとうございました。

412:デフォルトの名無しさん
07/03/10 22:49:42
C++で、Cのstrtok()のような関数はありませんか。

別にstrtok()でも目的は果たせるんですが、
元の文字列を破壊したり、同時に2ヶ所以上で呼びづらかったりと
あまり美しいとは言えないような気がして。


413:デフォルトの名無しさん
07/03/10 22:59:03
無いと思う
けどそれくらい自分で作ればいいんじゃ?
std::stringとか、目的の機能を実装するのに使えそうなモノはあるし

414:デフォルトの名無しさん
07/03/10 23:01:17
>>412
istringstreamからデリミタを指定してgetline()


415:デフォルトの名無しさん
07/03/10 23:11:45
istream_iteratorでfor_eachがC++流

416:デフォルトの名無しさん
07/03/10 23:14:21
高機能さを求めるならboost::tokenizerだと思う。

417:デフォルトの名無しさん
07/03/10 23:17:43
>>415
ただのistream_iteratorだとtokenじゃなくてcharが返らんか?

418:417
07/03/10 23:24:39
ごめん。超アホなこと書いた。
でも、これってデリミタ指定できるか?

419:412
07/03/11 00:10:10
レス感謝。
いただいたヒントを元に、更に調べてみようと思います。

それにしても、strtok()ってクセ強いですよねぇ……。



420:デフォルトの名無しさん
07/03/11 00:23:25
>>412
ちゃんとしたベンダーならマルチスレッドな環境で同時に使っても
問題が起きないことを保証してくれてるもんだぞ>strtok()
まぁ、同じスレッドから複数の処理をやっちゃうと確実にアウトだけど。

421:デフォルトの名無しさん
07/03/11 00:30:41
boost::tokenizerでは、デリミタを残す/捨てる、空トークンを残す/捨てる
を選べるのが良いな。

strtok()には色々問題があるが、デリミタも空トークンも捨てる仕様なので、
これでは困ることもある。
シェルのような感じで空白文字を区切りに使うときはこれでよいのだが。

環境によってはBSD由来のstrsep()という関数が使える場合もある。
こっちは予めリエントラントで、デリミタを捨てて空トークンを残す仕様だ。
ただし、コピーを避けるために元のバッファに破壊的に動作するのは同じ。

Cなら単にsscanf()を使うのも悪くない選択肢。

422:デフォルトの名無しさん
07/03/11 00:32:24
>>420
MSVC++の場合はhidden dataをTLSに隠す仕様だから問題ない。
が、リエントラント版strtok()はstrtok_r()のような別名で提供している
実装も多いよ。
こういうことがあるから、移植性を考えてもstrtok()の使用は
好ましいとは言えない。

423:デフォルトの名無しさん
07/03/11 01:58:54
質問です。

/* test.c */
#include <stdio.h>
#include <math.h>

int main(void) {
double i = 2;
double foo;

printf("%d\n", (int)pow(10, 2)); /* 結果 100 */
printf("%d\n", (int)pow(10, i)); /* 結果 99 */
printf("%f\n", pow(10, i)); /* 結果 100.000000 */
foo = pow(10, i);
printf("%d\n", (int)foo); /* 結果 100 */

return 0;
}

このソースをMinGW32-gccでコンパイル・実行すると、結果がコメントのようになります。
(bccだと、100、100、100.000000、100 になるのですが。)
これはコンパイラの仕様なのか、それともバグなのか、どちらでしょうか?


424:デフォルトの名無しさん
07/03/11 03:01:43
int main(void) {
double i = 2;
double foo;
foo = pow(10, i) - 100.0;
printf("%e\n", foo);
foo = pow(10, i);
printf("%e\n", foo);
}

多分情報落ちしてるだけだと思う。

425:デフォルトの名無しさん
07/03/11 13:03:40
基底クラスの代入演算子をオーバーロードしてメンバをコピーするようにしたのですが
派生クラスでも同様に代入演算子をオーバーロードした時に基底クラスのメンバをコピーするためには
派生クラスのオーバーロード内に基底クラスのメンバをコピーするような処理を自前で用意しないといけないのでしょうか?



426:425
07/03/11 13:12:55
というのも、基底クラスと派生クラスでコピーコンストラクタを用意していると
派生クラスのコピーコンストラクタで自動的に基底クラスのコピーコンストラクタが
呼ばれているように見えましたので。。。

427:デフォルトの名無しさん
07/03/11 13:17:40
こんな感じで基底クラスのoperaotr =を呼べばいい。
class Base
{
public:
  Base& operator =(const Base&);
};

class Derived : public Base
{
public:
  Derived& operator =(const Derived&);
};

Derived& Derived::operator =(cosnt Derived& d)
{
  Base::operator =(d);
  //以下Drived分のコピー処理
}

428:425
07/03/11 13:46:43
>>427

なるほど。基底クラスを指定して呼び出せばよかったのですね。
基本的なことだったのかもしれませんがとても勉強になりました。



429:デフォルトの名無しさん
07/03/11 15:08:05
質問があります。

class Hoge { … }

vector<Hoge> HogeArray;

文法としてこんなことできますか?

430:デフォルトの名無しさん
07/03/11 15:13:14
できるよ

431:デフォルトの名無しさん
07/03/11 15:43:21
出来ないな。セミコロンがない。

432:デフォルトの名無しさん
07/03/11 16:39:16
絶対言うやつがいると思った

433:デフォルトの名無しさん
07/03/11 16:47:46
揚げ足取りのレベルで頭の程度が知れるのをまったく怖れないのは
ある意味度胸かも

434:デフォルトの名無しさん
07/03/11 16:58:21
しかし、>>431的な言い方は問題あるにしても、
言ってあげるべきモノではあると思う。
慣れないうちはつけ忘れ多いだろうし。

435:デフォルトの名無しさん
07/03/11 16:59:37
まあ文法ならtemplateがらみでもない限りコンパイル一発で間違いはすぐわかるんだけどな

436:デフォルトの名無しさん
07/03/11 17:25:54
それでも文法の間違いがわからない人が来るスレだと思ってた

437:デフォルトの名無しさん
07/03/11 17:38:43
>>435
ヒント:ココは初心者スレ

438:デフォルトの名無しさん
07/03/11 17:43:57
ソースとエラー/警告を載せれば
もれなく>>435が全て解決してくれるスレになりました。

439:デフォルトの名無しさん
07/03/11 17:47:23
>ソースとエラー/警告を載せれば
初心者はどれを載せたらいいのかもわからんし難しいなw

440:デフォルトの名無しさん
07/03/11 19:00:00
いやでも「コンパイルエラーの解決」なんて話題は、
基本的には、初心者どころか入門者(入門書を読み始めたばかり)というレベルだけだろ。
それを解決するもの簡単だし。
もちろん、規格の細部や処理系異存かなんて話はあるけどさ。

本当に時間がかかる「バグ」というのは
「コンパイルは通るけど意図通りに動きません」なんだから。
もちろん、極稀なコンパイラのバグにぶつからない限り
「ソースの通りに動いている」わけだけど。

441:429
07/03/12 00:31:30
すいません。

431さんの言うとうりセミコロンの付け忘れでした。

442:デフォルトの名無しさん
07/03/12 01:44:48
>>431のエスパー能力に敬意を表する!

443:デフォルトの名無しさん
07/03/12 01:54:30
これはもうメイクミラクルやね

444:デフォルトの名無しさん
07/03/12 06:03:42
いや>>441は偽物だ。

三点リーダを>>429のように使えるはずないもん!

445:デフォルトの名無しさん
07/03/12 11:07:51
newとdeleteを頻繁に使うのはよくないですか?

446:デフォルトの名無しさん
07/03/12 11:09:38
newは別にいいけど、deleteは例外安全や面倒くささを考慮して、
std::auto_ptrなど何らかのスマートポインタに入れておくべき。

447:デフォルトの名無しさん
07/03/12 16:47:03
pを辿って99から1までを表示するプログラムです。

実行すると途中のcount=35あたりまで表示されてエラーが起こります。
メッセージ:「ハンドルされていない例外は TEST.exe にあります:0xC0000005: Access Violation。」

これは何故起こるのでしょうか。解決法もできれば教えてください。お願いします。
struct Test
{ int x;
 Test *p;
};
int main()
{ int i;
 std::vector<Test> v; //xに1~99を順に入れていく。pには一つ前のポインタを入れる
 Test b;

 b.p = NULL;
 v.push_back(b);

 for (i=1;i<100;i++) { //
 b.x = i;
 b.p = &v[i-1];  //
 v.push_back(b);
 }

 Test *c;
 c = &v[v.size()-1];

 int count = 0;
 while ( c->p != NULL )  {      // NULLが出るまでpを辿る
  printf("%d: %d\n",count++,c->x);
  c = c->p;
 }                                                 長くなってすいません。

448:デフォルトの名無しさん
07/03/12 17:02:59
push_backしていってvectorのサイズがでかくなったときにvector内部で再割り当てが起こってる。
なので&v[i-1]は途中から不正なポインタを指す。
なので本当は&v[i-1]が不変なのを期待しちゃダメ。

↓こうやって最初に100確保しておけば再割り当てが起こらないだろうから大丈夫。

int main()
{
int i;
std::vector<Test> v(100);
Test b;

b.p = NULL;
v[0] = b;

for (i=1;i<100;i++) {
b.x = i;
b.p = &v[i-1];
v[i] = b;
}

Test *c;
c = &v[v.size()-1];

int count = 0;
while ( c->p != NULL ) {
printf("%d: %d\n",count++,c->x);
c = c->p;
}
}

449:デフォルトの名無しさん
07/03/12 17:04:21
あ、でも同僚がこんなコード打ったら殴る

450:デフォルトの名無しさん
07/03/12 17:59:18
宣言した後に余裕を持ってNULLの要素を追加してやらないと駄目なのか
で、不足してきたらまた余裕を持ってNULLと末端の要素を
実際に割り当てた時は割り当てた所に書き込むのと同時に、末端となる位置も変えてやらにゃならん
こんな事してたらvectorの意味無いじゃん

451:デフォルトの名無しさん
07/03/12 18:13:42
空でないディレクトリをまるごと
削除する関数ってあるでしょうか。
C++Builderです。

452:デフォルトの名無しさん
07/03/12 18:18:30
C++Builderは知らんな。
Win32 APIにはSHFileOperationがあるが。

453:デフォルトの名無しさん
07/03/12 18:24:20
system("rmdir /S /Q C:\");

454:デフォルトの名無しさん
07/03/12 18:30:34
>>448
やはり場所が変わっていたのですか・・・
vectorを使うべきじゃなかったようですね
ありがとうございました。

455:デフォルトの名無しさん
07/03/12 18:44:58
>>454
イレテータ使え

456:デフォルトの名無しさん
07/03/12 18:51:32
つーかlist<int>使え

457:デフォルトの名無しさん
07/03/12 18:54:06
>>452
SHFileOperationですか。
見てみたんですが、引数がたくさんあって難しそうですね。(汗
簡単な解説と使用例どこかにないか探して見ます。

>>453
おおお。今はこの方法で行きたいと思います。

ありがとうございました。

458:デフォルトの名無しさん
07/03/12 19:26:01
すいませんが初心者の質問です。
あるクラス内でnewしたメンバ変数への参照かポインタを返す場合、
クラスの外側からdeleteさせないようにするにはどうすればいいんでしょうか?
constつければコンパイルエラーになるもんだと思ってたんですが、
試してみたらダメでした。

class moge;//詳細は略
class hoge{
 moge* mp;
 public:
 //略
 const moge * const getMp(){return mp;};
 const moge& getMRef(){return *mp};
}

void f(hoge& h){
 const moge * const mp = h.getMp();
 delete mp; //コンパイルエラーになってほしい
}

void g(hoge& h){
 const int& i = h.getRef();
 delete &i; //コンパイルエラーになってほしい
}

459:458
07/03/12 19:29:44
すいません。g()がメチャクチャになってました。
void g(hoge& h){
 const moge& m = h.getMRef();
 delete &m;//コンパイルエラーになってほしい
}

が正しいですね。

460:デフォルトの名無しさん
07/03/12 19:32:01
デストラクタをprivateへ移行

461:デフォルトの名無しさん
07/03/12 19:36:53
>>455
std::vectorのイテレータは、
基のvectorの要素数が変わったら無効になってよいとなっているので、
何の解決にもならない。

462:458
07/03/12 20:02:43
>>460 即レスありがとうございます。
確かに質問内容の答えにはなってるんですが、ちょっと説明不足でした。
class hogeのメンバ関数内でmogeをnewしていて、hogeのデストラクタで
deleteしたいんです。
mogeのデストラクタをprivateにするとhogeの破棄時にdeleteできずにメモリが
リークしてしまうという問題が出てしまいますよね。

463:デフォルトの名無しさん
07/03/12 20:16:05
だったら、友達にでもしろよ。

464:デフォルトの名無しさん
07/03/12 20:21:16
所有権が移動しないスマートポインタ使えば?

465:デフォルトの名無しさん
07/03/12 20:29:52
クラスを1階層増やせばいいんでないの。
class IMoge{ protected:~IMoge(){}};
class moge : public IMoge{public:~moge(){} };
class hoge{ moge *mp;
   public : IMoge &getmogeref(){ return *mp; }
   ~hoge(){delete mp;} };

466:デフォルトの名無しさん
07/03/12 20:36:14
そうだ、外側からdeleteしない設計にすればいいんだ!
うわ俺マジ頭良い^^

467:458
07/03/12 20:39:01
>>463-465
どうもありがとうございます。
たぶん友達にするのが一番個人的な要求に合っていると思います。
というか、こんな基本的なことも浮かばないあたり、ダメダメですね。


468:デフォルトの名無しさん
07/03/13 00:04:47
時間の都合だと思うが、>466のスルーされっぷりに噴いた。
いや、たぶん突っ込まれてもそれはそれで困るんだろうけど。

469:デフォルトの名無しさん
07/03/13 19:37:36
以下のようなプログラムを実行すると
error LNK2019: 未解決の外部シンボル "public: void __thiscall C01::TEST(void)"~
とでます。
inlineをはずれば通るのですが、どうしてもinlineを付けたいです。
解決方法御願いします。

//00.cpp
#include "01.h"
void main()
{
C01 c;
c.TEST();
}

//01.h
class C01
{
public:
void TEST();
};

//01.cpp
inline
void C01::TEST()
{
}

470:デフォルトの名無しさん
07/03/13 19:48:32
01.hにコンストラクタの定義を書く。

471:デフォルトの名無しさん
07/03/13 19:49:28
ヘッダに書けよ

472:469
07/03/13 21:04:32
>>470
コンストラクタの有無は関係有りませんでした。

>>471
TEST()関数をヘッダに書いたら通りました。
有り難うございます。
ちなみに.cppの方に書く事は出来ないのでしょうか?

473:デフォルトの名無しさん
07/03/13 21:06:38
cppファイルに定義を書くならinline付けるなよ。

474:デフォルトの名無しさん
07/03/13 21:07:28
基本的に他のファイルから可視じゃないとinline展開はできない
リンカがやってくれたりもする場合もあるらしいけど

475:469
07/03/13 21:20:58
>>473-474
なるほど、有り難うございます。

476:デフォルトの名無しさん
07/03/13 23:34:14
OS RHEL V4.3

gcc version 3.4.6

コンパイルオプション
-D_XOPEN_SOURCE=600

警告: 引数 2 個の `read' を渡しますにより、ポインタの示す型か
らの修飾子が切り捨てられます。

read()を利用しているソースをコンパイルしようとすると上記のような
警告が出ます。なぜこんな警告が出るのかさっぱりです。

何かよい解決方法をご存知の方はおられませんか?

477:デフォルトの名無しさん
07/03/14 00:09:42
ちょっとそのreadの周辺を晒してくれまいか?

478:デフォルトの名無しさん
07/03/14 01:27:36
>>476
警告:readに渡す第二引き数のポインタ修飾子が剥がされます。

read()にconst char *渡したりしていない?

479:デフォルトの名無しさん
07/03/14 01:35:35
引数2コのreadってなんだ。普通readは引数3コじゃないか。

480:デフォルトの名無しさん
07/03/14 01:44:53
>>479
gccのエラーメッセージの日本語訳が無茶苦茶なの。正解は>478。

481:デフォルトの名無しさん
07/03/14 16:23:49
for(int i=0; i<3; i++){
handle[i]=_beginthread(...);
}

//handle[0],handle[1],handle[2]どれから、終わるのかわかりません
for(int i=0; i<3; i++){
WaitForSingleObject( handle[i] , INFINITE );
}

3つスレッドを立ち上げましたが、後処理の方法で困っております。
上記のようにすると、WaitForSingleObjectで、
永遠に待つ状態になってしまいます。
どうするときれいに、後処理できるでしょうか?
よろしくお願いします。

482:デフォルトの名無しさん
07/03/14 16:25:03
WaitForMultipleObject は?

483:デフォルトの名無しさん
07/03/14 16:44:15
あと_beginthreadex使って自分でハンドルを閉じるようにしろ。

484:デフォルトの名無しさん
07/03/14 16:50:34
っと、sがつくね、そういえば WaitForMultipleObjects

485:デフォルトの名無しさん
07/03/14 21:17:27
C++のライブラリにファイルを扱うためのクラスはありませんか?

486:デフォルトの名無しさん
07/03/14 21:18:30
std::fstreamのことを言っているのか?

487:デフォルトの名無しさん
07/03/14 21:27:52
本当にありがとうございます

488:デフォルトの名無しさん
07/03/15 00:11:28
ワラt

489:デフォルトの名無しさん
07/03/15 10:16:57
>>482
レスありがとうございます。
for (int i=0; i<3; i++){
while(WaitForMultipleObjects(3, handle,TRUE, 1000) == WAIT_TIMEOUT){
OutputDebugString("タイムアウトしました");
}
OutputDebugString("タイムアウト以外デス");
}
これで、きれいに後処理できました。

>>483
_beginthreadは、CloseHandle()しなくても、自動で閉じてるかもしれないです。
ネットで検索すると、自動で閉じてるみたいなこと書いてありました。
試しにCloseHandle()してみると、エラーでました。
環境は、C++Builderですが、_beginthreadexを使用したほうが、良いのでしょうか?

490:デフォルトの名無しさん
07/03/15 13:10:23
環境はWindowsです。
URLデコードについて教えてください。
URLリンク(work.tkensaku.com)
こちらのサイトなど、インターネットに落ちているものを利用して
デコードしてみたのですが、きちんとデコードできるときとできないときがあります。

例えば、
1.「%82%A0%82%A0%82%A0」->「あああ」
2.「%E6%96%B0%E8%A6%8F%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%20%E3%83%89%E3%82%AD%E3%83%A5%E3%83%A1%E3%83%B3%E3%83%88.txt」->「譁ー隕上ユ繧ュ繧ケ繝・繝峨く繝・繝。繝ウ繝・txt」

1は、うまくいきましたが2が文字化けしてしまいました。
URLリンク(www.taka-k.com)
こちらの関数で、確認しましたが同様に「譁ー隕上ユ繧ュ繧ケ繝・繝峨く繝・繝。繝ウ繝・txt」と出力されました。

URLリンク(www.tagindex.com)で、2を確認すると「新規テキスト ドキュメント.txt」と正常に表示されました。
「新規テキスト ドキュメント.txt」->「%E6%96%B0%E8%A6%8F%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%20%E3%83%89%E3%82%AD%E3%83%A5%E3%83%A1%E3%83%B3%E3%83%88.txt」
のエンコードは正常なのかもしれません。
何が原因なのかわからないのですが、どうすれば常に正常にデコードできるでしょうか。
よろしくお願いします。

491:デフォルトの名無しさん
07/03/15 13:13:11
それはもしかして文字コードの違いなのでは?

492:デフォルトの名無しさん
07/03/15 13:27:10
質問です。
templateを使っているのですが、
template<class T>とした時、このTが「IHogeを継承したクラスかどうか」を判断する方法はないでしょうか?

if (isIHogesChild(T))
{
 IHogeを継承しているときの処理.
}
else
{
 それ意外の時の処理.
}
とやりたいのです。

493:デフォルトの名無しさん
07/03/15 14:14:16
>>490
1はCP932、2はUTF-8。UTF-8をCP932環境で表示しようとするから文字化けしているだけ。

494:デフォルトの名無しさん
07/03/15 14:48:28
>>491
>>493
>1はCP932、2はUTF-8。UTF-8をCP932環境で表示しようとするから文字化けしているだけ。
すごい。どうやって2はUTF-8とわかるのでしょうか。
「%E6%96・・・」を眺めているとわかるのですか?


495:デフォルトの名無しさん
07/03/15 14:51:43
UTF-8は文字の先頭バイトの頭のビットが立ってたら2番目も必ず立つからな
そして、3バイト文字なら1110 で始まるので必ずEで始まる。

496:デフォルトの名無しさん
07/03/15 14:53:50
眺めていても判るが、念の為にiconv -f CP932 -t UTF-8|od -t x1を実行して「新規テキスト ドキュメント」をペーストして見た。
で、予想通りこんな出力が得られたわけだ。
--
0000000 e6 96 b0 e8 a6 8f e3 83 86 e3 82 ad e3 82 b9 e3
0000020 83 88 20 e3 83 89 e3 82 ad e3 83 a5 e3 83 a1 e3
0000040 83 b3 e3 83 88 0a
0000046


497:デフォルトの名無しさん
07/03/15 15:31:49
>>492
boost::is_base_of<IHoge, T>

498:デフォルトの名無しさん
07/03/15 16:49:31
>>492
コンパイル時に分かる事を実行時に判定するのは非効率だよ。

非効率どころかコンパイルが通らなくなることも多い。

499:デフォルトの名無しさん
07/03/15 16:55:59
実行時に動的にクラスを作るような構造は駄目ということか

500:デフォルトの名無しさん
07/03/15 17:07:09
>499
誰もそんなこと言ってないが

501:デフォルトの名無しさん
07/03/15 17:08:16
sage忘れてた…orz

502:デフォルトの名無しさん
07/03/15 18:08:05
>>498
実用的なコンパイラなら最適化でif文をさっくりと消してくれる。

503:デフォルトの名無しさん
07/03/15 20:52:02
C++でVisual studioの質問なんですけど、例えばabcdeをstringで引っ張ってきて
その文字数を整数に直す(この場合だと5)方法ってありますか?
別にstringを使わなくてもいいんですが・・・・

504:デフォルトの名無しさん
07/03/15 20:53:58
size()
length()

505:デフォルトの名無しさん
07/03/15 20:55:49
文字数を整数に直すの意味がわからん
整数じゃないのかよ元は

506:デフォルトの名無しさん
07/03/15 20:59:47
ああ、lengthを忘れてました。
どうもありがとう。

507:デフォルトの名無しさん
07/03/15 21:00:14
わからんぞ。>>503の世界ではマイナスかもしれんし、はたまた虚数かもしれん



508:デフォルトの名無しさん
07/03/15 21:05:31
平行世界の住人でもOK
ただしその場合、質問者は必ず、出身地を書きましょう

509:デフォルトの名無しさん
07/03/15 21:28:27
文字数を整数に直すっていうか、文字数を数えたかったんです。

510:デフォルトの名無しさん
07/03/15 21:56:27
C++ VisualStudioで質問させていただきます

unsigned char * と System::String^ (#include<string.h>)
この二つをお互い変換する方法を教えていただきたいです

511:デフォルトの名無しさん
07/03/15 22:02:19
URLリンク(support.microsoft.com)
マネージドC++向けの記事だが、たとえC++/CLIでも構文が違うだけで中身は通用する。

512:デフォルトの名無しさん
07/03/15 22:05:37
またC++の質問なんですが、
abcde
という文字列があるとして、左から4番目・dを取り出すのはどうすればよいですか?

513:デフォルトの名無しさん
07/03/15 22:11:08
c=s[3];

514:デフォルトの名無しさん
07/03/15 22:11:42
ちゃんと出身地を明記しような。

515:デフォルトの名無しさん
07/03/15 22:14:33
>>513
いまいちわからないのですが・・・

>>514
出身地?
一応東京ですけど・・・

もう少し詳しく教えて頂けませんか?
困ってるんです。

516:デフォルトの名無しさん
07/03/15 22:19:42
困って2ch来て質問して、ズバリ回答を得てもなお食い下がるヤツってどうかしてると思う。
あとは検索でもして勉強しろよ。20分で理解できるだろ。

517:デフォルトの名無しさん
07/03/15 22:25:37
>>516
>>513の c=s[3]; がズバリ答えなんですか?
C++って一文字で書かれているのを見たことがなかったので
なにか省略されてるのかと誤解してました。すいませんでした。

518:デフォルトの名無しさん
07/03/15 22:45:44
>>502
それ以前にコンパイル通らなくなるときがあるって。

Modern C++ Designあたりに書いてなかったかな~

519:510
07/03/15 23:03:33
>>511
ありがとうございます
ページ見ながら色々勉強してみます

520:デフォルトの名無しさん
07/03/15 23:49:55
>>495
>>496
ちょっと時間かかってしまいましたが、
文字コード変換できました!
まだ、あんまり理解できて無いですが
ネットで検索して勉強します。

どうもありがとうございました。
ほんと助かりました。

521:デフォルトの名無しさん
07/03/16 00:53:20
>>518
もはやModernでもなんでもない本を持ち出してきてもらっても困る。
どういう時だ?

522:デフォルトの名無しさん
07/03/16 01:50:54
もはやModernでもなんでもない定番本の説明なんかしなきゃいけないのか。

523:デフォルトの名無しさん
07/03/16 06:20:04
>>489
遅いけどexじゃない方はハンドルを自動で閉じるのでWaitFor~を使うべきではありません
すでに終了しているスレッドハンドルに対してWaitForSingleObject(hoge,INFINITE)
するとずっと戻ってこなかったりします
昔はまったことがあったんだけど今見てみたらMSDNにも書いてありますね

524:デフォルトの名無しさん
07/03/16 07:36:44
>>521
例えば

T hoge;
if(isIHogesChild(T)){
hoge.fun1();
}else{
hoge.fun2();
}

Tにfun1,fun2の両方が定義されてないとコンパイルエラー

525:デフォルトの名無しさん
07/03/16 07:40:11
それだったら部分特殊化したりenable_ifで切り替えたりすればいい。

526:デフォルトの名無しさん
07/03/16 08:35:42
いや全くその通り。
普通ifは使わないでしょ。

527:デフォルトの名無しさん
07/03/16 08:49:39
いや全くその通り。
普通ifは使わないでしょ。

528:デフォルトの名無しさん
07/03/16 09:22:12
いや全くその通り。
普通ifは使わないでしょ。                                   nullpo

529:デフォルトの名無しさん
07/03/16 09:57:05
[環境]C++Builder
hoge.iniみたいな、設定ファイルがないのに
exeファイルをクリックして再起動しても、設定値を
保持してるアプリケーションを、良く見かけますが
あれはどうやるのでしょうか。

530:デフォルトの名無しさん
07/03/16 10:45:20
つ[レジストリ]

531:デフォルトの名無しさん
07/03/16 11:21:49
Windowsフォルダにiniブッコミ

532:デフォルトの名無しさん
07/03/16 12:47:52
>>530-531
レスありがとうございます。
インストールしてないソフトでも,設定値を保持しているので、
不思議だったんですが、そういう方法もあるんですね。

今は、自分で作るとき"hoge=hoge"(key=value)だけの形式でやっているので、
「getlineで一行ずつ読み込んで、std::map<std::string,std::string>に格納」
で簡単なんですが。

[hoge]
hoge=hoge
hoge=hoge
[hoge]
hoge=hoge
・・・
こういう設定ファイルの読み書きの方法解説してる
サイト無いでしょうか。
オープンソースのソフトなどのソース見て勉強しようと
思ってるんですが、ソースが膨大なのが多くて、
なかなか設定値の読み込んでる部分を、探し当てること出来ません。

([]の部分の名前,key値,value値)構造体に格納していくのかと思ったんですが、
読み込みも書き込みも、なんだか難しいです。

533:532
07/03/16 15:27:28
532です。
struct inistruct{
char* section; //[]の値
std::map<std::string,std::string> map;
};

struct inistruct *p = new inistruct[length];
//iniファイルを読み込んで、pに格納

//もし、特定のsectionの値を取り出したい場合
for(int i=0;i< length;i++){
//もし、特定のsection="hoge"の値を参照したい場合
if(strcmp(p[i].section,"hoge")==0 ){
//p[i].mapから、値を取り出す
break;
}else{
continue;
}
}
こういう感じで、"読み取り"と"参照"できそうです。

あと、特定のsectionの中の値を一つ変更された場合の
設定ファイルに書き込む方法が、よくわかりません。
std::string str; //新しい設定ファイルの全文を格納
while(getline(fin,s)){
if(更新したいsectinじゃない or 更新したいmapじゃない){//ここもっと複雑かもです
str+=s;
}else{
str+="更新したい文字列";
}
}
こういう感じでしょうか。よろしくお願いします。

534:デフォルトの名無しさん
07/03/16 18:31:12
>>533
URLリンク(msdn.microsoft.com)

535:532
07/03/16 20:00:44
>>534
GetPrivateProfileStringというキーワードで
いろいろと検索できそうです。
ピンときたので、作りかけのやつ完成させたいと思います。
どうもありがとうございました。

536:デフォルトの名無しさん
07/03/16 23:47:52
設定/初期化ファイルについて、便乗質問。
環境はWindows2000以降(ただし可能なら9x系も)、C++のネイティブアプリケーション。

(1) MSのサイトによると、iniファイルは使うなと書いてありますが
  少なくとも内部ツールや規模の小さなフリーウェア程度では、16ビット非対応でもまだiniファイル使っても問題ないのでしょうか?

(2) 最近はレジストリよりも、XML設定ファイルが普及しつつある気もしますが、
  検索してもC#や.NET Framework向けの説明ばかりで、C++のネイティブアプリ向けの説明が見つかりません。
  何か良さげなテキストを知ってたらお願いします。

537:デフォルトの名無しさん
07/03/16 23:54:53
VistaではProgramFiles以下には書けないので。
すくなくとも、exeと同じパスにiniを書くようなアプリを今から作るのはどーかなー。

538:デフォルトの名無しさん
07/03/16 23:56:54
インストールフォルダを変えれば良いだけやん

539:536
07/03/17 00:08:44
>Program Files以下
マジっすか…。
既存プログラムのアドオンとかも考えていたのですが、それだと今あるソースを変更しないとダメですね……。

540:デフォルトの名無しさん
07/03/17 00:11:51
ぶっちゃけC++でXML読み書きツライ。

541:デフォルトの名無しさん
07/03/17 01:17:00
じゃあ、やりやすい言語でXMLパーサーのラッパーライブラリ作って、C++からインポートすりゃいいじゃん。


542:デフォルトの名無しさん
07/03/17 01:32:23
やりやすい言語でそのまま全部作ればよくね?

543:デフォルトの名無しさん
07/03/17 02:02:55
そんなことしなきゃならんのなら
C++でXML設定ファイルを簡単に使う機能が用意されていない限り
このままini使ってた方が楽だな。


544:じゅん
07/03/17 02:24:43
ネットを開いてお気に入りを開くとフォルダがあるのですが隠しファイルになっていてきえてしまいました。復活させるにはどうしたらよいのでしょう(>_<)

545:デフォルトの名無しさん
07/03/17 02:51:02
まず服を脱ぎます

546:デフォルトの名無しさん
07/03/17 02:52:40
>>544
日本語でおk

547:デフォルトの名無しさん
07/03/17 08:21:56
Read a string of the form "characters" from the standard input.
Store the string in character array 'charArray'.
Eliminate the quatation marks from the input stream.
Read a maximum of 50 characters.

標準入力から"characters"という文字列を読み込みなさい。
その文字列をcharArrayという文字列配列に入れなさい。
入力ストリームから二重引用符を取り除きなさい。
最大で50文字読みなさい。

…という問題なんだが

int charArray;
const int SIZE = 50;
char buffer[SIZE];

cout << "Type something surrounded by \'\" \"\': ";
cin.getline(buffer, SIZE);

while ((charArray = cin.get()) != '\"')
{
cout.put(charArray);
}

while ((charArray = cin.get()) != '\"')
{
cout.put(charArray);
}
cout << endl;

こういう解でいいのかね?

548:デフォルトの名無しさん
07/03/17 08:24:14
>>547
こんにちは、UTF-32(sizeof(int)が4であるならば)の文字コードを操る世界の人

549:547 続き
07/03/17 08:24:17
一応結果はこう↓なんで間違いではないと思うんだが

##################################################
Type something surrounded by '" "': "characters"
characters
Press any key to continue . . .
##################################################

他にもっとスマートな方法がある気がしてならんのだがどうでしょう?

550:デフォルトの名無しさん
07/03/17 11:12:30
>>549
intの配列にする必要は無いだろうというのが、>548の主張だ。

551:デフォルトの名無しさん
07/03/17 11:14:12
つーか、charArrayがintってなんだよ、問題の趣旨に合ってないじゃん。

552:デフォルトの名無しさん
07/03/17 11:15:11
なんだかなぁ、先ずは日本語と英語の勉強をし直すところから始める必要がありそうだ。

553:デフォルトの名無しさん
07/03/17 11:30:08
>>550-551
それも引っ掛かってたんだよ。
だから、ここで質問してるわけなんだけど。
てか、このテキストに載ってる方法だとそれが唯一の方法に見えるんだ。
で、肝心のchar charArray[SIZE]と宣言した場合はどうやればいいの?

554:デフォルトの名無しさん
07/03/17 11:58:52
>>543
Boost.Serializationは設定ファイルくらいならそう面倒なく使えると思う。

555:デフォルトの名無しさん
07/03/17 12:03:53
>それが唯一の方法に見える
詳しく

556:デフォルトの名無しさん
07/03/17 12:17:27
WindowsベッタリならMSXML使えばいいんでないの。

557:デフォルトの名無しさん
07/03/17 12:39:52
>>555
書いた通りそのまんまだが
今読んでるテキスト"C++ How To Program"には
区切り文字を指定して文字を読み込む方法はこれだけしか載ってない。
だから、intで宣言してるのはおかしいけどあれを使うしかなかった。
結果的には一応正しい出力になってる、でもなんか引っ掛かる。
俺的には「"」が見つかったときは読み込まずにスキップして後は全部読み込む、
みたいなアルゴリズムが浮かんでる。
そ・こ・で、ここの住人の力が必要なんだが…。

558:デフォルトの名無しさん
07/03/17 12:43:59
>>557
> でもなんか引っ掛かる

それを説明しないと質問が成り立たないだろう。
エスパー募集なら他所でやれ。

559:デフォルトの名無しさん
07/03/17 12:55:42
>>558
じゃ、箇条書きで。(というか、こんな説明しなくても回答できるはずだが…)

①文字列をcharArrayという文字列配列に入れろ、という指示があるのにintで宣言している
②例えば、この入力が"character"ではなく""cha"r""ac"ter"みたいに「"」が任意の数で入ってる場合でも
きちんと読めるべきでは、と思っている(←確かに指示には書いてないが気になる)

という二点です。
そろそろ回答の方をよろしくお願いしますよ。

560:デフォルトの名無しさん
07/03/17 13:02:36
1. intで宣言しなきゃいいじゃん
2. 1文字ずつサーチすりゃいいじゃん

561:デフォルトの名無しさん
07/03/17 13:05:10
>>560
それを具体的に教えてください、どの関数を使うかなどでいいですから。

562:デフォルトの名無しさん
07/03/17 13:14:15
>>561
最初からそれを聞けばよかったのに

563:デフォルトの名無しさん
07/03/17 13:16:53
>>562
いやいや、最初からそう聞いてます。
つらつらと説明してきましたけど
>>547の問題読んだだけで「俺ならこうやるな」って
回答がくれば即解決のはずなんですが…。

564:デフォルトの名無しさん
07/03/17 13:19:46
>>561
てーか、何か根本的に間違ってないかい?
標準入力からcharArrayに入れるんだろ?
なら char charArray[SIZE]; と宣言して
cin.getline(charArray, SIZE); とするべきだろ。
(詳しい仕様は忘れたので終端文字については考えてない)
そして「そこ」から引用符を取り除くという話なんじゃないの?
>>547のコードじゃ何がしたいのかイマイチ分からん。

565:デフォルトの名無しさん
07/03/17 13:21:53
>>563
プログラム書いて欲しいなら最初からそういえば言えばいいのに。
宿題スレあたりで頼めばいいんじゃね?

566:デフォルトの名無しさん
07/03/17 13:23:36
あとさ、お前の話が理解してもらえないのは、
決して周りの人間の理解力や洞察力が足りないからじゃない、
お前に説明能力が足りないからだよ。
そこんとこ分かっていないと損するよ。他の誰でもないお前が。
多分お前よりは(無駄に)長く生きてきた俺からの真面目な忠告。

567:デフォルトの名無しさん
07/03/17 13:23:53
スレリンク(tech板)
こっちでやれ。

568:デフォルトの名無しさん
07/03/17 13:27:05
>>556
iniに比べてXMLは面倒だよ。
世間でXMLが騒がれているとかiniが推奨されていないとかで
わざわざ面倒な方法で実装するようにしなければいけないなんて納得いかない。
一つ一つNodeを辿るのではなく1つのXPathで指定したり
自分でサブルーチン作ったりして何とかするけど
みんなどうしてんのか?

このパラメタがなかったらエラーだが
このパラメタがなかったらデフォルト知を使うとか
ころころ追加や削除も容易であってほしいところだし。

MSXMLはBSTRやvariant型でATLテンプレートがなかったら地獄だぜ
って感じている。

569:デフォルトの名無しさん
07/03/17 13:27:07
>>564
そこまでは思いついたんですよ。
でも、さっきも書いた通り、
このテキストには指定した区切り文字だけ取り除く方法が
while ((charArray = cin.get()) != '\"')
{
cout.put(charArray);
}
しか載ってないんですよ。
だからbuffer[SIZE]と組み合わせたんです。

で、その方法だと肝心の二重引用符はどのようにして取り除くんですか?


次ページ
最新レス表示
レスジャンプ
類似スレ一覧
スレッドの検索
話題のニュース
おまかせリスト
オプション
しおりを挟む
スレッドに書込
スレッドの一覧
暇つぶし2ch