- 1 名前:デフォルトの名無しさん mailto:sage [2008/01/24(木) 14:52:45 ]
- このスレは標準C規格や規格に合致した移植性の高い記法・技法に関するスレです。
C言語初心者の初歩的な質問、GUIなどの標準Cではできない事の質問、 ソース丸投げ、宿題、書籍 などは専門の別スレッド↓があるのでそちらへ。 C言語なら俺に聞け(入門篇) Part 24 pc11.2ch.net/test/read.cgi/tech/1201083176/ 【初心者歓迎】C/C++室 Ver.47【環境依存OK】 pc11.2ch.net/test/read.cgi/tech/1200464091/ C/C++の宿題を片付けます 103代目 pc11.2ch.net/test/read.cgi/tech/1200318925/ 【書き込む前に】 ・まず問題を冷静に吟味してCの話か否かをはっきりさせてから質問しましょう。 ・質問する前には最低限検索を。 ・エラー(警告含む)が起きたのならばエラーメッセージを書きましょう。 【参考文献】 C FAQ 日本語訳 www.kouno.jp/home/c_faq/ Cプログラマ必読 ・プログラミング言語C(通称 K&R) www.amazon.co.jp/exec/obidos/ASIN/4320026926/250-7563469-9920244 【このスレのログ】 前スレ:pc11.2ch.net/test/read.cgi/tech/1190261457/ 他の過去ログ:nssearch.hp.infoseek.co.jp/clang/ 【このスレ住人としての心得】 わざとスレ違いあるいはごく低レベルな質問を繰り返して 流れを妨害する荒らしがいます。適当に誘導して放置してください。
- 197 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 13:26:26 ]
- 論理エラーまでチェックしていたら OS なんて書ける性能はでないよ。
- 198 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 15:06:53 ]
- >>195
メモリ配置の連続性要求はCとの互換性のため
- 199 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 15:08:34 ]
- >>198
連続性要求と境界チェックは別の話だっしょ。
- 200 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 15:30:03 ]
- 境界チェックしてほしいなら /RTCs を付ければいいよ。VC 以外は知らない。
- 201 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:06:54 ]
- >>199
連続性要求と境界チェックは同じだとは言っていない。 「互換性なんてどうでもいい」なら連続性要求も必要ないはずだと言いたいだけ
- 202 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:12:50 ]
- 俺のカンでは話がかみあってないな
- 203 名前:>>136 mailto:sage [2008/05/18(日) 16:13:31 ]
- >>196
VRAM サイズの配列を宣言して、VRAM のアドレスにマップできるようにすればいいだけ。 >>197 いつの時代だよ。 爺は早めに引退しとけ。
- 204 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:14:08 ]
- >>201
普通の配列の話じゃなくて std::vector の話なんだけどな。 普通の配列に関しては互換性も理由の1つだろう(それだけじゃないとは思うが)。
- 205 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:14:46 ]
- >>203
そうやってどんどん OS を重くしてるから Vista みたいに叩かれるんだよ
- 206 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:33:09 ]
- >>204
配列じゃなくてstd::vectorに連続性要求があるんだけど
- 207 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:52:19 ]
- まぁ「レガシーAPIにstd::vector渡せますか?」
というのはC++のFAQだよな 次の規格ではstd::stringもそうなるんだっけ
- 208 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 16:57:42 ]
- std::string::c_str() があるのにそんな必要あるの?
- 209 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 17:07:54 ]
- 現在のc_strはコピーが発生する可能性があってパフォーマンスに響くかもしれない。
- 210 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 17:10:49 ]
- どう考えても>193がおかしい
Cにはvectorが存在しないのだから互換性が問題になるはずがない
- 211 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 17:12:25 ]
- Cで書かれたライブラリとのバイナリ互換性とか
- 212 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 17:50:29 ]
- >>206
だから連続性要求の話なんて誰もやってないんだってば・・・。 境界チェックの話だ。
- 213 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 17:53:11 ]
- そもそもだなぁ
なんで std::string::c_str() な話がこのスレで出てくる?
- 214 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:11:46 ]
- もし境界チェックを行う必要が無いという仕様が
大昔はマシンパワーが弱かったからという問題で作られたのなら C++ を作る時に std::vector で at でも operator[] でも境界チェックをすれば良かった。 でもそうしなかったということは、それだけの問題じゃないってことだろう。 という話。
- 215 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:16:35 ]
- だからCもC++も基本的に効率側に仕様を倒すんだよ
安全性はライブラリで頑張る方針
- 216 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:22:08 ]
- そういうこと。
昔マシンパワーが弱かったからじゃなくて、 マシンパワーに関わらず効率を取るってこった。
- 217 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:31:08 ]
- マシンパワーが高くなっても 10 分かかっている処理は速い言語で 5 分にしたいよ。
アプリにもよるけど。
- 218 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:32:57 ]
- >>215
> 効率側に仕様を倒す ちゃう, 特に C に関しては高級言語だと思ってはいけない freestanding な環境でも動作可能, つか, 標準ライブラリを使用せず (libgcc とかは微妙だけど)に動作可能なバイナリを吐き出せる事も 求められている. 実際 crt.o を自前で書けば, 標準ライブラリを使わずに実行イメージを 作ることが可能(しつこいけど libgcc とかは微妙) 境界チェックに関しては微妙だけど...
- 219 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:34:22 ]
- >>212
だから境界チェックしてない理由(の1つ)に連続性要求と同じ理由は考えられないのかと 言ってるだけなんだが。 std::vectorがCにないから互換性の問題がないなら operator[]で境界チェックをやることだって互換性の問題を起こさない
- 220 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 18:39:34 ]
- >>219
連続性要求は C++98 ではなく C++03 で導入された。
- 221 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:19:52 ]
- >>203
世の中Cで書いたプログラムのターゲットは3GHzクラスばかりじゃないんだよ。
- 222 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:37:35 ]
- >193は自分のレスをもう一回冷静に読み直せ
>191はvectorの境界チェックのみの話しかしていない だからそもそも互換性や連続性の話は関係ない お前が勝手にoperator[]全般の話を持ち出したから話がかみ合ってないだけだ
- 223 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:43:16 ]
- これは俺のカンだけど
>>193はoperator[]はあらゆるオブジェクトで同じもんだと思ってるね でなきゃ互換性なんてセリフ出るはずがない
- 224 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:48:39 ]
- >>219
vectorの連続性要求の理由はそのほうが直感的かつ便利だからであってCとの互換性からではない。 なぜならvectorはCに存在しないから。C++にしか存在しないものがCとC++の間での互換性で問題になる は ず が な い 。
- 225 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:50:43 ]
- >>224 だったらスレタイ読んで出直してこい
- 226 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 19:53:11 ]
- >>225
お前はレスの流れを読むべきだな
- 227 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 21:48:21 ]
- >>221
で、それがどうかしたのか? 非常にタイトな部分には、チェックをはずせるようにしとけばいいだけだろ。 しょぼい環境の奴は、頭もしょぼいのか? (w
- 228 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 21:52:24 ]
- 仕様と処理系の区別もつかないくらい耄碌してるのか。
- 229 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 23:26:28 ]
- 「ディフォルトは検査するが、指定した部分の検査をしなくてもいいように指示できる」
と言う言語仕様にすればいいだけ。 どこに処理系の話が出てくるんだ? # 耄碌爺って他人を耄碌してると思いたがるよな。(w
- 230 名前:デフォルトの名無しさん mailto:sage [2008/05/18(日) 23:33:09 ]
- C言語の仕様は
「チェックなんて効率の悪い事はデフォルトではしない。検査は各々自己責任でやれ」 というスタンスなんだよ
- 231 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 00:14:36 ]
- 耄碌してんじゃなくて若くて無知なだけだったか。
- 232 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 00:21:52 ]
- >>230-231
はぁ? いまごろ何言ってんの? そんなこと >>192 に書いてある。 耄碌爺はちょっと前のレスすら覚えてないらしいな。 病院に行った方がいいぞ。
- 233 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 01:14:18 ]
- 話の整理
197 「Cぐらい男らしい言語じゃないとOSなんて組めないよねー」 ↑ 偏見というほどでもないがたぶん誇張 203 「そんなことはない、今のマシンのスペックなら(他の言語でも)十分いけるよ」 ↑ 正しいとは言い切れないが間違いではない 221 「そんな高スペックの環境ばかりじゃないんだよ」 ↑ ここがずれてる 203はそんな環境でCでない(チェックの厳しい)言語を使えとは言ってない 227 「低スペックな環境なら(その言語の機能で)チェック外すようにできればいいだろ」 ↑ まあ正論 230 「Cはそういう言語じゃないんだよ」 ↑ Cでない言語の話をCの話と勘違いしている というわけで話の理は203にある だが煽るのはやめろ
- 234 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 02:40:18 ]
- 自演乙、と言えばいいのか?
- 235 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 05:16:42 ]
- すっかり違う言語にかわっちゃうような機能を、オプションでつけはずし?
配列とポインタが交換可能なのはC言語の特徴ですよ。 ポインタが配列を指してるかどうかのチェックからするんですか?
- 236 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 05:47:52 ]
- ああ、そうか、>>203は最初からC言語の話なんかしてないのか。
>>233 解説ありがとう。 ということで、スレ違いだな。
- 237 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 12:44:06 ]
- C言語は最適化のヒントを与える機能を追加すれば後は拡張しなくていいよ。
C言語の役割はある程度ポータビリティーがあって可能な限り性能を出すこと。 どんなに CPU の性能が上がってもこの需要はなくならない。
- 238 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 15:40:22 ]
- できることが増えるスピードよりやりたいことが増えるほうが速いからな
- 239 名前:デフォルトの名無しさん mailto:sage [2008/05/19(月) 22:33:30 ]
- >>235
相変わらず、頭固いネェ。 > 配列とポインタが交換可能なのはC言語の特徴ですよ。 未だに配列アクセスよりポインタアクセスの方が常に速いとか 思ってるんだろうな...。
- 240 名前:デフォルトの名無しさん mailto:sage [2008/05/20(火) 06:08:38 ]
- 頭の固い人間 VS 論点がズレている人間
の対決はいつ見ても不毛
- 241 名前:デフォルトの名無しさん mailto:sage [2008/05/20(火) 10:01:59 ]
- >>239
君の脳内言語の話はスレ違いだ。
- 242 名前:デフォルトの名無しさん [2008/05/20(火) 22:05:48 ]
- C言語をはじめたばかりであまりわからないのですが、
ビットシフトはなんの役に立つのでしょうか?
- 243 名前:デフォルトの名無しさん mailto:sage [2008/05/20(火) 22:23:18 ]
- >>242
それなんてコピペ? こんな感じでよろしいか?
- 244 名前:デフォルトの名無しさん mailto:sage [2008/05/20(火) 22:27:14 ]
- おk
- 245 名前:デフォルトの名無しさん mailto:sage [2008/05/21(水) 00:41:16 ]
- >>241
反論できなくなったら、脳内言語ときたか。 だったら、>>221 あたりでそう書きゃいいと思うが、 しょせん耄碌爺には無理か。(w
- 246 名前:デフォルトの名無しさん mailto:sage [2008/05/21(水) 01:18:38 ]
- 煽るな
- 247 名前:デフォルトの名無しさん mailto:sage [2008/05/21(水) 01:38:16 ]
- >>245
>>233 >>236
- 248 名前:デフォルトの名無しさん mailto:sage [2008/05/21(水) 10:51:11 ]
- >>245
つまりこういう事だな。 「脳内言語だって気が付くのが遅せーんだyp」
- 249 名前:デフォルトの名無しさん mailto:sage [2008/05/21(水) 23:45:16 ]
- 昔の知識で煽ったら、反撃くらって撃沈しただけだろ。
- 250 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 01:22:46 ]
- 俺言語の話なんかする奴が悪いな
- 251 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 04:36:43 ]
- 俺言語君の知識は、最近のCPUは速いって事だけだったからな。
反論する余地は無いな、たしかに。
- 252 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 07:42:58 ]
- お前らも煽るな
- 253 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 10:44:54 ]
- 大勢のフリした一人だろ。煽っているのは。
- 254 名前:デフォルトの名無しさん [2008/05/22(木) 11:51:11 ]
- おやそくの一言が出ました。
- 255 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 11:55:57 ]
- お夜食?
- 256 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 12:18:30 ]
- ↓ タイプミスをプギャーして勝ち誇るAAをどーぞ
- 257 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 12:19:49 ]
- m9(^д^)
- 258 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 17:41:00 ]
- ぐぐってもプギャーの意味分からなかった。
- 259 名前:デフォルトの名無しさん mailto:sage [2008/05/22(木) 22:44:05 ]
- > 俺言語君の知識は、最近のCPUは速いって事だけだったからな。
> 反論する余地は無いな、たしかに。 にもかかわらず反論してた爺は哀れだな。(w
- 260 名前:デフォルトの名無しさん mailto:sage [2008/05/23(金) 05:38:05 ]
- いつまでも爺爺言ってる奴が根に持ちすぎてて怖い
将来犯罪起こしそうだな
- 261 名前:デフォルトの名無しさん mailto:sage [2008/05/23(金) 07:38:27 ]
- 脳内言語だと解ってからは、だれも反論なんかしちゃいないのにな。
- 262 名前:デフォルトの名無しさん mailto:sage [2008/05/23(金) 23:57:40 ]
- >>261
> 脳内言語だと解ってからは、だれも反論なんかしちゃいないのにな。 >> 反論してた 爺は日本語も不自由らしい。(w
- 263 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 01:01:27 ]
- 俺言語の話してるのに、C言語の話だと思って反論してやんのプギャー
こうですね、よくわかります。
- 264 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 01:50:10 ]
- ひっかかった、くやしいムキー。
こうですね、よくわかります。
- 265 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 02:09:10 ]
- いつまでやってんの!
- 266 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 02:26:07 ]
- ケンカはやめて(><)
- 267 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 11:46:20 ]
- 爺で検索すればいいからわかりやすいな
- 268 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 17:49:54 ]
- C89 との違いのみを完全に全て列挙したような資料ってありますか?
- 269 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 17:51:43 ]
- C89 と C99 との違い・・・です。
- 270 名前:デフォルトの名無しさん mailto:sage [2008/05/24(土) 18:03:32 ]
- 完全かどうかは知らないけど
seclan.dll.jp/c99d/ とか
- 271 名前:デフォルトの名無しさん mailto:sage [2008/05/26(月) 17:40:59 ]
- !0の値は1ですか?不定ですか?
- 272 名前:デフォルトの名無しさん mailto:sage [2008/05/26(月) 17:42:57 ]
- 1です
- 273 名前:デフォルトの名無しさん mailto:sage [2008/05/26(月) 17:49:09 ]
- ありがとう
- 274 名前:デフォルトの名無しさん mailto:sage [2008/05/26(月) 19:06:31 ]
- >>270
結構詳しいですが、完全なんですかね・・・。 何か漏れがあるとかいう話はないんでしょうか。
- 275 名前:デフォルトの名無しさん mailto:sage [2008/05/28(水) 22:52:00 ]
- 究極的にはC99の規格票買ってきて突き合わせるしかないだろ
- 276 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 12:22:33 ]
- 意味情報を利用しても、C (C89) の文法はLALR(2)ではないかという
疑問がありますので質問です。 構文規則はK&Rのものしか参照できないので、もしかしたら仕様書の ものと違うかもしれないのですが、 compound-statement: { declaration-list_opt statement-list_opt } という構文規則で、 int foo; typedef int foo; /* 型名とグローバル変数の名前空間は独立 */ void bar(void) { foo ?? /* ?? を読むまで、fooは宣言の一部であるとしてシフトするか、 文の一部であるとして、宣言を空にリダイレクションするか、決められない */ と思うのですが、間違いがどこかにありますでしょうか?
- 277 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 12:30:47 ]
- >型名とグローバル変数の名前空間は独立
この仮定が間違ってる。
- 278 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 12:57:24 ]
- 型名も変数名も全て「一般の識別子」だよ
違うのは構造体タグだろ
- 279 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 15:10:44 ]
- 識別子と言うことと、名前空間の管理は全然別の話だよ。
- 280 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 16:14:06 ]
- Cの名前空間は4種類。
・ラベル ・タグ ・メンバ ・その他すべて(typedefした型名や一般の変数の名前を含む) つまり二つのfooは同じ名前空間を持つ。 これを同じスコープ(この場合ファイルスコープ)で使ったら当然衝突する。 スコープが異なるなら識別子の優先順位と隠蔽によってまったく問題なく処理できる。
- 281 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 17:07:45 ]
- C言語 名前空間 でググルとほとんどどんぴしゃの内容が...
uyota.asablo.jp/blog/2006/08/24/497407
- 282 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 17:11:45 ]
- >>281
まちがってるなぁ そこでa a;が許されるのはスコープが違うからであって名前空間が違うからじゃない
- 283 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 20:47:48 ]
- グローバルな型名はローカル変数名でシャドウされる?
- 284 名前:デフォルトの名無しさん mailto:sage [2008/06/01(日) 21:40:28 ]
- されるよ。
- 285 名前:284 mailto:sage [2008/06/01(日) 21:43:56 ]
- たとえば、
typedef int a; a main(){ a a; a b; // error return 0; }
- 286 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 05:48:23 ]
- 型を宣言するとき
defineではなくtypedefを使わないといけない明確な理由って なんですか? 今まで普通に使ってきたけど、新人にどう説明すればいいか 悩んでいます。
- 287 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 06:04:08 ]
- >>286
typedef char * pchar; pchar a, b; sizeof(b)=? #define pchar char * pchar a, b; sizeof(b)=?
- 288 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 06:38:47 ]
- >>286
あと、たとえば型size_tを要求する関数があったとして、 #define size_t int とかやると、size_tの変数を渡してもintで宣言した変数渡しても、コンパイラには区別がつかない。
- 289 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 07:12:47 ]
- >>286
typedef char *pchar; const pchar a; → a が const #define pchar char * const pchar a; → *a が const 主にポインタ関連で困ったことになる。
- 290 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 13:46:28 ]
- >>288
もともとCのtypedefは弱いtypedefだから区別ないけどね
- 291 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 13:48:33 ]
- >>286
関数ポインタ形とか配列型だと、構文の都合上で#defineではできないってのもあるね。
- 292 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 21:08:43 ]
- defineじゃデバッグ時にこまるじゃん
- 293 名前:デフォルトの名無しさん mailto:sage [2008/06/02(月) 23:22:48 ]
- typedefにはスコープがある。
defineには無い。
- 294 名前:デフォルトの名無しさん mailto:sage [2008/06/03(火) 21:24:03 ]
- typedefにはスープがある。
defineには無い。
- 295 名前:デフォルトの名無しさん mailto:sage [2008/06/04(水) 01:19:44 ]
- define には名前空間がない。
- 296 名前:デフォルトの名無しさん mailto:sage [2008/06/04(水) 07:28:02 ]
- typedefにも名前空間はない
- 297 名前:デフォルトの名無しさん mailto:sage [2008/06/04(水) 07:44:55 ]
- 我輩には名前がない。
|

|