1 名前:ぬ ◆NUNUK382Dk mailto:sage [2007/12/27(木) 20:32:47 ] エスケープシーケンスやWin32APIなどの環境依存なものでもOK。 ただしその場合、質問者は必ず環境を書きましょう。 ※sage禁止です(と代々スレに書いてありますが自己判断で)。 【前スレ】 【初心者歓迎】C/C++室 Ver.45【環境依存OK】 pc11.2ch.net/test/read.cgi/tech/1197090562/ 【アップローダー】(質問が長い時はココ使うと便利) kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/joyful.htm
232 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 21:59:30 ] 今日はものすごく調子が悪くてとても C言語について調べる気がしないんですが。 誰かレスお願いします。
233 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:01:06 ] >>232 お前はなんについて質問したんだよw
234 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:04:47 ] www.imgup.org/iup531850.jpg
235 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:12:54 ] >>233 何かを限られた時間で作るときの目標として ゲームにこだわる必要はないんですかね。
236 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:19:07 ] >>235 どこから「ゲーム」が出てきたんだ? エスパーで答えれば 好きにしろ、人に聞くな、目標を立てるところからが勉強だ。
237 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:20:24 ] 人生相談スレではありません。
238 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 22:22:57 ] ゲームといえば、ライフゲームとスタートレックかな。
239 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 23:21:54 ] >>212 >家電製品とかのシステムもC/C++で書かれていたりするんですか? Cがほとんどだと思う。 ある程度メモリとCPUパワーに余裕があれば、C++も選択肢になるだろうな。
240 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 23:36:44 ] 組み込みはC++が多い
241 名前:デフォルトの名無しさん mailto:sage [2008/01/03(木) 23:56:36 ] 組み込みC++ってそんな贅沢させてくれるのか? Cがほとんどじゃまいか?
242 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:02:54 ] 今は組み込みも(全体的に)だいぶ性能上がってるんじゃないか
243 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:09:06 ] コンパイラさえ対応していれば使うよ。 コストなんてどちらにせよコード次第。
244 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:28:37 ] 組み込みは一回しか経験したことないけど、一応C++だったな でもnewを使わなかったし、ベターCって使い方だったけど・・・
245 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:31:15 ] 組み込み全く知らんのだけど、newを使わない事による組み込み的なメリットって何かあるのかね?
246 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:33:44 ] 例外処理省いてバイナリをコンパクトに出来るとかそのあたりかね newは例外投げるし。
247 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:34:11 ] 性能は大分上がってるけど、16bit環境も珍しくないからな。 8bitは流石に見なくなったが。(やってるところもあるだろうが。) C++でやるかどうかは、コストよりも政治的な要素が強い希ガス。 MDAツールが使える、といった明確なメリットがなければ、 Cで押し切られそうだな。
248 名前:212 mailto:sage [2008/01/04(金) 00:43:39 ] むーそうだったのですか。 ハードウェア言語?とかいうのを使っているのだと思ってました。 ありがとうございますm(_ _)m
249 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:52:48 ] >>245 メモリが少ないのでヒープが小さくなる。その結果newに失敗する可能性があるとか リアルタイムが要求される場合に遅いとか?
250 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 00:59:08 ] >>245 普通のnew/deleteは、空き領域の断片化によってメモリ不足に陥る可能性がある。 例外はコンパイルオプションいじらないと普通は投げないんじゃないかな。 代替策として、静的確保した領域にplacement newしたり、 断片化しないように制限を付けたメモリ管理を取り入れたりと、工夫してる。
251 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 01:06:50 ] 携帯電話みたいにOSが入ってる環境ならnew(mallocも)とか使うだろうけど IOから自分で実装するような組み込みならまず使わないと思うよ。 環境によっちゃRAMやスタックの使用量を監視しながらデバッグすることだってあるし。
252 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 02:10:51 ] C++で組み込みっつったらBREWとかしか思いうかばんなぁ
253 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 02:31:05 ] >>252 組込みのソフトが何で開発されたか、なんて普通表に出てこないから。 詳しくは言えないが、おまいらの目に触れるところで C++(全部ではないが)使って作られたもの知ってるよ。
254 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 05:42:17 ] 日立(ルネサス)のはC++コンパイラだったな
255 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 10:49:14 ] 【ISO/ANSI/JIS】 C言語なら俺に聞け! Part 132 pc11.2ch.net/test/read.cgi/tech/1190261457/ からの誘導で来ました。 =========== 仕様: 1. UNIXのcronみたいに特定の時間になるとある処理を実行させる 2. そのプログラム自体はdaemonとしてずっと走り続けている こういうことをLinux上でやりたいんですが、 sleepかalertを使って、 希望の時間になったかを調べ続けるしかないですかね。 何か普通はこうやるよってのあります? 1分に1回温度を測定するプログラムです。
256 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 11:15:11 ] 現在の時刻を取ってきて、Sleepで寝かせる時間を計算すれば良いんじゃないかな。
257 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 11:18:46 ] >>255 cron使うわけにはいかないの? どうしてもプログラム内で完結したいなら、alarm()かsetitimer()だろうね。sleep()でもできなくはないけど。 残念ながら、alert()なんてのは知らん。
258 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 11:19:15 ] >>256 Sleepってなんですか?
259 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 11:35:19 ] >>256-257 レスありがとうございます。 やっぱりそうなりますか。 alertじゃなくてalarmでした。
260 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 12:11:27 ] そもそもcronのソース読めばいいじゃないか
261 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 12:19:00 ] それはめんどくせえじゃん
262 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 13:27:42 ] そもそもcron使えばいいじゃないか。
263 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 14:51:41 ] >>255 引っ越す前から見てるんだけど 時間の分解能を定義してないのはなぜよ? sleep とか alam でやれば当然誤差累積だし… 精度とか確度とかって数学の時間に習わなかったか?
264 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 15:09:03 ] 何で偉そうなの?
265 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 15:19:32 ] >>263 些末な問題だから。
266 名前:255 mailto:sage [2008/01/04(金) 17:22:32 ] >>263 引っ越し前からの長期に渡る応援ありがとうございます! 精度は1秒あればOKです。 sleepにせよ、alarmにせよ、 仕掛ける前にtime_tを取ってきて、 それから逆算してやろうかなと思っててわざわざ書きませんでした。 数学は得意です。 自分で微分を発明しました(`・ω・´)シャキーン
267 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 17:39:02 ] ライプニッツもしくはニュートン乙
268 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 18:13:59 ] 凄い奴が書き込んでたんだな。しかも前スレから。
269 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 18:45:21 ] >>263 どこに引っ越したんだ?
270 名前:デフォルトの名無しさん mailto:sage [2008/01/04(金) 19:44:39 ] いや、>255が他のスレから移動してきただけのことだろ。
271 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 03:46:06 ] 度忘れしてしまったので助けて 引数にポインタをとる関数があるのだが このポインタのアドレスを自動変数のものに書き換えるのはNG このポインタに自動変数を代入するのはOK でいいんだよね
272 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 03:49:55 ] >>271 ごめん、読解できない
273 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 03:53:50 ] 寝ぼけてるから日本語でokになってしまったorz a(int* p) { int local = 10; //適当 p = &local; //NG *p = local; //これはどうだったっけ? }
274 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 03:59:04 ] >>273 //これはどうだっけ? OKだよ。 ってか、なんでこの程度の事が分からん。 //NG これの理由は説明できるか?
275 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 04:00:36 ] >>273 *p = local; //これはどうだったっけ? 問題ない pの指す領域に10の値が代入される pがもつ10の値と、localが持つ10の値は、それぞれ別の領域に格納されている状態になる
276 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 04:01:11 ] よくわからんが混乱してしまった、最近疲れてる予感orz あれだ、auto変数は関数から脱出した瞬間ナイナイされちゃうからな するとポインタpは意味の無いところを示してしまうのでエラーになるんだ
277 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 04:12:09 ] >>274-275 説明ありがとう 今日はもう休もうorz
278 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 08:30:54 ] 文字列から指定の文字列を省いて他の変数へコピー 例えば 文字列が入った変数 MOJI[]="aaabbbccc\0" 指定の文字列="bbb"だと MOJI→他の変数へaaaccc\0をコピー できれば aaabbbccc→ポインタ使ってMOJI自身をaaaccc\0に ってしたいんだけど、どのようにすればいい?
279 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 08:35:58 ] ドゥアブルポイントゥアァァァァ
280 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 08:57:36 ] strstrでbbb探してbbbのに続くバイトをヌル文字まで一文字ずつ前にコピー
281 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 09:04:56 ] void func(char * a, char const * b) { if (a == NULL || b == NULL || a[0] == '\0' || b[0] == '\0') return; char const * p = strstr(a, b); if (p == NULL) return; char tmp[strlen(a) + 1]; sprintf(tmp, "%.*s%s", p - a, a, p + strlen(b)); strcpy(a, tmp); } char MOJI[] = "aaabbbccc"; char * b = "bbb"; func(MOJI, b); 但し、"aaabbbccc\0"はナンセンスなんで"aaabbbccc"に変更済み
282 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 09:06:01 ] >一文字ずつ前にコピー 馬鹿がいる。 >char tmp[strlen(a) + 1]; c99使いがいる。 # つーか、一時領域要らないだろw
283 名前:281 mailto:sage [2008/01/05(土) 09:10:17 ] >>282 確かに一時領域要らなかった。 >>278 ってことで、訂正。これでc89でも大丈夫。 void func(char * a, char const * b) { if (a == NULL || b == NULL || a[0] == '\0' || b[0] == '\0') return; char const * p = strstr(a, b); if (p == NULL) return; strcpy(p, p + strlen(b)); }
284 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 09:13:58 ] >>283 いや、未だc89じゃ通らないし。つーか、char const * pじゃなくてchar * pだろよ。
285 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 09:28:25 ] >>283 strcpyでコピー範囲が重なってるから動作が未定義になるぞ。
286 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 09:35:26 ] さらに指定の文字列は複数回出現する可能性も有るから・・・ さらに言えば指定文字列を取り除いた後に前後の文字列がくっついて取り除くべき指定文字列になる可能性も。 ex. aabbcからabを取り除くとabcになって再度abが出現。
287 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 10:05:44 ] ありがとうstrlen使う発想がなかったから助かりました 実はURLからime.nu/を消したかっただけなんでこんな感じでまとめたみた if(NULL!=strstr(url,"ime.nu/")){ char *buf; buf=strstr(url,"ime.nu/"); url[strlen(url)-strlen(buf)]='\0'; buf+=strlen("ime.nu/"); strcat(url,buf); }
288 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 10:27:58 ] strcatも未定義動作になるから止めれ。
289 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 11:18:35 ] >>276 ポインタpも関数から脱出した瞬間ナイナイされるので安全。
290 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 11:21:28 ] strcpy()で、前方への移動ができない実装ってあるんかいな。 未定義には違いないけど。
291 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:10:38 ] >>273 >p = &local; //NG これもOKだよ よく考えろ、pもローカル変数だ
292 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:32:16 ] >>291 ほう? void TestFunc(int* p) { int x = 10; p = &x; } int main(int argc, char* argv[]) { int a; TestFunc(&a); printf("%d\n", a); return 0; }
293 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:44:20 ] >>292 そういう話をしてるんじゃないと思うが。
294 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:45:20 ] 何が「ほう?」なんだか。
295 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:52:06 ] >>292 君が何を言いたいのか分からない 要するに、そのコードがどうした? 何か問題でも?
296 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 14:59:12 ] >>292 void TestFunc(int* p) { int x = 10; p = &x; } int main(int argc, char* argv[]) { int a = 5; TestFunc(&a); printf("%d\n", a); return 0; } 出力結果 5
297 名前:292 mailto:sage [2008/01/05(土) 15:00:49 ] ごめん、俺が悪かった。物凄く勘違いしてたらしい。いじめないでくれ。
298 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:10:58 ] ローカル変数のポインタをリターンするときに注意が必要なんだっけ?
299 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:14:17 ] あれ?戻った先で使おうと思っても残ってる保証がないんぢゃ? > 298
300 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:15:17 ] そうだね。 int* f() { int a = 10; return &a; // NG } 特に構造体とか大きいものを返したいときに、 コストを避けようとしてやってしまう人もいるかも。 素直に値で返すか、引数に格納先のポインタを貰うべし。
301 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:21:00 ] そんな時のための動的確保ですよ > 300
302 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:24:48 ] >>300 動的確保するならauto_ptrですな。 std::auto_ptr<int> f() { return std::auto_ptr<int>( new int(10) ); }
303 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 15:25:07 ] ヒープ領域に確保されるからdeleteで明示的に削除しない限り開放されないってやつか ただしdelete忘れるとメモリリークが起こるから注意(´・ω・)
304 名前:デフォルトの名無しさん [2008/01/05(土) 18:52:20 ] 初歩的な質問ですいません。ポインタに関して質問です。 二次元配列の動的確保なのですが、 TCHAR hoge[5][260]; のような時に5の部分だけ動的に確保して260の方は固定したいのですが、 TCHAR *hoge[260]; hoge = (TCHAR *)malloc(sizeof(TCHAR)*260*num); のようにすると、"'char *'から'char *[260]'に変換することはできません"とコンパイルエラー吐きます。 TCHAR **hoge; で最初から動的確保を2度行う方法は分かるのですが、片方を固定した場合どのようにすべきでしょうか。
305 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 18:54:06 ] TCHAR (*hoge)[260];
306 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 18:54:47 ] hoge = (TCHAR (*)[260])malloc(sizeof(TCHAR)*260*num);
307 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 18:54:58 ] sizeof(TCHAR)*260 を sizeof(hoge) にするとどうなる?
308 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 18:55:45 ] あるいは hoge = (TCHAR (*)[260])malloc(sizeof(*hoge)*num);
309 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 19:02:05 ] typedef すると分かりやすいよ。 typedef TCHAR Path[MAX_PATH]; Path *hoge; hoge = (Path *)malloc(sizeof (Path) * num);
310 名前:304 mailto:sage [2008/01/05(土) 19:23:37 ] 即レス感謝です。 >>307 そうすると、後者の場合は戻り値が4になりました。 何故かsizeof(TCHAR)だと1でした。何故2じゃないのだろう・・・。Unicodeじゃないからかな・・・?? >>305-306 のように間接参照演算子を括弧でくくると上手くコンパイルも通り、 for(i = 0 ; i < max ; i++) hoge[i] = "test"; と動作も確認出来ました。 >>309 のようにtypedefのやり方もググって見つけたのですが、 直接的にどうやれば通るか知りたかったもので。。 やはり、typedefの方が分かりやすいですね。
311 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 19:30:57 ] 型宣言の * は間接参照演算子とは別物。
312 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 19:35:03 ] >>310 TCHARはマクロでワイド文字(wchar_t)とマルチバイト文字(char)を切り替える VCならプロパティからUnicode文字セットを使用するようにすればワイド文字になる 後"test";は_T("test");もしくはTEXT("test");って書くように。そうすれば切替の対象になるから。
313 名前:デフォルトの名無しさん mailto:sage [2008/01/05(土) 21:29:06 ] 構造体にすると見慣れた形になる。 typedef struct { TCHAR str[260]; } Path; Path* hoge = (Path*)malloc(sizeof(Path) * num); 煩雑かな。
314 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 00:18:19 ] なんて言うかポインタの配列と多次元配列へのポインタを勘違いしている様な希ガス int *p[10]だとint型のポインタが10個あるポインタの配列 int a[10][10]とかの多次元配列へのポインタなら int (*p)[10]
315 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 00:55:57 ] C言語で何か分かりやすいプログラムはないでしょうか。
316 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 00:56:34 ] helloworld
317 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 00:59:19 ] int main(){ return 0; } 多分これが一番分かりやすい
318 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 01:48:10 ] C++Builder 6でコンパイルした後 printfでテキスト文を表示したいんですけど どうすればいいんでしょうか。
319 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 01:49:48 ] エスパーが質問に答えるスレ pc11.2ch.net/test/read.cgi/tech/1187922645/
320 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 02:15:16 ] 実行すれば良いんじゃない。
321 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 02:28:04 ] 日本語をコマンドプロンプトや「メモ帳」で表示させたいです。 できれば背景が白い所に分かりやすく表示させたい。 マジレスきぼんぬ。
322 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 02:34:03 ] コマンドプロンプトの配色を「白地に黒文字」に設定
323 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 02:48:13 ] #include <stdlib.h> system( ); で、適当に コマンドの命令だが、 color F0 とか #define color(x) printf("\033[%dm", x + 30); MS使用だったかも知れないが。 system("notepad.exe puni.cpp"); 詳しくは調べて
324 名前:304 mailto:sage [2008/01/06(日) 02:57:35 ] >>314 それを観て何となく納得出来ました。 キャストが初めて観るので、もうちょっと弄ってみます。 レスくれた皆さんありがとうございました。
325 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 05:36:09 ] 動的メモリの解放がいまいちよく判りません。 以下の(A)で生成した snow は、 (B)で問題なく解放されているのでしょうか? void procMain() { Snow ***snow = NULL; int i, j; // 生成 ←(A) snow = new Snow**[10]; for ( i = 0; i < 10; i++ ) { snow[i] = new Snow*[5]; for ( j = 0; j < 5; j++ ) { snow[i][j] = new Snow(); } } // 解放 ←(B) for ( i = 0; i < 10; i++ ) { for ( j = 0; j < 5; j++ ) { delete snow[i][j]; } delete snow[i]; } delete snow; } 下2つの delete が delete[] の様な気もしますが、 判る方がいましたらよろしくお願いします。
326 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 05:49:38 ] >>321 ファイルに出力した後にそのファイルを開けばいい。 fp=fopen("test.txt","r"); fprintf(fp,"hoge"); fclose(fp); system("test.txt");
327 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 06:32:15 ] >>325 new [] 使ってるから delete [] だろうね。 こういうのはややこしくなるから、 フラットな配列にして添え字は掛け算するのがシンプルでいい。 Snow *snow = new Snow[10*5]; for (int i = 0; i < 10; i++ ) for (int j = 0; j < 5; j++ ) snow[i*5+j].xxx(); delete [] snow;
328 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 06:40:43 ] >>321 >>318 でエディションがPersonal以外ならOutputDebugString。イベントタブに出力される
329 名前:325 mailto:sage [2008/01/06(日) 08:55:02 ] >>327 レスありがとうございます。問題が解決しそうです。 どちらの delete でもコンパイルが通っちゃうから自信が持てない・・・
330 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 11:33:30 ] >>315 全然関係ないが、自分が一番最初に見たC++のサンプルはこれだ。 #include <iostream> int main(int argc, char *argv) { std::cout << "Hello World !" << std::endl; return 0; } ついでに、一番最初に聞いたクラスの説明は 猫も人もみな哺乳類なのです だ。
331 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 11:48:57 ] >>330 mainの引数もまともに書かないとは、悪いサンプルだな。
332 名前:デフォルトの名無しさん mailto:sage [2008/01/06(日) 12:42:49 ] 俺はこれだった・・・ static char _main[] = { 0x81, 0x21, ...., 0x21 } PDPほにゃらら専用とかかいてあった