[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 901- 2chのread.cgiへ]
Update time : 05/09 10:52 / Filesize : 232 KB / Number-of Response : 957
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

C言語なら俺に聞け(入門篇) Part 18



1 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 06:39:50 ]
C言語の入門者向け解説スレです。
・C++言語はスレ違いです。
・分からない事をなるべく詳しく書いて下さい。
・ソースコードを晒すと答えやすくなるかもしれません。
・質問者は最初にその質問をした時のレス番号を名前欄に書いて下さい。

前スレ
C言語なら俺に聞け(入門篇) Part 17
pc11.2ch.net/test/read.cgi/tech/1185286631/

教えて欲しいのではなく丸投げしたいならこちらへ
C/C++の宿題を片付けます 94代目
pc11.2ch.net/test/read.cgi/tech/1185452895/

2 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 06:40:23 ]
Part 1 ttp://pc8.2ch.net/test/read.cgi/tech/1146700389/
Part 2 ttp://pc8.2ch.net/test/read.cgi/tech/1153818463/
Part 3 ttp://pc8.2ch.net/test/read.cgi/tech/1160682950/
Part 4 ttp://pc8.2ch.net/test/read.cgi/tech/1162999861/
Part 5 ttp://pc8.2ch.net/test/read.cgi/tech/1165022193/
Part 6 ttp://pc10.2ch.net/test/read.cgi/tech/1167325490/
Part 7 ttp://pc10.2ch.net/test/read.cgi/tech/1170064980/
Part 8 ttp://pc11.2ch.net/test/read.cgi/tech/1171946674/
Part 9 ttp://pc11.2ch.net/test/read.cgi/tech/1173284217/
Part 10 ttp://pc11.2ch.net/test/read.cgi/tech/1174290325/
Part 11 ttp://pc11.2ch.net/test/read.cgi/tech/1176800483/
Part 12 ttp://pc11.2ch.net/test/read.cgi/tech/1178620766/
Part 13 ttp://pc11.2ch.net/test/read.cgi/tech/1179301993/
Part 14 ttp://pc11.2ch.net/test/read.cgi/tech/1181735298/
Part 15 ttp://pc11.2ch.net/test/read.cgi/tech/1182719692/
Part 16 ttp://pc11.2ch.net/test/read.cgi/tech/1184003625/

3 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 06:41:08 ]
3ゲト 1乙です

4 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 06:42:58 ]
 〇∧〃 初心者からの質問?
 / >  でもそんなの関係ねぇ!
 < \  そんなの関係ねぇ!

  〇/ はい!
 /|    オッパッピー!!
 />

ja.wikipedia.org/wiki/%E5%B0%8F%E5%B3%B6%E3%82%88%E3%81%97%E3%81%8A
> 元々「オッパッピー」は卑猥な言葉の略語だったらしいが、他の芸人にダメ出しを受けて
> 「オーシャンパシフィックピース」に変更した。

5 名前:997 mailto:sage [2007/08/16(木) 06:43:47 ]
すみません、名前変えるのわすれてました、前スレの997です
前スレの>>998さん返答ありがとうございます。その書き込み不可属性というのは
どうやったら解除できるんでしょうか?

6 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 06:46:19 ]
>>5
ファイルを右クリックしてプロパティを開く
Windowsなら読み取り専用ってチェックボックスのがある

7 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 07:13:18 ]
Cでリストとかキューとかの汎用ライブラリをガツガツ使いたかったら
C++使えってことですよね?
自分で書いても良いですけど効率悪いので...
皆さんはどうされてます?自分で全部かいてます?

8 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 07:14:28 ]
C++使う

9 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 08:17:50 ]
テンプレートがないと辛いね。
マクロでも実装はできるけど、エレガントとは言いがたい。

10 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 08:37:31 ]
>>9
Linuxでデバイスドライバかいてると
マクロで実装した汎用リストがあったりするんですが
それ使えるのはもちろんLinuxカーネルだけだから
それの汎用バージョンみたいなのないのかなぁ...っと



11 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 08:45:30 ]
そこだけ綺麗に描き直してフォークすればいいじゃん

12 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 08:47:22 ]
>>10
こんなの見つけた
www5d.biglobe.ne.jp/~noocyte/Programming/CMacros.html

13 名前:5 mailto:sage [2007/08/16(木) 17:30:09 ]
>>6 返答ありがとうございます。
また質問なのですが、Visual C++:2005 の設定を間違えて保存などした場合、
どうすれば初期設定にもどせるんでしょうか?

14 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 17:32:21 ]
C言語のスレで前スレ最後の書き込みがオッパッピー解説ってどうよ

15 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 17:56:05 ]
だが、それがいい

16 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 18:00:46 ]
正直に言えやぁ、ほまは オッパッピー がむっちゃ好きなんやろ?
男なら絶対そうやろ?隠さんでええよ、バレとるからw

17 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 19:17:35 ]
ツール → 設定のインポートとエクスポート → すべての設定をリセット

18 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 22:19:28 ]
整数Aは整数Bの何%であるか表示するプログラムのソースを教えてください。

19 名前:5 mailto:sage [2007/08/16(木) 22:23:27 ]
>>17 レスありがとう でも戻らないorz
なんかマイクロソフト公式HPに

Visual SourceSafe エクスプローラのプロジェクト ペインで削除されたファイルが所属していたプロジェクトを選択します。
[ファイル] メニューで [プロパティ] をクリックし、[削除された項目] タブをクリックします。
復元するファイルを選択します。
[復元] をクリックします。

って書いてあるけど、これどうやるんでしょうか?


20 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 22:52:50 ]
>>19
再インスコ



21 名前:デフォルトの名無しさん mailto:sage [2007/08/16(木) 23:02:08 ]
>>19
それは Visual SourceSafe がインストールされてないとどうにもならない
Visual SourceSafe エクスプローラは Visual SourceSafe の本体の一部だしな

っつーか
その「書いてあるけど、」の部分は SourceSafe の中に格納したデータを削除した時に
SourceSafe の中の「ごみ箱」的な場所からデータを復元させるための手順なんだが

この際再インスコに同意しておく

22 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 10:59:14 ]
ポインタと配列で質問なのですが、
int a[3][4];

int *p = a[0];
のように、int * 型のポインタ p を a[0] に初期化すれば、 a[i][j] は p[i*4+j]
と書いても同じことになります。ネットのポインタ説明よりコピペなのですが、
a[i][j] は p[i*4+j]この部分が良く分かりません。[i*4+j]の詳しい解説を
していただけませんか?


23 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:04:55 ]
初期化の部分はint *p = a;の間違いだと思うが、

a[3][4]は、メモリ上(?)で
a[0][0]、a[0][1]、a[0][2]、a[0][3]、a[1][0]、a[1][1]、a[1][2]、・・・・
という順番になっているから。

24 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:11:51 ]
int *p = a; のaはaの配列の先頭を指しているらしいですよ

25 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:16:54 ]
>>23 じゃあどんな高次元配列(?)でも[i][j]をポインタで表すのに[i*4+j]
と共通してるんですか?なんか悩んでる内に[i*4+j]を覚えてしまった。
分からないのならまるおぼえしてしまおうかなw

26 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:27:40 ]
まさか。その4はどこから出てきたと思ってるんだ

27 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:51:08 ]
こんにちは。次の職場で使うため、C言語の勉強をしているものです。

入門書を一通り読み、簡単なアプリも幾つか作りましたが、
今ひとつ他人のソースを追うのが苦手です。
そこで、数読んで慣れようと考えました。
もしご存知でしたら、ソースを沢山読めるサイトを教えていただきたく。

28 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 11:55:24 ]
www.google.com/codesearch?q=lang%3Ac

29 名前:22 mailto:sage [2007/08/17(金) 12:08:01 ]
配列[i][j] とすると ポインタ[i * jの要素数 + j]ですよね。
考えてもさっぱりなんで公式として覚えてしまおうと思います。

30 名前:27 mailto:sage [2007/08/17(金) 12:17:12 ]
>>28
ライブラリやフリーのソースについては、
コードリーディングという本で読んでみたのですが、
規模が大きすぎる&仕様がソースのみで、今ひとつでした。



31 名前:22 mailto:sage [2007/08/17(金) 12:23:57 ]
[i * 型の使用バイト数 * j]かもしれませんね。

32 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 12:30:03 ]
>>31
冗談だろwww

a[0][0]、a[0][1]、a[0][2]、a[0][3]、a[1][0]、a[1][1]、a[1][2]、・・・・
==a[0] 、==a[1] 、==a[2] 、==a[3] 、==a[4] 、==a[5] 、==a[6] 、・・・・
あとは分かるよな?

33 名前:22 mailto:sage [2007/08/17(金) 12:58:27 ]
なるほど、そういうことっすか。ポインタに配列を代入した場合、
2次元配列をポインタでを表す場合、感覚で言うと繰り上げないでそのまま数を加算
するんですね。

34 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 13:08:14 ]
>>23
int *p = a じゃ警告出るだろ。
a[0] か *a か (int*)a じゃないと。

35 名前:22 mailto:sage [2007/08/17(金) 13:10:17 ]
日本語変だorzエスパー読みしてください

36 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 13:13:52 ]
>>34
そうだな。スマン

37 名前:19 mailto:sage [2007/08/17(金) 14:03:38 ]
サイスコして復活したのはいいけど、こんどはソースいじって上書きしようとしても
アクセス権限がありません、管理者に許可をもらってください。ってでる
どうしたらいい?

38 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 14:07:09 ]
あー
ものすごくアレだ
もしかしてVista使ってて
VisualStudioにまだ公式Vista用パッチ当ててないか
ソースを\Program Files\の下に保存かけてしまってる
とか
なんか

39 名前:19 mailto:sage [2007/08/17(金) 14:32:53 ]
>>38 それかぁああああ!!!
どうしたらいいかおしえて1おねがい!おしててうhw

40 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 14:55:58 ]
C言語と関係ないし、内容も別スレで聞いたほうが早いと思うから
それ以上はVisualStudio関連スレでやって下さいな。



41 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 14:59:10 ]
>>39
ラスト。これ以上は判らんスよ

MSのサイトで 2005 update SP1 vista で検索しとけば大概わかるっしょ
あとは別スレで

42 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 17:41:01 ]
この質問してたヤシが30過ぎたおっさんだったら失笑してしまう。

43 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 23:10:09 ]
>>42
30過ぎの女性だとしても苦笑もんだな。

44 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 23:51:08 ]
>>22
配列は、大きな連続した領域として、メモリ上に確保されます。
a[3][4]とb[12]はメモリ上では同じ様に存在します。
仮に a == b(同じアドレス)だとしたら。
&a[0][0] == &b[0]
&a[0][1] == &b[1]
&a[0][2] == &b[2]
&a[1][0] == &b[4]
&a[2][0] == &b[8]
&a[2][3] == &b[11]
の様に対応します。
aの右側の添字が1増える毎に、bの添字が1増え、
aの左側の添字が1増える毎に、bの添字が4増えるのが分かるとおもいます。
お察しの通り、4は要素数です。
したがって a[i][j] は b[i*4+j] です。

2次元配列は1元配列を、ただ折り畳んだものと考えれば分かりやすいでしょうか?(下の例で同じ文字同士が対応していると思ってください)
1次元配列:a[12]
0123456789AB
2次元配列:a[3][4]
0123
4567
89AB


45 名前:デフォルトの名無しさん mailto:sage [2007/08/17(金) 23:53:28 ]
図に描いてみればすぐわかるんだけど、文章で説明するのは難しいね。

46 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 00:01:34 ]
こんな俺におすすめのCの教科書を教えてくれまいか。

・Javaはそれなりにやってる。
・Cは「触ったことある」レベル。ポインタのポインタって頭破壊する気? マクロとか#defineぐらいしか知りませんが?
・内容は多少ハイレベルでも大丈夫、というかみっちりやってくれる本の方が嬉しい。
・演習がしっかりある奴がいい。むしろ多少重いぐらいで丁度良い。

お願いしますだ

47 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 00:52:41 ]
>>46
規格書。
・プログラミング初心者向けではない。
・それを知るために読むのだろ。
・内容はハイレベルだが漏れもなければ間違いもない。
・世の中の全てが演習のテーマだ。

48 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 01:07:08 ]
>>47 それ以外で何か頼むw 規格書もいつか読むんだろうけどさ・・・

49 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 01:55:23 ]
>>46
C++だけど「独習C++」なら持ってる。演習付き。
これのC版はどうだろう?(俺は読んだことないけど)
書店で片っ端から開いてみたら?
ところで、ポインタのポインタで頭破壊なら、二次元配列でも頭破壊か?

50 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 03:29:35 ]
>>49
独習Cは書店にあったなー。平積みだったし、定評ある本なんだろうなやっぱり。thx

2次元配列は大丈夫、かな? ポインタで要素にアクセスしようとするのは慣れないけど。
基本的に、ポインタ周りの使い方と理解が全くだめ。Javaにポインタがないからだねw
参照という意味ではJavaでも無意識で使ってるのは確かだけど、Cだときっちり意識して使わないと駄目な感じに見える・・・



51 名前:デフォルトの名無しさん [2007/08/18(土) 04:15:36 ]
今 C言語勉強中で一通り超基礎を終わらせたのですが教えてください><

int ia;

while(ia != -999){
scanf("%d",&ia);
}

これを実行させて入力時に「a」とかを入れると無限ループするのですが
なぜでしょうか?

もちろんchar型ではないのでこんなんしたらダメだと思うんですが
 a のアドレスが ia に代入されるんだったら-999じゃないから
無限ループにならずにまた入力になると思ったんですが・・

なんでだろぅ・・

52 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 04:24:30 ]
www9.plala.or.jp/sgwr-t/c/sec07.html
> scanf()で読み込み不一致が起こる問題では、上記 「atoi()、atol()、atof()」を使って回避します。
> 読み込み不一致は、scanf()を for や while などのループの中で用いた場合、入力バッファに
> 残されたデータを永遠に受け付けないため無限ループになってしまい意外に深刻な問題となります。
> そのためデータを一旦、scanf("%s", ○)や gets()を用いて文字列として入力し、それから上記の
> 変換関数を用いて期待するデータ型に変換するのです。

int i = 0;
char a[20];

while(i != -1) {
printf("整数値を入力してください(終了条件:-1)\n");
scanf("%s", a);
i = atoi(a);
}





53 名前:デフォルトの名無しさん [2007/08/18(土) 04:30:09 ]
>>52
超すばやいお返事&回答ありがとうございます(@w@

なるほど・・これをすると入力を永久に受け付けなるのですね
しかもサイトまで教えていただいてありがとうございます!
このサイトいいですねw勉強してきます

54 名前:デフォルトの名無しさん [2007/08/18(土) 06:22:06 ]
乱数に関しての質問なのですが、教科書には

#include<stdio.h>
#include<stdlib.h>
#include<time.h>

int main(void)
{
int i;
srand((unsigned)time(NULL));

for(i = 0; i < 10; i++){
printf("%d\n", rand() % 100);
}

return 0;
}
でおkと書いてるんです。
コンパイルは通ったのですがこの部分の
printf("%d\n", rand() % 100);
これってもし 0 がきたら0割りで無限ループになるんでしょうか?
0がくることはないですか?
自分は
printf("%d\n", (rand() +1 % 100);
のほうがいいんじゃないかと思ったのですがどうなのでしょうか?




55 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:22:34 ]
>>52
だからそのサイトは地雷だって。果てしなく間違いが見つかる。

56 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:25:29 ]
>>54
馬鹿もん、0割る100は0だ。

57 名前:51 [2007/08/18(土) 06:28:18 ]
すいません^^; >>54 は 51です。名前入れ忘れました。 

58 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:29:06 ]
>>57
別に誰でもいいから自分宛のレスを読んでレスしてから言い訳しろ。

59 名前:51 [2007/08/18(土) 06:33:35 ]
あぅ・・すいません。言い訳じゃなかったのですが つw;)
今 0/100やっても大丈夫でした^^;申し訳ありません。
学校でCOBOLとC、同時にやってるのでごっちゃになってしまいました。。
(COBOLは0を割ると無限ループになっちゃうので・・)
一回試してから聞くようにします^^;ごめんなさい

60 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:41:01 ]
>COBOLは0を割ると無限ループ
そうだっけ? どうでもいいけど常識的には有り得ないんだけど。



61 名前:51 [2007/08/18(土) 06:42:56 ]
>>60
あぅ、うちの学校のホストだけなのか´ω`;
GS−8200って富士通のホストです


62 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:46:09 ]
うぁはは、COBOLってすげー。
--
COBOL アプリケーションプログラムを強制終了するには、2 通りの方法がありま
す。
方法 1
0 で 0 を割る COBOL アプリケーションプログラムを作成します。

63 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:46:36 ]
例外ベクタの飛んだ先にHLTが埋め込まれてるんじゃないの。
古代の処理系ならありがちだよ。

64 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 06:50:28 ]
ゼロで除算する事が問題になるのはよく聞くけど
ゼロを除算する事が問題になるなんて聞いたこと無いな

65 名前:51 [2007/08/18(土) 06:54:47 ]
あ!ほんとだ
100/0にしたらコンパイルエラーになった。
完全に私の覚え間違いでした・・ちょっとROMって勉強しなおします・・

66 名前:デフォルトの名無しさん [2007/08/18(土) 10:31:49 ]
C言語を勉強する前に身につけておかなければならないことは?

67 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 10:35:22 ]
>>66
そういう頭でっかちの考え方を捨てること

68 名前:デフォルトの名無しさん [2007/08/18(土) 10:37:58 ]
基本スペックは中卒+パソコンオタクです

69 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 10:46:27 ]
なんだかんだ言っても、コンピュータの仕組みを知ることも重要だよね。
人によってはコード、文字列を入力しているようにしか思えないだろうけど
汎用電子計算機に処理してもらっていること、どのように処理されているのかとか。
そういうのを知ると、より適切なプログラミングが出来るようになる。

70 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 11:12:26 ]
>>55
なんか、そのサイトの作者が自作自演で宣伝してるんじゃないかってかんぐりたくなるな。



71 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 11:19:22 ]
だとしたらかなり高度な自演だなw

72 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 20:06:55 ]
〇∧〃 初心者からの質問?
 / >  でもそんなの関係ねぇ!
 < \  そんなの関係ねぇ!

  〇/ はい!
 /|    オッパッピー!!
 />

全部わすれておっぱっぴー!

73 名前:デフォルトの名無しさん [2007/08/18(土) 20:29:38 ]
一つ質問があります。よろしくお願いします。

realloc()についてなんですが、このメモリ領域拡大縮小関数の
P186の定義を見てあきれたんですが、
新規にメモリを確保して、memcpy()で内容をコピーしてるんですが
領域を縮小するときはともかく、領域を拡大した場合、
元のメモリ領域の外までコピーしていますよね。
これってエラーにならないんですか?
確かに書き換えているわけではないので
問題ないのかもしれませんが、これじゃメモリを別アプリから覗き見放題じゃ
ないですか。本当のところどうなんでしょうか。単にわたしの資料が古いだけかな。

それと今、C++でrenew()みたいな関数作ろうと思ったんですが、
元のメモリ領域のサイズがわからないので難儀しています。
何かよい解決策がありましたらご教授ください。


74 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 20:31:22 ]
P186って、なんのページ?

75 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 20:37:50 ]
こっちが呆れた。

76 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 20:40:54 ]
標準ライブラリって仕様は統一されてても実装は処理系依存じゃ?

77 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 20:58:29 ]
>>76
標準の話じゃなくて、なにかの本のP186に載ってる実装例の話でしょ。

78 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:03:54 ]
P-186号文書

79 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:04:23 ]
文字列がABCDEFG・・・みたいに続いていて
2文字目だけコピーするまたは3文字目から5文字目をコピーするといった方法ありますか?
strcpy()だとできない・・・

80 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:07:36 ]
memmove, memcpy, strncpyとか



81 名前:デフォルトの名無しさん [2007/08/18(土) 21:11:28 ]
>>74
ANCI C言語辞典です。
ちなみに、XPでBCCのC++でnew使って同様にmemcpyしてみましたがエラーにならないようですね。

char* p1;
char* p2;
p1 = new char[10];
memset(p1, 'A', sizeof(char)*10);
p2 = new char[1000000];
memcpy(p2, p1, sizeof(char)*1000000);
delete p1;
delete p2;


82 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:14:25 ]
>>81
そりゃエラーにならんだろう
範囲外を書き換えているわけじゃないし

83 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:26:36 ]
>>74
オッパッピーのピーだよ、きっと

84 名前:デフォルトの名無しさん [2007/08/18(土) 21:27:46 ]
>>79
こんなんでどうでしょう

const int siz = 3;
char s[] = "ABCDEFG";
char* p;

p = new char[siz];
memset(p, '\0', siz);
p[0] = s[1];
printf("2文字目:[%s]\n", p);
memset(p, '\0', siz);
memcpy(p, &s[2], sizeof(char)*3);
printf("3文字目から5文字目:[%s]\n", p);
memcpy(p, &s[2], &s[5] - &s[2]);
printf("3文字目から5文字目:[%s]\n", p);
delete p;


85 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 21:29:43 ]
>>82
やっぱりそうですか。了解しました

86 名前:79 mailto:sage [2007/08/18(土) 22:00:39 ]
>>84
サンクス!なんとかできた

87 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:18:53 ]
>>86
間違っても>84を真似してはいけません。それはCではありません。
--
bool strExtract(char * dest, const char * str, unsigned from, unsigned to)
{
if (str == NULL || dest == NULL) return false;
unsigned length = strlen(str);
if (from - 1 >= length || from < to) return false;
length = to - from + 1;
sprintf(dest, "%*.*s", length, length, str + from - 1);
return true;
}

char buf[100];
char str[] = "ABCDEFG";

// 2文字目をコピーした文字列を得る
strExtract(buf, str, 2, 2);
// 3-5文字目をコピーした文字列を得る
strExtract(buf, str, 3, 5);

88 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:30:44 ]
84、87は初心者か、悪意のある上級者だろうな。

89 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:36:04 ]
>>88
84が初心者(というか、自称初級者)で87が悪意のある(というか、臍曲がりの)上級者かと。

90 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:36:13 ]
#include <stdio.h>
#include <string.h>

int main(){
char a[]="ABCDEFG";
char b[10];

/* 3文字目から5文字目こぴー */
strncpy(b, a+2 ,3);
b[3]='\0';

/*確認*/
printf("%s.%s\n", a, b);

return 0;
}



91 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:43:04 ]
>>73
realloc()の返り値は、渡した引数と必ずしも一致していない。
必要なら、別の領域を探してきてそちらに移す。

というか、
>>これじゃメモリを別アプリから覗き見放題じゃないですか。

物理アドレスと論理アドレスの違いを勉強してくれ。





92 名前:デフォルトの名無しさん mailto:sage [2007/08/18(土) 23:49:34 ]
>>79
90が普通の書き方だけど、Windows環境なら、windows.hをインクルードして、
lstrcpyn()を使う方法も。

93 名前:87 mailto:sage [2007/08/18(土) 23:57:12 ]
一部訂正。
--
- if (from - 1 >= length || from < to) return false;
+ if (to - 1 >= length || from < to) return false;
--
toで制限しておけばfromは必然的に制限の必要がないのを逆にしてしまった。
toで制限するなら、%*.*sも冗長と言えば冗長か。%.*sにすれば引数のlengthが一つですむ。

>>88>>89
何さ。
>>90>>92
strncpy()の仕様を覚えるくらいならsprintf()を使いこなした方が潰しが利きそうな気がするが。

94 名前:90 mailto:sage [2007/08/19(日) 00:07:12 ]
>>93
>strncpy()の仕様を覚えるくらいならsprintf()を使いこなした方が
両方覚えるのが良いかと思います。後回しにするのならまだしも、
少なくともこの時点で切り捨てる必要は無いでしょう。
両方知れば、使い分ける事ができますから...

95 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:07:46 ]
>>93
覚えるのは「strcpy()の長さ制限のあるバージョンがあったな」ってくらいでいいでしょ。
使うときは、仕様を確認すればいい。

96 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:15:29 ]
strncpyはstrcpyに比べて異常終了しにくいので、まあともかく早く
動かしたいときには、よさそうな気もするけど、データの異常に気づかない
可能性があるのでおすすめではないです。
sprintは普通に重い処理だからスピードとか気にするところでは
避けたいですが、まぁ使いやすいっちゃ使いやすいですね。
memsetで初期化するのも褒められたやり方じゃないよな。

97 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:20:53 ]
>>96
strncpy()でデータ異常に気づかないって、どういうケースで?

98 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:22:24 ]
sprintfは「書式を指定する」てところに、特徴があるので、
その様な状況ではsprintfが適切でしょ。
対して,strcpy,strncpyは文字列のコピーが目的の関数ってことで、
>>79の様なケースでは、関数本来の目的にあってるかと思う。

99 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:26:17 ]
strncpy()は、コピー先の後ろを0で埋めるという仕様があるので、
strncat()を使ったほうが速度的には有利だけど、書き方が直感的ではなくなる。

dst[0] = '\0';
strncat(dst, src, n);



100 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:26:50 ]
>>97
文字列終端の'\0'を忘れるケースがありますね。



101 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:29:28 ]
>>100
コピー元の文字列が、0がついてないような場合でも、長さ制限があるから無事に処理ができてしまうということ?
それは(この文脈では)sprintf()でも同じことでは?

102 名前:100 mailto:sage [2007/08/19(日) 00:49:40 ]
>>101
送り側の文字列に0が無ければそうですが、送り側に0があった場合でも、
strncpyの場合、送り側が受け側の長さ(与えた長さ制限)以上の場合、付きません。
対して、sprintfならば0は自動的につきます。受け側に起きる問題ですね。

ちなみに >>100 != >>96 ですので、
>>96さんのいう異常が同じ事を言ってるのかは、わかりませんが。


103 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 00:50:34 ]
指定した長さでコピーがカットされた時、
\0終端してくれないってことだろ

104 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 01:14:06 ]
char s[] = "12345678", d[4];
strncpy(d, s, sizeof(d));

ってやったときにdは0終端されないっす。
こういう挙動なのでとっても使いづらいっす。

使いどころはないこともないんだけど、
まず使うことはないですね。

105 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 01:34:21 ]
フリーの統合開発環境でいいのありますか

106 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 01:35:46 ]
Visual Studio

107 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 01:39:40 ]
>>104
strncpyの返り値が d じゃなくて、コピー後の末尾だったら良かった。
と思ったことがある。そうすれば、次々に連結する処理が楽かなーと。
まあ、それくらいなら自作出来るけど。

108 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 02:01:33 ]
>>105
いいのかどうか分からないけど
少し重いが
同じツールでJavaも開発できるエクリプスなんかどうでしょう?
コマンドプロンプトしかありませんが


109 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 04:40:42 ]
学生なら迷わずVS 2005 academic

110 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:05:01 ]
学生で今はちょっとCをやった所だけど、やっぱりCよりC++の方がすごいソフトができるの?
なでしことかドリトルでは限界があるの?プログラマーは生涯にたくさんの言語を使うらしいけど
DとかJavaとかいろいろありすぎてどれをやればいいのか分からない、とりあえずCからやってるけど



111 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:08:05 ]
初めはJavaかC#からやるのがいいんじゃないかな
Cはその次がいいと思うよ

112 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:20:16 ]
マジで? ちょっとVisual C# Express Edition落としてきます

113 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:24:36 ]
Cからやるべきだろ

114 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:27:17 ]
俺もCからがいいと思うよ

115 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:33:57 ]
C#かJavaあたりだろうね。

116 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 14:38:28 ]
俺も初めはバグを作りにくく直しやすい言語がいいと思うからC#やJavaをすすめる。
Cより型付けが強いし何かあれば例外投げて原因に気づきやすい。
あとGCがあるからメモリ周りは比較的無頓着にできる。
もちろんその後もCはやらないでいいって言ってるわけじゃないよ。

117 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 16:23:01 ]
strncpy みたいな使いにくい関数じゃなくて、
strlcpy が標準になればいいのに。


118 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 16:34:54 ]
NULLターミネイト位やっといてくれよとは思う
結局ラッパー関数書くハメになるし

119 名前:デフォルトの名無しさん [2007/08/19(日) 18:11:09 ]
void PhysicsDraw(){

for(int x=40; x<640; x=x+40) DrawLine(x,0,x,480,GetColor(64,64,64));
for(int y=40; y<480; y=y+40) DrawLine(0,y,640,y,GetColor(64,64,64));
DrawCircle(320,240,30, GetColor(255,0,0),TRUE);
}
ていうプログラムが本に載ってたんですがそのままやっても

> C:\borland\bcc55\Bin\make.exe -fDebug\dxtest.mak TARGET
MAKE Version 5.2 Copyright (c) 1987, 2000 Borland
bcc32 -W -3 -Od -w- -AT -pc -H- -k -b -v -y -L..\DxLib -DDEBUG -nDebug -I..\DxLib;C:\Users\shiro\Desktop\MyC\プロジェクトに追加すべきファイル_BCC用\DxLib -c C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp
Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland
C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp:
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 3: 未定義の関数 'DrawLine' を呼び出した(関数 PhysicsDraw() )
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 3: 未定義の関数 'GetColor' を呼び出した(関数 PhysicsDraw() )
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 4: 未定義の関数 'GetColor' を呼び出した(関数 PhysicsDraw() )
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 4: 未定義の関数 'DrawLine' を呼び出した(関数 PhysicsDraw() )
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 5: 未定義の関数 'DrawCircle' を呼び出した(関数 PhysicsDraw() )
エラー E2268 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 5: 未定義の関数 'GetColor' を呼び出した(関数 PhysicsDraw() )
エラー E2451 C:\Users\shiro\Desktop\MyC\dxtest\dxtest.cpp 5: 未定義のシンボル TRUE(関数 PhysicsDraw() )
*** 7 errors in Compile ***

** error 1 ** deleting Debug\dxtest.obj

Make End !! (Elapsed time 0:00.296)
ってエラーが出るんです。どうしてでしょうか?
ちなみに今日プログラム始めたばかりです。

120 名前:デフォルトの名無しさん mailto:sage [2007/08/19(日) 18:40:01 ]
>>119
それはコードの一部だからコンパイルできないよ。

どっかにコードの全部が掲載してあるんじゃね。
もしくはCDに入ってるか。

つか、本文も読めばいいのに。



121 名前:名無しさん@お腹いっぱい mailto:sage [2007/08/20(月) 02:31:35 ]
質問なのですが家でc言語使えるようにしようと思って
microsoft.net Framework version 2.0 再頒布可能パッケージ
microsoft.net Framework version 2.0 SDK 日本語版
をダウンロードしたのですが友達の話によると
microsoft.net Framework version 2.0 日本語版 language pack
が必要らしいのですがmicrosoftの公式サイトに行っても見つからないのですが
どうやったら手に入るのでしょうか?
すごい初歩的な質問ですいません

122 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 02:38:44 ]
>>121
悪いことは言わんから Visual C++ 2005 Express Edition 使っとけ。

123 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 10:45:33 ]
C言語で.NET?

124 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 10:47:25 ]
.NETが必要なら導入すべきだが、C言語ってだけだと別に必要ってわけでもないガナ

125 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 11:10:49 ]
>>107
あー、それ俺も思った。
strncpy(d, s, sizeof(d))[sizeof(d)] = '\0';
           ↑   ↑
           ここがなんかクドイ

126 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 11:39:29 ]
>>125
くどいかどうか以前に、いろんな意味で間違いすぎ。

127 名前:51 [2007/08/20(月) 12:41:28 ]
低レベルな質問なのですが・・
こないだ友人と話してたのですが(どちらも現場経験なし)、
if文に{}っていりますか?
ifのあと文が1つなら{}は省略してよし、と書いてあるので友人はいらないといいます。
けど私は読みやすいから{}つけたい人間です。
こんな感じです。
if(ia==0){
printf("HelloWorld\n");
}
{}はつけないほうがいいのでしょうか?



128 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 12:48:48 ]
>>127
宗教論だな。正直どっちでもいい。

いろいろな人がソースコードを編集するなら
インデントとか括弧とかはツールで一括変換するようにすればおk
GreatCode とか

129 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 12:53:52 ]
if(foo)
 if(boo) zoo=0;
else // !fooのつもり
 zoo=1;
みたいなのをやらかしそうなら、付けといた方がいいかな、程度のもんだと思う。

130 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 12:58:20 ]
私のところのコーディングガイドでは、1行に収める場合のみ省略化としている。
つまり、
if (foo) bar();
はOKだけど
if (foo)
  bar();
はダメ。
勿論、
if (foo) {bar();}

if (foo) {
  bar();
}
もOK。



131 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 12:58:51 ]
>>127
>if文に{}っていりますか?
つけてもつけなくても文法上間違いではない。
>{}はつけないほうがいいのでしょうか?
つけたほうがいい。

132 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 13:07:31 ]
>>126
>いろんな意味
kwsk

133 名前:132 mailto:sage [2007/08/20(月) 13:10:15 ]
あ、ありえないミス…
× sizeof(d)
○ sizeof(d)-1

134 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 13:11:37 ]
俺は逆にカンマ演算子を使ってまで中括弧は使わないようにしてる
えへへ

135 名前:51 [2007/08/20(月) 13:11:45 ]
>>128>>131
回答ありがとうございます。
どちらでもいいし、つけたほうがいいっぽいですね^^
やはりつけるようにします。

136 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 13:18:09 ]
>>125
dが配列だと思っていいのかな?
だったら
sprintf(d, "%.*s", sizeof(d) - 1, s)
でいいじゃん。

137 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 13:25:54 ]
>>136
0終端の為だけに態々そんな余計な文字列パースさせるの?

138 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 13:31:17 ]
>>137
余計なメンテナンスに時間取られるくらいならありじゃね?
パフォーマンスが問題になるようなら入れ替えればいいことだし。
# まさかMS-DOSの時代みたいにprintf()系をリンクしないでサイズ節約なんて考えないだろうし。

139 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 18:58:08 ]
>>135
文がひとつのケースでも括弧をつけたほうがミスがなくなる。

140 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 20:58:52 ]
宗教論争になるからそろそろやめようぜ。



141 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 21:18:10 ]
という指摘は既に >>128 でなされているわけですが
どーしても自分語りがしたい阿呆が多くてなかなか収束しません。

142 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 21:19:17 ]
なに仕切ってんのコイツ

143 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 21:35:48 ]
 ヽ○     小学校のころから、学級委員してました♪
  |>    
  ((

 〇∧〃 
 / >  でもそんなの関係ねぇ!
 < \  そんなの関係ねぇ!


  〇/ はい!
 /|    オッパッピー!!
 />

チントンシャンテントン♪
チントンシャンテントン♪


144 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 22:10:27 ]
いろんな意味で終わったネタを引っ張るなよ

145 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 22:57:39 ]
>>135
一行のときは{}は無いほうがいいよ。
10年に一度もしないようなミスのために、読みやすさを損なうことはない。

コードを大量に書いてる人は、省略する派が多いし。



146 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 23:21:38 ]
笑わせてくれるぜ

147 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 23:39:51 ]
>>145
コードを大量に書いてる人ってだれ?

148 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 23:54:27 ]
読みやすさを考えたらコードを大量に書くとか・・・

149 名前:デフォルトの名無しさん mailto:sage [2007/08/20(月) 23:56:52 ]
>>147
linux書いてる人とか、apache書いてる人とか、postgres書いてる人とか、その他いろいろ。

150 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 00:01:02 ]
「一行でも{}をつけた方が良いか」とかの、
くだらない事を質問するような奴なら、つけた方が良いと思う。
俺はつけないが



151 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 00:42:31 ]
>>149
その人たちは本当に読みやすさのために省略してるのか?

152 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 00:44:55 ]
そもそも「コードを大量に書く人」のソースをlinuxやapache書いてる人として
その人たちの中じゃこっち派が多いよってのは無理があるだろう。
そこらへんのプログラマだって大量にコードは書いてる。

153 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 00:45:55 ]
うぅ、日本語が変だ・・・orz

154 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 05:56:54 ]
「if」って打ったらエディタが
if () {
}
って勝手に出してくる(ように設定している)ので、
消すのが面倒だし害はないし後々の面倒を予防できるのでそのまんまにしてまーす。

155 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 06:49:28 ]
そういうのって()の中にカーソル移動すんの面倒じゃないの?

156 名前:デフォルトの名無しさん [2007/08/21(火) 07:51:06 ]
>>135 つけたほうがいいっぽいですね^^

質問内容は釣ネタに見えますがまだレスが流れている様ですので

プログラムは評価を受けるとかレビューとかされる場合があり
必ず中括弧'{}'で括るケースでも例えば1行しかないのに何でわざわざ中括弧で括るの?と質問された時
何と答えるかです

自分なりに定性的定量的な論旨展開で結論を出すか
ご存知かと思いますが世の中にあるコード標準とか規約とかを引用するかですね
例えば以下リンクが良く纏まっていますのでお勧めですが
www.literateprogramming.com/nrad.pdf
次レスに続く

157 名前:wolf ◆8VH3XAqjlU mailto:sage [2007/08/21(火) 07:51:49 ]
>>135 つけたほうがいいっぽいですね^^
続き

中括弧で括るケースについての記述は
2.C++ Coding Standard
└─Usage Of The Implementation Language
└─Control Structures
└─Branching
└─if ... else statement

に有りますが中括弧だけでなくインデントや比較代入記号に関しても検討して下さい

if(ia==0){
printf("HelloWorld\n");
}

僕ならこう書きます
if(0==ia)
{
printf("HelloWorld\n");
}

158 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 07:54:31 ]
定量的な論旨展開ってなんだ?

159 名前:デフォルトの名無しさん [2007/08/21(火) 08:08:03 ]
いきなり書き込まれてしまいまして訂正かねて

>>135 つけたほうがいいっぽいですね^^
続き

if(ia==0){
printf("HelloWorld\n");
}

僕ならこう書きます
if(0==ia)
{
  printf("HelloWorld\n"); <---- 訂正
}

>>158 定量的な論旨展開ってなんだ?
あまり即答はしないほうですがたまにはソフトウエア工学的な
意見展開もいいかもしれませんので
例えば
ひと纏まりしたコードは1画面内に収まったほうがreadabilityが良いですから


160 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:12:00 ]
日本語おかしい



161 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:19:17 ]
「たとえば」がなにとたとえてるのかさっぱりわかりませんが。

162 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:23:40 ]
比較で定数を左にもってくるというテクニックも、警告が出ないよう
にコーディングするって当たり前のことをしてれば必要ないですね。
変に技巧にはしるようなことはやめて、素直に書きましょう。


163 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:24:48 ]
定量的といいつつ、定量的なことは一切書いてない件。

164 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:26:06 ]
そもそも論旨は展開するようなもんじゃない

165 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:27:25 ]
本当に釣りネタに見えるなぁ・・・

166 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 08:58:16 ]
インデント論争に発展するのだけはやめような

167 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 10:24:11 ]
>>145
どこが
> 読みやすさを損なう
のかさっぱり。やっぱ、主観的なことしかいえないだろ?
だからやめろつってんのにw
コンパイルが通ればどっちでも良いんだよ。
むしろ必要性について知らない方がダメ

168 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 10:25:24 ]
>>151
そういう人たちは複雑になるんで、やはり規則性を持った記述をしているため
書いたり書かなかったりみたいな、ことはしてないはず。

169 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 10:41:52 ]
>>168
書いたり書かなかったりしていますが何か。
// 書かないケース
if (foo) bar();
// 書くケース
if (foo) {
  bar();
}

170 名前:デフォルトの名無しさん [2007/08/21(火) 10:47:34 ]
scanfだと入力後エンター押す必要がありますが
画面に入力した瞬間から反映される関数ってありますか?



171 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 10:50:15 ]
>>170
標準ではありません。環境依存になりますが、例えばcursesなどのライブラリを使えばできないわけではありません。

172 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 10:51:10 ]
あるいは、{ } が不要な1文のみの場合、
if() の後ろにそのまま続けてifと同じ行に書いていたり。
だから読みづらいだの主観的な意見はナンセンス。
自分が思うとおりに動作するように記述できて、コンパイルが通れば良し。

173 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:04:53 ]
読みづらさをないがしろにする意見はナンセンス

174 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:08:07 ]
読みづらいなんてのは主観なんだから放っておけばいいさ。
読みにくいという指摘なら、話を聞かないでもないが。

175 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:12:10 ]
読みにくさは主観じゃないの?

176 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:14:40 ]
客観的立場に立とうとした表現だね。定量的ではないが。

177 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:14:52 ]
誘導

コーディングトラブルの約70%はif文などでの{}省略
pc11.2ch.net/test/read.cgi/tech/1173416521/

178 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:16:12 ]
>>173
だからその読みづらいって主観が個人的なものでナンセンスだって言っているんだが?
人それぞれで、括弧があれば読みづらい、なければ読みづらいとか言われても
んじゃどっちだよ?って争いになるから、括弧の必要性を理解した上で
自分が思う通りに処理するソースがコンパイラに通ればそれで良いだっつってんだよ、バカかてめぇはw

179 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:22:53 ]
括弧がなくても通るからって理由でつけるつけないをわざわざ
一個人の読みやすさという客観的ではない曖昧な基準で話を進められても困るだろ。
とりあえず、オープンソースのように、他者と交互にやりとりしている人たちのソースを見て
参考にするのも良いだろ。自分だけが編集するソースならどっちをとろうが個人の自由。

180 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 11:24:39 ]
どっちでもいいけどソース内で統一されてれば読みやすい



181 名前:デフォルトの名無しさん [2007/08/21(火) 12:05:16 ]
>>171さん
例を教えてください
お願いします

182 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 12:28:52 ]
>>181
例としてcursesライブラリを挙げていますが。

183 名前:デフォルトの名無しさん [2007/08/21(火) 12:58:43 ]
ifの括弧についてもれがまとめるからもうこの話題はおわろうぜ。

[結論]
ifに括弧はつけなさい。
[理由]
つけてもつけなくてもいい文法が問題だけど
このスレだけでも大半の人間がどちらでもよい、又はつけたほうがいい
というんだからつけなさいYO!

可読性なんてものは人それぞれ違うんだから議論自体が無意味。

もし{}つけたら効率が落ちるんなら
あんたのプログラムif文使いすぎ。作り直しなさい

{}つけるのにそんな面倒か?
なんでそんなにつけるのに反発するんだ?

YOU!つけちゃいなYO

以上まとめでした

184 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:08:18 ]
if(bFlag) i++;
これとか括弧付けるだけ無駄だろ

185 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:11:48 ]
んじゃ、1行纏め。
・迷ったらつけとけ。つけないなら理論武装しておけ。

186 名前:デフォルトの名無しさん [2007/08/21(火) 13:15:49 ]
>>185
先生ノ >>184に「なんで無駄な{}つけてんだ!」ってからまれたら
どういう理論武装しておけばいいですか?

187 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:35:18 ]
>>186
日本語読めますか? >185には「つけないなら」と書いてあるのですが。

188 名前:デフォルトの名無しさん [2007/08/21(火) 13:37:10 ]
>>187
じゃあ「つけないなら」どういう理論武装しておけばいいですか?

189 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:38:48 ]
俺は括弧もゴムも付けない派

190 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:39:34 ]
武装できるような理論があればそもそも論争は起きん



191 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:43:31 ]
理論武装しないならつけとけw

192 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 13:44:57 ]
なぜ?

193 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 14:16:00 ]
>>184 誰がそういうのにも必ず付けろって言った?だからそういう議論は
相手を罵倒したり屁理屈が横行するからやめろつってんのに、うざっ
所詮夏厨か

194 名前:デフォルトの名無しさん [2007/08/21(火) 14:35:00 ]
>>182さん
ぐぐったら理解できました
ありがとうございました

195 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 14:42:11 ]
なんで>181は自分の環境を書こうとしないのだろう……

196 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 16:20:33 ]
>>195
国家機密なんです(><)

197 名前:デフォルトの名無しさん [2007/08/21(火) 17:42:35 ]
Windows XPのGUIのプログラムをc言語で作りたいのですがどうすればいいですか?


198 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 17:44:55 ]
>>197
教えたいのはやまやまですが国家機密なんです。

199 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 17:45:06 ]
>>197
どう、とは?
環境の話なのか、前提知識の話なのか、
それともそれらはクリアしてて、コーディングの話なのか。

200 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 18:15:47 ]
>>197
まず、Windows NT系の入ったパソコンを用意します。



201 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 18:42:03 ]
次に、VCを違法コピーします。

202 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 18:43:43 ]
>>155
もちろんエディタが()の中にカーソルを勝手に移動させまーす。
あと、そこに加えて{}の中にマークをつけるので、
()と{}の中にキー一発で飛べるようにしてまーす。

203 名前:197 [2007/08/21(火) 18:52:30 ]
>>198
え、そうなんですか?私は国家には忠誠を誓っているものですから安心しておしえてください。

>>199
あ、すいません、前提知識ですね。
APIとかをOSの仕組みなどを勉強すればいいのでしょうか?
APIの実装方法やアルゴリズムなどの実装がなんか漠然としてしまって理解できません、

>>200
パソコンは、Windows XPなのでNT系だと思うので多分大丈夫だと思います。

>>201
VC2003なんとかというコンパイラとボーランドの無料のコンパイラをインストールしてあります。

204 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 19:00:54 ]
猫でもわかるでも読んどけ

205 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 19:06:18 ]
>>203
VC2003なんとかというコンパイラを使います。

ひとりでGUIを勉強するときは、チュートリアルがないと無理。
サンプルのたくさん載った参考書が必要。

Windowsアプリの作成は理解するというより慣れるです。
理解しようとすると挫折します。サンプルを入力、コンパイルして慣れてください。

206 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 19:10:37 ]
>>203
まさかノってくれるとは思わなんだ。

つかGUIプログラミングはせめてC++とMFCでする気は無いか?
もっと簡単にするならC#という言語を使う手もある。
C言語でやるのは面倒だが、何か理由があっての事か?

207 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 19:31:01 ]
>>203
・Visual C++ 2005 Express Edition と Microsoft Platform SDK を一緒に使う
ttp://www.microsoft.com/japan/msdn/vstudio/express/visualc/usingpsdk/

・Win32 API入門
ttp://wisdom.sakura.ne.jp/system/winapi/

208 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 21:03:04 ]
>>179
コーディングスタイルって、経験が足らないヤツが頭で考えたっていびつになるんだよな。
実際コードをたくさん書いて、世間で実際に評価されてる人のを参考にしたほうがいいよね。


209 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 22:55:29 ]
括弧があってもなくても、可読性に影響がでないくらいシンプルな記述を希望します。
COBOLを連想させるような200行以上もある関数はヤメレ

210 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 23:13:44 ]
じゃあ俺はFORTRANを連想させるようなgoto使いまくりの関数にするぜ。



211 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 23:15:33 ]
>>209
同感です。if文だけに着目するよりも、前後の文を含めて、
そして全体を通してシンプルであることが望ましいですね。
適当に空行を入れるだけでも、それなりに変わりますからね。

212 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 23:24:05 ]
正直、こんな書き方はやめて欲しい。
--
double sum = func(
          sx[ox]
          ,cx[ox]
          ,sy[oy]
          ,cy[oy]
          ,xDim
          ,yDim
          ,wr
          ,wi
     );

213 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 23:33:15 ]
>>212
1行にしてみました。どうでしょう?
double sum = func(sx[ox], cx[ox], sy[oy], cy[oy], xDim, yDim, wr, wi);

それとも構造体にまとめて、ポインタ渡しが良いですか?
具体的に希望があればどうぞ。

214 名前:212 mailto:sage [2007/08/21(火) 23:38:29 ]
>>213
いやまぁ、とっくに整形済みだけどね。

215 名前:デフォルトの名無しさん mailto:sage [2007/08/21(火) 23:52:40 ]
>>213
全部グローバル変数で渡して引数はなしの方向で

216 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 00:04:31 ]
手動インライン展開で

217 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 12:45:29 ]
>>212
コーディング規約でそのスタイルを規定しているところもある。
これだと、引数一つ一つにコメントがつけられるという利点がある。

コーディングスタイルはそれぞれ良いところもあれば、悪いところもあるのが普通で、
プロジェクトあるいは会社でコーディングスタイルが統一されていることが大事。

218 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 12:56:14 ]
>>217
カンマを行頭に持っていくのは規約以前の問題。
英語圏の人が見たら発狂するぞ。


219 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 13:16:24 ]
>>215
悪質にも程があるわ

220 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 13:58:01 ]
カンマ行頭はSQLじゃよくやるけどな



221 名前:デフォルトの名無しさん [2007/08/22(水) 14:19:32 ]
gets関数やscanf関数は想定外の入力をされて変な挙動をする可能性があるので使わない方がいいと
聞いたのですが、ではどういう風にすればいいのでしょうか、実際のプログラムではどうしているか教えてください。

222 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 14:23:44 ]
>>221

>>52参照。
getsは問題がないだろう。

223 名前:221 [2007/08/22(水) 14:29:44 ]
>>222
gets関数はバッファオーバーランの危険性がありませんか?
例えば、char buffer[1024] と宣言した場合に1024バイトであるという情報を
gets関数に伝える手段がないと思うのですが、、、

224 名前:デフォルトの名無しさん [2007/08/22(水) 14:40:39 ]
test

225 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 14:41:42 ]
>>223
fgets

226 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 14:51:24 ]
>>222 みたいなのがいるところをみると、やはり日ごろ来ていない夏厨なんだなぁ〜って思う

227 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 14:53:32 ]
ずっと居る奴も痛いがな

228 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:11:44 ]
gets なんて捨てプログラムでしか使えねえ

229 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:13:18 ]
捨てプログラムでは使う

230 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:14:00 ]
>>223
入力可能な最大文字数を超えるサイズののバッファを確保しておけばいいだけじゃん。



231 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:21:56 ]
>>230 みたいなのがいるところをみると、やはり日ごろ来ていない夏厨なんだなぁ〜って思う

232 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:27:17 ]
>>231 getsに関する君の考えは?

233 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:30:33 ]
>>232
getsに対する俺の考えなんてどーでも良い。存在そのものが問題視されているのは
とっくの昔に知れ渡っていること。それに関する文献を自分で調べな。この板に
一定の期間来て色々と議論を見てきた人なら、まず知っているよ。そう、そんなのは使わないのが鉄則。

234 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:31:31 ]
>>233 だから、それをここで君の言葉でいいなさいよ。

235 名前:デフォルト名無しさん mailto:1111111 [2007/08/22(水) 15:37:29 ]
「DOS窓を開く」を説明してください。

236 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:38:14 ]
>>233
知らないならレスしないでください!

237 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:40:18 ]
セキュリティに関しても問題とされるバッファオーバーラン、固有の環境とか仕様で
対処すりゃみたいなことを言わず、プログラム側でしっかり対処すること。
とにかく、getsだけはありえん。

238 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:41:37 ]
>>235
これくらいは理解してみて
ykr414.com/dos/

239 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:42:40 ]
234 名前:デフォルトの名無しさん 投稿日:2007/08/22(水) 15:31:31
>>233 だから、それをここで君の言葉でいいなさいよ。

236 名前:デフォルトの名無しさん 投稿日:2007/08/22(水) 15:38:14
>>233
知らないならレスしないでください!

↑なんだこいつ?うざすぎ。説明してもらえなきゃ相手が理解していないってことになるなら
そう思ってろ。すでに説明は済んでいるのにな。痛すぎ。お前みたいな奴が質問に答えるのも
問題があるだろ。とっとと失せな、夏厨。

240 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:44:14 ]
>>239
知らないならレスしないでください!



241 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:44:55 ]
入力は何もプログラムを起動してユーザがキーボードで文字を入力する以外にも
ファイルからリダイレクトってのもあるし、データを受ける側が用意した記憶領域を
超えて入力を受け付けてしまうことなんて考えたらキリがないが、そういうのも含めて
getsだけはありえん。使った時点でアホだと思われるぞ。

242 名前:234 mailto:sage [2007/08/22(水) 15:48:10 ]
gets関数は>>223のいうとおりバッファオーバーランの危険性がある。
fgets関数と違ってgets関数の引数にはバッファのサイズの引数がないからだ。

でも、それは>>230のいうとおりで、想定最大入力文字数のバッファを用意しておけば
それですむはずだ。

プログラムを作るときは、入力データの種類やサイズの範囲、誤動作の許容レベル
というものがあるはずで、自分または身内が使う簡単なテストプログラム程度のもの
であればコンソール入力のバッファをchar buf[1000];ととってもなんら問題がないと思われる。

243 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:50:08 ]
ttp://ja.wikipedia.org/wiki/%E3%83%90%E3%83%83%E3%83%95%E3%82%A1%E3%82%AA%E3%83%BC%E3%83%90%E3%83%BC%E3%83%A9%E3%83%B3
問題点のヒントを出しても調べようとしないのか。頼む、お前みたいな無知が
生半可な浅はかな知識でいい加減な回答をするのは迷惑なんで黙っていてくれ

244 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:54:19 ]
>>243
知らないならレスしないでください!

245 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 15:56:45 ]
gets を使うことでバッファオーバフローのサンプルコードを出せる
反面教師のようなところが利点

#include<stdio.h>

int main(void){
int a=3;
char buf[8];
int b=5;
int diffa, diffb, diff=-1;
int i;

diffa=(char*)&a-buf;
diffb=(char*)&b-buf;
if(diffa>0 && diffa<50) diff=diffa;
if(diff>diffb && diffb>0 && diffb<50) diff=diffb;
if(diff<0) return 0;

printf("a=%d b=%d\n", a, b);
printf("Input next string\n");
for(i=0;i<diff;i++) putchar('*');
printf("x\n");
gets(buf);

printf("a=%d b=%d\n", a, b);

return 0;
}

246 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 16:07:32 ]
getsでOKかNGかは作成するアプリのバッファオーバーランの例外処理の要求レベルによるだろう。
業務で使用するものなら、getsは使わないほうが望ましい。fgetsを使う。

テストプログラムや身内で使うものならgetsも可。
ただし、その場合でもバッファは「十分なサイズ」のものを用意しておくこと。

ということかな?



247 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 16:08:42 ]
うん

248 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 17:19:09 ]
バッファオーバーフローを利用したコードインジェクションの例を書こうと思ったが、
>>245 みたいに広い範囲で使えるソースを書くのって難しいね

249 名前:デフォルト名無しさん mailto:1111111 [2007/08/22(水) 17:43:25 ]
>238 arigato mucho obrigado

250 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 18:10:52 ]
相変わらずおまいら gets 好きだね。
飽きないね。



251 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 18:35:48 ]
gcc@linuxなのですが、
a というプログラム(プロセス)から b を必要に応じて起動し
(aはbを起動した後引き続き起動し続ける)ようにしたいのですが、
どうやるのが正しいのでしょうか?

今は、
a側で

pid = fork();
if (pid==0) execv(b);

のようにしているのですが、このやり方であってます?

252 名前:デフォルトの名無しさん [2007/08/22(水) 20:06:36 ]
>>244
Linux Programmer's Manualには「gets()は絶対に使用してはならない。」と書かれている

253 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 20:07:03 ]
教科書を終わったばかりでscanf()とか使いまくりなんだけど、
そういうやらないほうがいいマナーがまとまってる解説サイトはないですか


254 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 20:15:25 ]
少し古い気もするけど、C FAQ。
www.kouno.jp/home/c_faq/

255 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 20:18:37 ]
>>246 みたいなのがいるところをみると、やはり日ごろ来ていない夏厨なんだなぁ〜って思う


256 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 20:38:43 ]
>>252
捨てプログラムくらいならいいだろー

257 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 20:38:50 ]
お前きもいよ

258 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:09:06 ]
>>256
そういう話をしたらキリがないだろ。だったら話に入ってくるなよ。
なんでお前の個人的な都合を受け付ける話題になってんだ?
頼むからお前みたいな自分勝手なことしかいえない奴は大勢とやりとりする
場での議論には入ってこないでくれ。それからお前は二度とここで質問に回答するな。

259 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:10:12 ]
>>256 こいつダメだ。「何が問題」とされているのか分かってないのか?
そう思うなら自分だけが扱うソースでは使えば良いだろ。正式なものに書き換えるときに
わざわざgetsの部分を探して仕様を変更して書き直してたらそれこそ手間が掛かるだろ。

260 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:12:11 ]
>>256
確かにお前みたいな奴が作るプログラムなんて、他の人に使わせないだろうから良いけどさ。
getsを使った入力を受け付けるプログラムが、予期せぬ状況下でバッファオーバーランをして
OSの動作にまで何かトラブルを起こすようなら話にならんのだよ。そういうことも考えて
より精巧なプログラムを作れないようなら、お前はプログラミングには向いてない。
今すぐ将来の進路を変更した方が良いよ。



261 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:13:01 ]
>>256
いいですよ^^

262 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:15:45 ]
お前らきもいよ

263 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:29:42 ]
>>258-260
同じ人ですか?

264 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:32:43 ]
>>256 は今、布団の中で泣きながらダンディ坂野が24時間テレビでやっていた
ゲッツ1万回チャレンジを思い出しているに違いない。

265 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:45:13 ]
捨てプログラムのはずなだったのに、
なぜか他人が使っているという不思議な事態も想定すべき。

266 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:46:38 ]
盲目的に使っちゃいけない、と思い込む方が楽だからな
自分で判断しないから

信号も赤なら渡らない、と決め込んで
青なら安全確認もろくにしないで事故に会うタイプだな

267 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 21:56:23 ]
>>264
余計泣けるじゃないか
虚しさに

268 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:01:58 ]
>>265
> なぜか他人が使っている
ないない、お前日本語が理解できないアホだろ。だから議論に入ってくるなっつってんだが?
言葉以前に現状すら理解できんだろ。よく読め、アホ。

>>260
> 他の人に使わせないだろうから良いけどさ。
だから捨てなんだろ?getsを使ったプログラムを他人に使わせるなんて当然迷惑だ。

269 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:15:12 ]
>>268
何をそんなに興奮してるんですか?


270 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:16:24 ]
自分も意見が言える話題になって嬉しいんだよ



271 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:26:26 ]
こんなの拾った

167 名前:デフォルトの名無しさん[sage] 投稿日:2007/08/21(火) 10:24:11
>>145
どこが
> 読みやすさを損なう
のかさっぱり。やっぱ、主観的なことしかいえないだろ?
だからやめろつってんのにw
コンパイルが通ればどっちでも良いんだよ。
むしろ必要性について知らない方がダメ

272 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:29:37 ]
拾うな
捨てとけ

273 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:33:11 ]
#define mygets(s) fgets((s), sizeof (s), stdin)
sが配列型でなかったら死亡。
C++ならもっと頑張れるが、std::string使えという罠。

274 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:38:26 ]
>>167
> むしろ必要性について知らない方がダメ 

もっともらしい理屈がいくつが挙がってるけど、そのスタイルを採用してないプロダクツでも
世間で評価されてるような実績をあげてるってことは、それらは机上の空論ってことだろ。
センスも見識もない人間が頭の中だけで考えたスタイルなんて、そういうことになりがち。

と遅レスしてみる。



275 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:50:02 ]
個人的な主観や特定の条件を述べられても結論が出ないんで、話を根本に戻すと

>>221 の質問は
> ではどういう風にすればいいのでしょうか

これに対して十分な領域を確保しとけってのは不適切。
なぜなら、確保した領域を 超えて受け付けることが出来る仕様 になっている以上
getsを使ってたら対処にならないんだよ。
その問題点の解決の対処をすることが >>221 に対して適切な回答になる。
getsに問題があるけど、問題が起こらないように使いましょうって
だからgetsを使うからセキュリティーホールなるものが出来てんだろって報告も無視するし。

276 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:52:05 ]
堂々巡りいいよ堂々巡り

277 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:52:07 ]
>>274
お前のバカじゃね?理解してなさすぎ。個人的な主観による 読みやすさ っていう基準が
無意味だって話だろ。自分が思う通りに処理が出来るソースがコンパイルに通れば
どういうスタンスやスタイルをとろうが自由だろ。あんたの言う世間で評価って言うのは
括弧を付ける付けないが評価の対象じゃないだろ?アホ杉・・・

278 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:53:43 ]
そんな危険な関数が何で備わっているんですか?

279 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:54:22 ]
>>274
んじゃ世間で評価されるプログラムのソースに1文のみで括弧が必要ない部分にも
括弧があったらどーすんだよ?くだらねぇ

280 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:54:22 ]
それはもちろん使って欲しいから



281 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:56:14 ]
>>277
だから「必要性」ってなんの話だよ。

それに理解できてないのはおまえのほうだろ。
括弧つけてるつけてないが評価されてるなんてどこにかいてる?

282 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 22:59:28 ]
>>279
だから、上のほうで挙がってる括弧のをつける理由ってのは机上の空論ってことだよ。

283 名前:デフォルトの名無しさん mailto:sage [2007/08/22(水) 23:14:49 ]
×煽り合いスレ

284 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 07:56:31 ]
読んでてふと疑問に思ったんだけど、
今時捨てプログラム以外でCUIで書くことってあるの?
getsなんぞそもそも使う場面が思いつかない

285 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 08:02:28 ]
>>284
君はサーバプログラムを知らないようだ。
他にもシェル上から使えるちょっとしたフィルタプログラムは便利だ。

まあ君には必要のないことなのかもしれないがな。

286 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 09:39:29 ]
>シェル上から使えるちょっとしたフィルタプログラム

はスクリプトで書くからなー

287 名前:286 mailto:sage [2007/08/23(木) 09:40:16 ]
あ、でもオレもCUIでCのプログラムは結構書くよ

288 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 09:50:46 ]
CUIエディタ使ってる奴なんかいないと思ってた…

289 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 09:53:35 ]
最近はGUIの定義が変わってきているから
vi みたいなスクリーンエディタもCUIエディタと呼ぶのかも

290 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 09:53:51 ]
vi 使うべ。



291 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 09:55:06 ]
まあ揚げ足はともかく、ApacheやRubyのモジュールをCで書いたりするしな。

292 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 11:15:37 ]
CMAGAZINEのガイドに従ってBorland C++ Compiler 5.5.1の「コンパイルの
実行手順」まで来ました。Hello, World!というソースプログラムを用例通り
に作ってc:\に「cppprog」フォルダを作成しました。

コマンドプロンプトの\system32\cmd.exeの画面で
C:\Documents and Settings>の後にcd \cppprogを入力しenterキーを押すと
「指定されたパスが見つかりません。」と表示されます。なぜか教えてください。

 保存の状態は、C:→Documents and Settings → 大野→ My Documents →
 cppprogフォルダです。 よろしくお願いします。


293 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 11:31:47 ]
cd "C:\Documents and Settings\大野\My Documents\cppprog"

294 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 11:32:42 ]
ユーザーアカウント名?Oh no!

295 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 11:51:34 ]
cd \cppprog
だと、
C:\cppprog
になる
cd cppprog
なら、現在の場所からの相対位置になる

296 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 12:02:09 ]
C言語についてじゃないな、却下。

297 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 12:10:49 ]
最近この手のプログラミング以前の質問多いよな

298 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 12:14:18 ]
>293, 204, 295ありがとう。
 漢字を打ち込む方法を教えてください。

299 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 12:18:02 ]
>>298
ショートカットの作業フォルダに指定するべし

300 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 12:19:07 ]
>>298
Alt+半角/全角



301 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 12:33:59 ]
まあ漢字めんどうならTABキー連打で

302 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 13:06:34 ]
>301 TABキーで
C:\Documents and Settings\All Users>まで進みました。
この後ろへcd \My Documentsを入力しエンターキーを押すと、
「指定されたパスが見つかりません。」が出ました。
 対策を教えてください。

303 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 13:24:33 ]
>>302
>>295

304 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 13:25:06 ]
サーバやモジュールはgetsを使える場面があるのか…
標準入力もまだまだ捨てたものじゃないってことだな
やったことないから勉強になった

305 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 13:34:04 ]
>303
Documents and Settings\All Users>cd cppprogでエンターキーでも
「指定されたパスは見つかりません。」が出ます。

306 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 13:39:53 ]
All Usersじゃなくて、自分のログインネームで
一個上に行くのは、 cd .. な

307 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 13:48:19 ]
コマンドライン初めてなら、それなりのとこ見ながらやったほうがいいよ
そこからコンパイルまでいくのは大変だし、ここはスレ違いになるから
みんな相手してられなくなるぞ

308 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 13:51:00 ]
ルート直下でやればいいじゃん

309 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 14:04:48 ]
>306 当たり前ですが、Borlandに対するログインネームでしょうね。
 「一個上に行く」というのは,>cd ○○○○(ログインネーム)と
 置くことを指しているのでしょうね。

310 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:10:13 ]
>>309
これ見て勉強して
ykr414.com/dos/



311 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:29:10 ]
OS :Borland

312 名前:311 mailto:sage [2007/08/23(木) 14:31:45 ]
ちょっと質問なんですけど、たとえば
key=value という文字列をsscanfをつかって'='で分解したいんですが

char text[256] = "key=value";
char *key,*value;
sscanf(text,"%s=%s",key,value);

という感じで打ってもできませんでした。だれかご教授おねがいします

313 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:34:45 ]
BorlandっていうOSは知らないなぁ

314 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:46:44 ]
だーかーらー
カレントディレクトリが C:\Documents and Settings\All Users なんだったら、
その状態で cd cppprog ってやったら
C:\Documents and Settings\All Users\cppprog
へ移動することになるし、cd 大野 ってやったら
C:\Documents and Settings\All Users\大野
へ移動することになる。もちろんそんなディレクトリは存在しないから、エラーが出るわな。

君が移動したいのは C:\Documents and Settings\大野\My Documents\cppprog だろ?
だったら1つ上のディレクトリ(つまり C:\Documents and Settings)に戻ってから、
大野 → My Documents → cppprog へと移動すればいい。
具体的には
cd ..
cd 大野
cd "My Documents"
cd cppprog
と順に移動していけばいい。

だいたいなんでCマガの書いてあるようにやらないんだよ。

315 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:46:59 ]
>>312
strtokでも使え

316 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 14:49:51 ]
>>312
OSはおいといて、key と value の領域確保の問題が一つ。
もう一つは、keyが"="まで読み込んでしまうこと。
"%[^=]=%s"とかでどうか

317 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 15:40:26 ]
>314 問題は、漢字のフォルダ名をコマンドプロンプトへ
  打ち込めないことです。フォルダ名をローマ字に変えようと
してもできません。よろしく。

318 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 15:46:12 ]
>>317
コンパイラ起動できるようになるまで、Win板で聞いたら?
とりあえず>>300-301

ちなみに、
C:\Documents and Settings\大野\My Documents
は、エクスプローラーの「マイ ドキュメント」のことだって知ってたか?

319 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 15:57:57 ]
せっかく答えてもらったのに礼は言わない、
それどころかレスをまともに読んですらいない、
救いようがないなこりゃ

320 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 15:59:00 ]
さすがに釣りだろwww



321 名前:デフォルトの名無しさん [2007/08/23(木) 16:05:44 ]
おじゃまします。質問です。

typedef struct{
char a[2];
char b[3];
char c[4];
}AA;

typedef struct{
char e[16];
}BB;

AA aa;
BB bb;

…こんなんで、aaに代入された値をbbに一発で書き込んで、
しかもスペースで埋めてくれる関数とかありませんか?

VBからCに書き直してたら、LSetで一発だったので。。


322 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 16:13:02 ]
関数使わんでもできるけど、一発(スペース埋めるなら2発か)でやるなら
memcpy() と memset() でどうか

323 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 16:18:12 ]
>319 ありがとうございました。cd 大野といわれても漢字をコマンド
プロンプトに打ち込めないみじめさ。嬉しさも中ぐらいなり、秋の風。

324 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 16:21:37 ]
どうしても無理ならマウス使ってコピペ
右クリックかシステムメニューでできる

325 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 16:31:15 ]
Alt+半角/全角 で入力できるぜ

326 名前:321 [2007/08/23(木) 16:35:43 ]
>322
できました。ありがとうございます!

327 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 16:49:57 ]
>>322,326
構造体のパディングは大丈夫なのか?
文字列の連結ではないのか?
いやできたならいいんだけど。

328 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 17:09:58 ]
同じ型が続いてるなら多分パディングはないんじゃないかなあ。

329 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 17:13:26 ]
パディングはcharが並んでるだけだったからあえて書かなかったが
LSetの仕様を考慮しないとね。どっちにしても一発は厳しい

330 名前:デフォルトの名無しさん [2007/08/23(木) 19:09:03 ]
char *func_b( char *str, char ch )
{
char *p;
for( p = str; *p != '\0'; p++ )
if( *p == ch ) return p;
return 0;
}

これと同等の処理を行う標準ライブラリ関数を教えてください お願いします



331 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 19:18:28 ]
strchr?

332 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 19:18:52 ]
strchrかな

333 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 20:06:37 ]
Borland

334 名前:デフォルトの名無しさん [2007/08/23(木) 20:23:42 ]
>>331-333
ありがとうございます
strcharだと
char *func_b( char *str, char ch )
じゃなくて
char *func_b( char *str, int c)
になるんじゃないかと迷ってました

335 名前:デフォルト名無しさん mailto:1111111 [2007/08/23(木) 20:26:41 ]
プログラム実行できました。今日中にできるとは思いませんでした。
Borland C++ Compiler のつぎはTurbo Debuggerです。
ありがとう!ありがとう! >293,294,295,314,318,
325さんAlt + 半角/全角や漢字のコピペが可能だとは驚きでした。

まだいろいろ教えていただくこともあろうと思います。




336 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 20:26:46 ]
>>321

memset(&bb, ' ', sizeof(bb));
bb = aa;

これでいいような気がするんだが、
構造体の要素って順番に並んでるとは規定されてないけどね。

337 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 20:29:48 ]
>>334
char *strchr (const char *s, int c) だよ

338 名前:312 mailto:sage [2007/08/23(木) 20:38:42 ]
レス遅くなってすいません。

>>316の[^=]を使う方法を試したのですがうまくできなかったです。。。
strtokを使うしかないって事ですかね

339 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 20:39:29 ]
ttp://www.bohyoh.com/CandCPP/C/Library/strchr.html

340 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 20:40:21 ]
>>336
>構造体の要素って順番に並んでるとは規定されてないけどね。
またいい加減なことを…ここは入門者が答えるスレ?



341 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 20:41:54 ]
>>336
だからgets肯定派のダンディ坂野は回答しなくて良いよって言っただろ?
ったく、これだから夏厨は・・・

342 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 21:18:41 ]
>bb = aa;

343 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 21:30:38 ]
>>336
規定されてるよ

344 名前:336 mailto:sage [2007/08/23(木) 22:11:17 ]
>>340
>>336
お、ずっと勘違いしてた。やべ
ははははh

345 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 22:29:21 ]
パディングが挟まってる可能性はあるが、順番はそのまま。

346 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 23:08:32 ]
全くの初心者です。質問ですが、

#include <stdio.h>
main()
{
printf("Hello World\n");
}

を、Cygwinでコンパイルしたいのですが、うまくいきません。
何故でしょうか。

347 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 23:10:40 ]
エラーメッセージを読め

348 名前:デフォルトの名無しさん mailto:sage [2007/08/23(木) 23:30:46 ]
gcc インストールし忘れているに 100 ガバス

349 名前:デフォルトの名無しさん mailto:sage [2007/08/24(金) 10:08:44 ]
>>338
どううまくできなかったのか。
ちゃんと
*key は key[128]
*value は value[128]
とかにしたか?

350 名前:デフォルトの名無しさん mailto:sage [2007/08/24(金) 17:50:23 ]
ヘッダーファイルについて質問なのですが、自作ヘッダーにsleepという関数を
作るとします。実際この関数を使おうと#includeしようとしたら同じく#includeした
time.hライブラリーにも同じ関数がある事に気づきました。
同じ名前の関数がある場合、関数の使用優先度って何で決まるんですか?



351 名前:デフォルトの名無しさん mailto:sage [2007/08/24(金) 17:52:15 ]
>>350
多分リンクした順だけど、普通はリンク時にエラーがでると思うよ

352 名前:デフォルトの名無しさん mailto:sage [2007/08/24(金) 17:56:37 ]
先にldが見つけたほうではないかな?

ふつうは自作の関数の名前を変えると思うんだが

353 名前:デフォルトの名無しさん mailto:sage [2007/08/24(金) 17:57:20 ]
そうなんですか。eclipse,CDTで開発してるんですが、予想通りでした。
ありがとうございました。

354 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 00:37:04 ]
>>351
エラーは出ないんじゃないかな。
関数の戻り値なり引数なりの型が違うなら、
コンパイル時にエラーになると思う。
警告かも知れない。

355 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 01:27:57 ]
Japan 1 0 2
Spain 2 0 1
Egypt 1 2 0
のように入力して、数字を左から 3点 0点 1点分と数えて点数の高い順に並べ
Spain, 7
Japan, 5
Egypt, 3
のように出力したい場合二次元配列使うと思うんだけど、データの型はどうすればいい?
全部intで出力のときだけ %s,%d で合ってますか?


356 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 01:44:14 ]
>>355
おれだったら、構造体の一次元配列で処理する。

357 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 11:58:03 ]
struct hoge
{
char name[1024];
int mark;
}

358 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 12:24:47 ]
生のデータを持つために、
struct {
char name[1024];
int mark[3];
}

359 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 17:58:54 ]
a = (struct A *)buf;
b = (struct B *)buf+20;

Bの構造体にbufの20バイト後から取り出したいんだけど
この記述はできない?

360 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 18:07:15 ]
>>359 の記述のままでもおk
でも、>>359 は何か根本的なことが分かっていない気がする



361 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 18:07:53 ]
>>359
bufがchar *などであるなら、
struct B b=*(struct B*)(buf+20)

362 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 18:09:37 ]
>>360
すっとこどっこい。

363 名前:デフォルトの名無しさん mailto:sage [2007/08/25(土) 18:17:56 ]
offsetとか使いたいのではないのかなあ

364 名前:359 mailto:sage [2007/08/25(土) 22:23:25 ]
一応できた.
でもあんまり理解してないorz

365 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 00:57:24 ]
システムコールってC言語ですか?

366 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 07:15:28 ]
共用体(union)の中で構造体使うと
うまく領域を確保できなくてデータが変になる現象が起きてます。

今は使わない文字配列を共用体の中に書いて
無理やり余裕を持たせて領域確保してるんですが
共用体で使うメモリ領域をうまく確保する方法はありますか?

ちなみに環境はVineLinux4.1でgcc3.3.6コンパイラ使ってます。

367 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 07:24:22 ]
うまくいかないソースと現象の詳細を示せ

368 名前:366 mailto:sage [2007/08/26(日) 08:00:38 ]
説明しにくいんですけど
2Dのrobocup用ライブラリlibsclientをいじってて
http://www.koders.com/c/fidD6E7EBDD071F6F9579D1CAF12EF2FC434F5F7074.aspx
292~295行目
typedef struct _Ppos {
        WhichTeam team ;  // enum(WhichTeam=int)
        int unum ;
} PlayerInfo ;
に「int type;」というのを追加してライブラリとプレイヤーを再コンパイルして
実際にサーバーに接続してみたら動作が明らかに変になるんです。
312~317行目
        union {
        PlayerInfo player ;// 292~295行目の構造体
                Side side ;          // enum(Side=int)
                FlagPos fpos ;     // enum(FlagPos=int)
                LinePos lpos ;     // enum(LinePos=int)
        } id ;
ここに「char hoge[30];」を追加すると問題なく動作するようになるんで
共用体で構造体の大きさの領域が確保できてないという結論に至ったわけです。

369 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 11:14:49 ]
結論に至る前に sizeof で大きさを調べてみろ

370 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 13:08:10 ]
make cleanしてないんじゃねーの?



371 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 13:27:06 ]
>>365
システムコールはC言語でもサポートされていますが
システムコールはC言語ではありません

372 名前:366 mailto:sage [2007/08/26(日) 13:49:54 ]
>>370
それでしたorz
ライブラリとプレイヤ自体はmake cleanしてたんですが
ライブラリを読み込んでるプレイヤ共通の関数をまとめたやつをし忘れてました。

>>367,>>369,>>370こんな僕にレスしてくれてありがと

373 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 21:34:06 ]
相談なんですが,ファイルに以下のように保存されていて,
a[1]=AAA
a[2]=BBB
a[4]=DDD
これを以下のように新規で追加,削除,変更などしたい場合,
a[1]=AAA
a[2]=ABC
a[3]=DEF
一回全部読み込んでbufなどに保存し,それから一気に全部ファイルへ書き込む方法が
あると思いますが,それ以外に方法ありますか?


374 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 21:43:43 ]
>>373
固定長レコードもファイルならfseekで該当レコードのところにファイルポインタを
位置決めしてfwriteでレコードを上書き。

375 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 21:53:28 ]
>>373
データをファイルの最後尾に書き込みして
読み込み時、重複する場合は「もっとも後ろにあるデータ」を有効とするとか

たとえば

a[1]=AAA
a[2]=BBB
a[4]=DDD
  ↓
a[1]=AAA
a[2]=BBB
a[4]=DDD
a[3]=DEF
a[2]=ABC
a[4]=

読み込み時にデータ(a[2]=BBB)をデータ(a[2]=ABC)で上書きする感じ
a[3] は新規追加、a[2]は変更、a[4]は値なしなので削除

376 名前:デフォルトの名無しさん mailto:sage [2007/08/26(日) 22:01:50 ]
>>374
その標準関数を使ったことないんで調べてみます

>>375
その方法も考えたんですが,何回も書き込みを行うとデータが多くなり
読み込むのに時間がかかりそうなんで,有効データだけ残す方法をとりたいですね

お二人様サンクスです!検討してみます

377 名前:デフォルトの名無しさん [2007/08/27(月) 17:11:43 ]
超初心者ですみません。
2の0乗+2の1乗+2の2乗+2の3乗+2の4乗+・・・
というプログラムはどのようにしたらよいのでしょうか?
いろいろ調べてかいてみたのですができませんでした><
どなたかアドバイスお願いしますm(__)m

378 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 17:19:53 ]
1 + 2 + 2 * 2 + 2 * 2 * 2 + 2 * 2 * 2 * 2 + ...

379 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 17:40:04 ]
for(n=1, sum=0;;n*=2) sum+=n;

380 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 17:47:15 ]
>>377
しょぼくて申し訳ないが、
int hoge(int count){
 int result = 1; 
 if(count <= 0)
  return 1;
 for(int i=1;i<count;i++){
  result += 2*i;
 }
 return result + hoge(count-1);
}



381 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 18:12:29 ]
二進法で結果を出力するプログラムならこれでいいよ。

#include <stdio.h>

int main(void)
{
  for (;;)
    putchar('1');
}

382 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 18:14:02 ]
// ウンコード
int func(size_t n) {
int ret = 1;
size_t i;
for (i = 1; i < n+1; ++i)
ret += 1<<i;
return ret;
}

383 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 18:15:40 ]
ウンコードなんて、クソースのパクリみたいだな、¢50徴収するぞ?

384 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 19:00:13 ]
>>377
pow(2, n+1) - 1

385 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 19:40:33 ]
>>377
~(~0<<n)

386 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 20:01:40 ]
ビット演算凄いです^o^

387 名前:デフォルトの名無しさん [2007/08/27(月) 21:15:03 ]
Javaで言うところの「equals」ってC言語だと何ですか?

388 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 21:17:00 ]
Javaの何のクラスのequals?

389 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 21:17:59 ]
>>387
==

390 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 21:18:36 ]
>>387
C言語には対応するものはないかな?
C++なら、状況応じて==をequals風に定義しなおすことになる。文字列とか。
Javaのように==とequalsを明確に区別することはできない。



391 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 21:25:34 ]
Stringクラスのequalsならstrcmp関数だろ
あくまで、文字列比較という意味でね

もっとも、equalsメソッドはオブジェクトのデータの比較だから
そういう意味なら、オブジェクト指向でないCにはそれに該当するものはない

392 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 21:31:41 ]
memcmp (^^;

393 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:11:53 ]
Cの場合、
構造体だと、専用の比較関数作らなきゃならんね。

394 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:18:11 ]
Object.equalsだったら、ポインタに対する==演算子が最も当てはまる存在だな。

395 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:27:05 ]
387です
失礼しました、説明が足りなかったようで・・・
Javaでは、([変数].equals("○○○")) と書くところを
C言語だとどのように書くのかという意味です

396 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:31:16 ]
>>395
何も読んでないのか?
クラスによってequalsの挙動は違うだろうが。

397 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:31:47 ]
>>395
[変数]の型は何?
派生クラスでオーバーライドできるから、
クラスによって挙動が違い、Cで対応するものも異なる。

なお、Stringなら>>391

398 名前:デフォルトの名無しさん [2007/08/27(月) 22:48:56 ]
ファイルのプロパティの概要で表示されるタイトルに
そのファイルの拡張子を除いたファイル名を設定するプログラムを作成したいのですが
どのようにすればタイトルに書き込めるのでしょうか?

399 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:53:24 ]
>>395
if (strcmp(変数, "○○○”) == 0) ・・・

400 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 22:55:30 ]
>>398
プロパティ窓を取得、拡張子まで削ってSetWindowText



401 名前:398 [2007/08/27(月) 23:11:00 ]
>>400
プロパティ窓はどのようにして取得するのでしょうか?

402 名前:デフォルトの名無しさん mailto:sage [2007/08/27(月) 23:17:33 ]
>>398
IPropertyStorageでググればいろいろ見付かる。
ただし、Cでやるのは面倒。少なくともC++は欲しい。

なお、この情報は、NTFSの副次ストリームに保管される。
あるいは、OLE構造化ストレージ(2003までWord/Excelファイルなど)なら
ファイル自身に保管される(このため構造化ストレージならNTFSでなくても可能)。


403 名前:398 mailto:sage [2007/08/27(月) 23:20:09 ]
>>402
Cでは厳しいですか・・
調べてみます
ありがとうございました

404 名前:デフォルトの名無しさん mailto:sage [2007/08/28(火) 22:01:37 ]
t

405 名前:デフォルトの名無しさん mailto:sage [2007/08/29(水) 03:30:57 ]
>>404
ありがとうございました

406 名前:デフォルトの名無しさん [2007/08/29(水) 11:41:07 ]
377です。
みなさんありがとうございます><

407 名前:デフォルトの名無しさん mailto:sage [2007/08/29(水) 20:34:19 ]
* 引数 :char *data : 追加したい文字列
* : int index : 追加したい位置
* : element *new_data : 新しく追加するリスト
* 戻り値:成功1,失敗-1
*/
int add_data(char *data, int index, ELEMENT *new_data){
ELEMENT *tmp;
int cnt = 0;

if(data == NULL || index < 0 || index > element_cnt || new_data == NULL){
return -1;
}
new_data->data = data;
/* インデックスの位置の直前に移動 */

for(tmp = head;cnt != index;cnt++,tmp = tmp->next);
new_data->next = tmp->next;
tmp->next = new_data;
printf("help\n");
return 1;
}
こんな感じでリスト構造にデータを入れる関数を作ったんですが、
Borlandでは正しく動くのにVisual Studioでは呼び出しもとに返らず終了してしまいます
helpというプリント文は表示されます。どなたか、解決策を教えてもらえませんか?
↓がリストの構造体です
typedef struct element {
char *data;
struct element *next;
} ELEMENT;


408 名前:デフォルトの名無しさん mailto:sage [2007/08/29(水) 21:11:45 ]
>>407
そのソースだけだとわかんないなぁ
引数の「char *data」はその都度領域確保されているの?
それから「element_cnt」って要素数だよね?いつインクリメントしてる?

409 名前:デフォルトの名無しさん mailto:sage [2007/08/29(水) 21:14:25 ]
>>407
デバッガでも使って確かめろ位しか

410 名前:デフォルトの名無しさん mailto:sage [2007/08/29(水) 21:20:40 ]
>>408
そうですよね。>>409さんのデバッガを調べてみます
「char *data」はただダブルコーテーションで文字列を渡すだけしてます
「element_cnt」については処理を書き込み忘れました



411 名前:408 mailto:sage [2007/08/29(水) 21:31:46 ]
>>407
それから追加するインデックスを0にした場合は
実際に追加されるのはインデックス1の場所にならない?
0の場合headを書き換えないとおかしくなるんじゃない?

まぁあと/* インデックスの位置の直前に移動 */ といっているけど
cnt!=index ってことはindex の位置で止まる

>new_data->next = tmp->next;
index+1の要素を新要素の次の要素にする
>tmp->next = new_data;
indexの次の要素を新要素にする

結局追加される場所はindex+1の場所にならない?

412 名前:407 mailto:sage [2007/08/29(水) 21:50:13 ]
>>411
すいません!書き忘れてましたけど、headはstatic変数で今回ダミーとして扱います
ちなみにheadはhead->next = NULLで初期化してあります。

for文の初期化でtmp = head;とあるので、head->nextでダミーではない値をもつリストに入るときにはcntは1になっています
なのでcnt == indexはひとつ前になるんじゃないかな〜と考えてます。間違えてたらすいません




413 名前:408 mailto:sage [2007/08/29(水) 21:54:23 ]
>>412
つまり head->next が最初の要素ってことですね
なら納得です

だとすると、やはりこのソースからだと分かりませんね
私はここまでです

414 名前:407 mailto:sage [2007/08/29(水) 22:11:13 ]
>>413
そうですか、ありがとうございました。
原因はこれだけのソースではわからないと思うので、ななし.orgに全部のソースをアップしました
見てくれるなら見てほしいです。んでVisualStudioで実行してほしいです

まだ途中なんでできたらツッコミとかよろしくおねがいします



415 名前:408 mailto:sage [2007/08/29(水) 22:33:26 ]
>>414
そういうときはURLも貼ってくれないと
ななし.orgってどこですか?

416 名前:407 mailto:sage [2007/08/29(水) 22:43:24 ]
すいません。。ここです
77c.org/upload.php?fn=off&page=1

417 名前:408 mailto:sage [2007/08/29(水) 23:02:01 ]
>>416
まずここかな

void init_list(void){
ELEMENT top;
head = ⊤

element_cnt = 0;
head->next = NULL;printf("\(^o^)/");
}

ELEMENT top; は関数のローカル変数
head = ⊤
top の実体は関数抜けたら無効になる
にも関わらず 関数外でhead(top) にアクセスしてる

418 名前:407 mailto:sage [2007/08/29(水) 23:12:46 ]
>>417
ああ〜!そうですねw普通におかしいですね

419 名前:408 mailto:sage [2007/08/29(水) 23:16:02 ]
>>418
一応こちらの環境(BCC5.5)では>>417を改善することで動作はします
(もう少し動作チェックしてみますが)

それから余談ですが、ポインタ配列使うなら ELEMENT next いらないんじゃないですか?
せっかくポインタ繋ぎしてるんですから add_data() 内で new_data=(ELEMENT *)malloc(sizeof(ELEMENT)) してみては?
いまは動作チェックが目的でこうしているというならゴメンナサイね

それから最後にfree()も忘れずに

420 名前:407 mailto:sage [2007/08/29(水) 23:24:18 ]
改善しました!>>408さん、ありがとうございました!

関数内でmallocはしなくて良い、と言う問題だったので、main側で確保したんです。
自分も関数内で確保した方がいいと思うのですが・・・



421 名前:408 mailto:sage [2007/08/29(水) 23:52:07 ]
>>420
そういうことですか
分かりました
それらが題意であるならしょうがないですね

余計なことかもしれませんが、
remove_element() は要素を削除するんですよね?
この方法(配列上で行う連結リスト)だと要素を削除した後、その後追加する際に、
空いている要素と空いていない(使われている)要素の区別がつかないので
その点も考慮していく方がよろしいかと思います

422 名前:421 [2007/08/29(水) 23:53:29 ]
#include <stdio.h>
main()
{
static int a[5]={15,8,48,50,27}
int sum,heikin,i;
sum=0;
for(i=0;i<5;i++){
sum=sum+a[i];
}
heikin=sum/5;
printf("goukei=%d\n",sum);
printf("heikin=%d\n",heikin);


}

これにあと配列中の奇数と偶数の数を出力するのを追加したいんですが
どうすればいいんでしょうか?

423 名前:407 mailto:sage [2007/08/30(木) 00:02:53 ]
>>421
確かにそうですね。mainの考慮をしてみます!

424 名前:408 mailto:sage [2007/08/30(木) 00:05:50 ]
>>422
こんなんでどうですか?
配列中の値を2で割ってあまりが出るかでないかで奇数、偶数を判断

#include <stdio.h>
main()
{
static int a[5]={15,8,48,50,27}
int sum,heikin,i;
int kisu=0,gusu=0;
sum=0;
for(i=0;i<5;i++){
sum=sum+a[i];
if(a[i]%2) kisu++;
else gusu+++
}
heikin=sum/5;
printf("goukei=%d\n",sum);
printf("heikin=%d\n",heikin);
printf("奇数 %d個 / 偶数 %d個",kisu,gusu);

}

425 名前:408 mailto:sage [2007/08/30(木) 00:08:32 ]
>>422
ところでなんで 421 なんですかね?

>printf("奇数 %d個 / 偶数 %d個",kisu,gusu);
改行忘れたので入れといてください

printf("奇数 %d個 / 偶数 %d個\n",kisu,gusu);

426 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 00:09:46 ]
おまえも、関係ないなら名前の所の番号外せ

427 名前:422 [2007/08/30(木) 00:15:18 ]
>>425
ありがとうございます。

名前はミスして書いてしまったようです。すいません^^;

428 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 00:26:43 ]
怒られちった

429 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 21:19:36 ]
質問です。
例えば、データの処理(検索など)を行いながら、
同時に秒単位で経過時間を標準出力するといったようなことってできますか?
できるのであれば教えていただきたいのですが。

430 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 21:44:54 ]
>>429
検索のループ中に時間表示機能入れるなり、スレッド作るなり、signal使うなり
まぁ状況次第でなんなりとどーぞ。



431 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 23:14:55 ]
奇数偶数なら

if(a[i] & 1)
//奇数
else
//偶数

では?

432 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 23:18:54 ]
>>431
% 2 でなにか不都合なことがあるの?

433 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 23:22:31 ]
>>431
負数が2の補数表現で無い環境の場合はうまくいかないんじゃない?
(そんな環境があるかどうかは知らないが…)

434 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 23:38:35 ]
問題の中に負数がないからどっちでもいいよ

435 名前:デフォルトの名無しさん mailto:sage [2007/08/30(木) 23:58:46 ]
>>432
もちろん論理的な不都合はないです。
ただ除算は一般に非効率なので、高速化を狙った提案。ですが、、
>>433
たしかに、そうですね。
使用可能かどうかの確認は必要だと思います。

436 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 01:46:43 ]
>>435
大丈夫、まともなコンパイラなら%2を割り算では実装しないから。

437 名前:435 mailto:sage [2007/08/31(金) 02:43:21 ]
>>436
gcc -S で試したら、確かに論理命令が生成されてました。
しかもunsigned だと n % 1 と n & 1 は完全に同じコードに。
勉強になりました。流れ止めて失礼しました。

438 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 09:54:01 ]
> n % 1 と n & 1 は完全に同じコードに
バグじゃね?

439 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 09:57:08 ]
バグだな

440 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 10:08:56 ]
n%2の間違いだろ、突っ込んでやるなよw



441 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 15:31:29 ]
実数で計算した結果の小数点以下を切り捨ててて
整数のところだけを別の計算に使いたいのです。

どのようにすればできるのかでしょうか。

442 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 15:37:22 ]
>>441
一度 int にキャストする (正数のときのみ)、あるいは floor()。
入門以前のレベル。本くらい買え。

443 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 15:40:06 ]
472 名前:デフォルトの名無しさん[sage] 投稿日:2007/08/31(金) 14:55:28
浮動小数点の小数点以下を簡単に取る方法ってないですか?

473 名前:デフォルトの名無しさん[sage] 投稿日:2007/08/31(金) 15:13:39
f - floor(f)

444 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 18:40:31 ]
文字列とfor文についての質問です。
--出力結果--
sample01.txt
sample02.txt
sample03.txt
sample04.txt
sample05.txt
------------
上のように出力し、かつそれぞれを格納したいのですが、
数字の部分に繰り返し文を使ってうまくやる方法がわかりません。

おしえてくらはい><

445 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 18:52:51 ]
sprintf(fname, "sample%02d.txt", i);

446 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 19:08:26 ]
あまりの入門レベルにワロタwww

447 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 19:17:16 ]
入門篇だからいいんじゃね?

448 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 22:00:31 ]
でも入門書くらい読めよ、てのが少なくない。

449 名前:デフォルトの名無しさん mailto:sage [2007/08/31(金) 22:41:01 ]
>>445
うまくいきそうです!ありがとうございました!!

450 名前:デフォルトの名無しさん mailto:sage [2007/09/01(土) 00:38:58 ]
>>429
できなくはないが、C言語入門の範疇じゃないな。
OS関連のプログラミングを勉強しないと無理。



451 名前:デフォルトの名無しさん mailto:sage [2007/09/01(土) 01:05:03 ]
>>444
char filename[5][100];

for (i = 0; i < 5; i++) {
  sprintf(filename[i], "sample%02d.txt", i + 1);
  printf("%s\n", filename[i]);
}

452 名前:デフォルトの名無しさん [2007/09/01(土) 23:22:05 ]
uintptr_t とかsize_t型ってなんなんですか
これもwindowsプログラミング特有の、#defineした型なんでしょうか?

453 名前:デフォルトの名無しさん mailto:sage [2007/09/01(土) 23:23:29 ]
#defineはしてないと思うよ^^

454 名前:デフォルトの名無しさん mailto:sage [2007/09/01(土) 23:35:05 ]
>>452
size_tは標準の型。
unsigned intとかunsigned longあたりのtypedef。
strlen()のリターン値とかで使われてる。

uintptr_tは知らんけど、
docs.sun.com/source/806-4836/conv_v9.html
これを見ると、導入が予定されてるのかな?

455 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 00:12:21 ]
size_tは標準Cに入っている記憶域の大きさを表す型、
sizeof演算子の結果の型と定められている。

uintptr_tはC99から導入された<stdint.h>で宣言されている型の1つで、
ポインタをキャストしても表現を失わないと規定されている符号無し整数型。
VC++でも最近はuintptr_t/intptr_tだけ<stdlib.h>で宣言されている。
<stdint.h>ごと入れればいいものを。

Windowsプログラムなら、uintptr_tよりUINT_PTRのほうが良く見かけるな。
こっちはWindows APIの型とされているし、
VC++にuintptr_tが入るよりも前から存在していたから。

456 名前:デフォルトの名無しさん [2007/09/02(日) 00:43:43 ]
一週間ほど前にプログラミングをCから始めまして現在、
ttp://homepage3.nifty.com/mmgames/c_guide/05-02.html
まで勉強しました。そこで、もっといいサイトがあるよ〜
っていうのがあれば教えてくださいm(_ _)m
できれば書籍等も・・・・

教えて君で失礼しますた(´・ω・`)

457 名前:452 [2007/09/02(日) 00:48:08 ]
>>453-455
ありがとうございます。
なるほど、typedefでしたか・・・・。



458 名前:デフォルトの名無しさん [2007/09/02(日) 00:49:16 ]
>>456
とりあえずこのサイト全部終わらせればいいんでない

459 名前:デフォルトの名無しさん [2007/09/02(日) 01:12:37 ]
Cで正規表現を自前で実装しようと思っていますが速度面で微妙

アセンブラのほうがいいですかね?



460 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:14:35 ]
Cで速度でないなら、アセンブラでやっても大差ないと思う



461 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:14:41 ]
>>459
アルゴリズムの問題だと思われ。

462 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:15:54 ]
>>459
grepか何かのソース読んでみるのはどーか

463 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:23:43 ]
なにの正規表現と比べて遅いと思ったのか分からないけど、
その比較した正規表現の処理系も、おそらくCで書かれてると思われ。

464 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:28:48 ]
Cってメモリと文字列処理がだるいよな

465 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 01:35:56 ]
何をいまさら

って初心者ですか
そうですね

466 名前:デフォルトの名無しさん [2007/09/02(日) 05:17:20 ]
>>456
俺としては、今はもう読むこと無いけど
「C言語入門本物志向が身に付く本」;入門
「ポインタ完全制覇」:ポインタ関連
「文字列操作+ファイル入出力完全制覇」:文字通りの内容
全部「科学技術評論社」
あとは、一応K&R。入門本じゃないけど。
まぁサイトでいえばwisdomsoftかな。
他にも色々あるけど。まぁ、がんばってね

それにつけても、俺が今のレベルまでどうやって勉強してきたのか
さっぱりわからん。学びはじめの頃は
[putchar()//一文字出力する関数]なんてコメントを書きながら
ソース書いてたな。

467 名前:デフォルトの名無しさん [2007/09/02(日) 06:45:53 ]
今更Cなんてやっても・・・

CでOSや組み込み系のドライバをサクサク書けるようになるには10年はかかる

やっと使えるなって感じた頃は全く需要がない恐れがある

468 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 07:10:17 ]
>>467
10年もかからないよ
それに、C言語とOS、ドライバーは関係がない

469 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 07:12:09 ]
ドライバをCで書くなんてえらい時代になったもんだな
ってアセンブラ厨の老人が沸いてくるよ

470 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 08:05:57 ]
tuhsなんか読んでるとUnixはversion 6の時代(1974)にすでにデヴァイス
ドライヴァはCで書かれている。
むしろmkdirだのpasswdとかのユーザープログラムがアセンブラで書かれて
たりして笑える。



471 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 08:06:54 ]
version 6じゃなくてversion 5だった

472 名前:456 [2007/09/02(日) 08:46:32 ]
>>458,466
レス((ヾ(。・ω・)ノ☆゚+.ァリガトゥ
とりあえず今のサイト最後までがんばってみて、
終わったら466さんの紹介してくださった書籍
よんでみます^^

473 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 11:27:38 ]
>>464
個人的には文字列操作はダルいけど、メモリ操作は楽。

474 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 13:44:29 ]
>>469
C て高級アセンブラだよね
こんな言語で業務アプリ書くアホいないよな
って感じてた老人ならここにいますが...


475 名前:デフォルトの名無しさん [2007/09/02(日) 14:22:06 ]
>>468
あんたアフォですか?
OSを作成するためにCが作成されたのに・・・

476 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 14:26:53 ]
もはや関係がないってことだろう

477 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 15:22:49 ]
1000から9999までの4桁の数字で、各桁を足した数で自分を割りきれる数がいくつあるか調べるプログラムを作りました。
今回は1325という正しい答えを知っていたのでエラーに気づきましたが、答えがわからない場合はどんな風にデバッグしていますか?

478 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 15:26:44 ]
全部出力して、検算する。

479 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 15:30:12 ]
各桁の合計を求める部分、割り切れるかどうかを判定する部分、個数を数える部分を
それぞれ個別にテストしてみる。

480 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 15:34:28 ]
別のアルゴリズムで解いてみる。



481 名前:デフォルトの名無しさん [2007/09/02(日) 15:36:56 ]
>>477
そのようなプログラムをCで書かなきゃいけないか?w

excelで十分だろ

482 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 15:40:25 ]
答えを知ってるってことは課題かなんかだろう
それで>>477みたいな疑問を持ったんだからやる価値があったってことだろう

483 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 16:52:58 ]
cat.cより抜粋

/* Buffer for line numbers.
An 11 digit counter may overflow within an hour on a P2/466,
an 18 digit counter needs about 1000y */
#define LINE_COUNTER_BUF_LEN 20
static char line_buf[LINE_COUNTER_BUF_LEN] =
{
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ',
' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', '0',
'\t', '\0'
};

/* Position in `line_buf' where printing starts. This will not change
unless the number of lines is larger than 999999. */
static char *line_num_print = line_buf + LINE_COUNTER_BUF_LEN - 8;

/* Position of the first digit in `line_buf'. */
static char *line_num_start = line_buf + LINE_COUNTER_BUF_LEN - 3;

/* Position of the last digit in `line_buf'. */
static char *line_num_end = line_buf + LINE_COUNTER_BUF_LEN - 3;

484 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 16:55:36 ]
>>483の続き

/* Compute the next line number. */

static void
next_line_num (void)
{
char *endp = line_num_end;
do
{
if ((*endp)++ < '9')
return;
*endp-- = '0';
}
while (endp >= line_num_start);
if (line_num_start > line_buf)
*--line_num_start = '1';
else
*line_buf = '>';
if (line_num_start < line_num_print)
line_num_print--;
}

Cの基本的なことを勉強して、cat.cのソースを読んでいますが
この行を計算する関数の処理が何が言いたいのかわかりません。
line_bufを参照しながらカウントしているように見えますが、いまひとつわかりません。
どなたかご教授お願いします。

485 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 17:16:14 ]
www.google.co.jp/search?q=%E3%81%94%E6%95%99%E6%8E%88
>何が言いたいのかわかりません
何を聞きたいのかわかりません

486 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 17:37:21 ]
行番号を表す文字列をポインタ使って変更してるんじゃない?
"399" → "400"みたいに。

487 名前:468 mailto:sage [2007/09/02(日) 18:25:16 ]
>>475
OSを作成するためにCを勉強しているわけではないだろ
そう意味で関係ない

488 名前:デフォルトの名無しさん [2007/09/02(日) 18:37:35 ]
じゃぁ、なん為にやってるの?

文字列を逆順に表示したりするプログラムを書くためですか?hw


489 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 18:41:38 ]
普通はアプリケーションを作成するためにC言語を勉強するんじゃない?

490 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 18:42:26 ]
この先必要となる基礎としての勉強じゃないんですか?>>488



491 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 18:43:35 ]
英語を習うときに、目的を持つかどうかの違い棚。

492 名前:デフォルトの名無しさん [2007/09/02(日) 19:06:28 ]
失礼します。
変数Aに一秒ごとに1を追加していくようにしたいのですが、どうしたらいいのでしょうか。

493 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 19:07:30 ]
どうしてそんなことをする必要があるのかってところから考えたほうがいいよ。

494 名前:デフォルトの名無しさん [2007/09/02(日) 19:09:41 ]
>>493
いや、タイマーに使いたいのですが。

495 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 19:14:44 ]
>>492

main()
{
  int A = 0;
  while (1) {
    sleep(1);
    A++;
  }
}

496 名前:デフォルトの名無しさん [2007/09/02(日) 19:16:24 ]
>>492
つ time.h
使った事無いけど…orz

497 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 19:21:45 ]
CでMMOのBOT作れるんでしょうか?

498 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 19:22:16 ]
いいえ

499 名前:デフォルトの名無しさん mailto:sage [2007/09/02(日) 19:29:53 ]
タイマーの値が必要なときに、現在時刻を取得すればいいんじゃない?
時刻の取得の仕方は環境依存

500 名前:デフォルトの名無しさん [2007/09/02(日) 19:35:31 ]
>>495-496
ありがとうございます
試してきます



501 名前:487 mailto:sage [2007/09/02(日) 20:03:34 ]
>>488
> 文字列を逆順に表示したりするプログラムを書くためですか?hw
なかなかよいポイントをついているね

プログラミングの本質はデータの加工と入出力
世の中のすべてのプログラムは「文字列を逆順に表示したりするプログラム」

データーベースのアプリだって通信モジュールだって高度な科学技術計算のプログラムだって
みーんな本質的には「文字列を逆順に表示したりするプログラム」だ
OSもね


502 名前:デフォルトの名無しさん mailto:sage [2007/09/03(月) 05:33:18 ]
もっと軽い言語がたくさんありますよ今は

503 名前:デフォルトの名無しさん mailto:sage [2007/09/03(月) 20:21:34 ]
例えば何?

504 名前:デフォルトの名無しさん [2007/09/03(月) 23:10:59 ]
おい、五輪実況(男)で看板とか名無しとかLRとか決めるからおちょくりに来いよ
ヒント:なんかVIPの同盟国とかほざいてるから

live24.2ch.net/test/read.cgi/ootoko/1188634806/


505 名前:デフォルトの名無しさん mailto:sage [2007/09/04(火) 16:12:59 ]
>>503
スクリプト系の言語のことをいってんじゃないの?

506 名前:デフォルトの名無しさん mailto:sage [2007/09/04(火) 16:17:54 ]
スクリプト系はゲロ重だろ

507 名前:デフォルトの名無しさん mailto:sage [2007/09/04(火) 18:12:15 ]
int main(void)
{
do {
switch (getnum("番号を入力してください\n")) {
case 1:
question(1);
break;
}
} while (0);
return 0;
}

int getnum(const char *msg)
{
int n;

for (printf(msg); scanf("%d", &n) != 1;) {
while (getchar() != '\n');
}

return n;
}
ここで使われているgetnumがいまいち理解できません。
何をしてるいるのか教えてください。

508 名前:デフォルトの名無しさん mailto:sage [2007/09/04(火) 18:18:44 ]
printf(msg) は msg を表示
scanf("%d", &n) は数字を入力
!= 1 は scanf で数字が正しく入力されたか確認
while (getchar() != '\n'); は改行が来るまで入力を読み飛ばす
return n; は入力された数字を返す

これでおk?

509 名前:507 mailto:sage [2007/09/04(火) 18:40:35 ]
>>508さん
よくわかりました。
ありがとうございます。

510 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 16:50:33 ]
kansai2channeler.hp.infoseek.co.jp/cgi-bin/joyful/img/4898.txt
質問させてください。
+と-と|を使って升目を出力するプログラムです。
第一に40行目のところのコメントをはずすと最初のループはなぜ止まるのですか?
第二に40行目の部分のコメントをはずしたときに
47行目を切り取り、49行目の後に記述すると結果が変わるのはなぜですか?
いろいろ試すうちに2つ目の問題もでてきて分からなくなりました。
よろしくおねがいします。



511 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 16:54:42 ]
意味がわからない変数名はやめろ

512 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 17:09:32 ]
continueやめてbreakにすれば?

513 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 17:45:26 ]
>>510
> 第二に40行目の部分のコメントをはずしたときに
> 47行目を切り取り、49行目の後に記述すると結果が変わるのはなぜですか?
コンパイラのバグだと思われる。

514 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 18:09:57 ]
>>510
>>512も言っているけどswitch内のcontinueやめてbreakにするとこうなる

+---+
|   |
+---+
|   |
+---+


515 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 18:14:27 ]
>>510
確認してないけどたぶんあれね

continueにしちゃっているから44行目からwhile()の式評価にとんじゃっているんだと思う
実際には47〜49行目は実行されていない
本来は47行目に行かなきゃ行けないのでbreakにする

516 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 18:20:35 ]
32行目を下のように変更するだけで動作が変わるから、バグでしょ
while (d < e){

while (d < e){printf("");

517 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 18:26:23 ]
gcc は期待したとおりの動作になったが
bcc だと >>516 の変更前後で出力内容が変化した

変更前
+---+

変更後
+---+
|   |
+---+
|   |
+---+

518 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 18:28:46 ]
あっwhile (d < e)があったの気づかんかった
とりあえず>>515は忘れて

>>514は目的の動作が分からんので保留かな

519 名前:510 mailto:sage [2007/09/05(水) 18:42:26 ]
皆さん見ていただきありがとうございました。
continueで戻ることばかり考えていてbreakを忘れていました、
while文の中にあるのでcontinueを使わずとも繰り返しになるのですね、
whileとbreakとcontinueの使い方を再確認します。
変数名も以後気をつけます。

コンパイラのバグということで
他のコンパイラを試してみようと思っていたのですが
>>517さん試していただきありがとうございました。

520 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 21:23:40 ]
>>519
switch があるから、breakはそっちを抜けるだけで
whileにまで影響しないんだよ
switchとwhileが同じbreakなのは
たまに不便だがな



521 名前:デフォルトの名無しさん mailto:sage [2007/09/05(水) 22:16:45 ]
まぁそういう時は多少見辛くてもif-else使うかな。俺は。
ループフラグとかgotoとかキラーイ

522 名前:デフォルトの名無しさん [2007/09/06(木) 02:48:24 ]
struct node *hoge(struct node* a)
{
struct node *b;
    b = a;
    a = NULL;
 free( b );
 return a;
}

free関数の形式を調べてみるとvoid free(void *ptr);と書いてありました
ttp://www.bohyoh.com/CandCPP/C/Library/free.html

つまり、上記の関数を実行すると、引き数で渡されたポインタaがNULLを代入される前に指していた領域を開できるということでしょうか?

自分で調べてみて「たぶんあっているな。」とは思ってもどうしても確信できなくて不安になってしまいます。みなさんはそんなことありませんでしたか?(このレス二つ目の疑問です)

523 名前:デフォルトの名無しさん [2007/09/06(木) 04:23:10 ]
適当な結果を標準出力に出力しつつ時々
y/n を聞いてくるコマンド ques が
あったとします。y/n を検知して
代わりに y を入力してくれる
プログラムを書きたいのですが、
何をキーワードに検索してよいのか
すらわかりません。パイプで検索したのですが
何か違う感じでした。
よろしくお願いします。


524 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 07:33:36 ]
>>522
・できる。
・根本的にポインタを理解できていればそんなことはないと思う。

>>523
他に標準入力する項目がなく、quesが確実に標準入力を利用しているというのなら、
yes | ques
でOK。

525 名前:デフォルトの名無しさん [2007/09/06(木) 10:22:16 ]
>>524
すいません。C言語でやりたいのです。
それと質問に応じて no と答える場面もあります。
よろしくお願いします。


526 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 11:01:35 ]
>>525
それなら、パイプで間違ってないと思う。
コマンドの標準出力/標準エラー出力を監視しながら特定のパターンを認識したら、
コマンドの標準入力に対して、yまたはnを投げる。

>何か違う感じでした。
何を期待しているか知らないが、コンソールアプリでは
WindowsのGUIアプリのように、入力待ちになったとかのイベントが
飛んできて、そこに処理を記述するわけではない。
実装はどうしても泥臭くなると思うが。

527 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 11:03:40 ]
ファイル操作について質問なのですが、
もし現在の日付をfprintf("%d %d %d %d %d %d\n",local->tm_year・・・以下略
こういう風にファイルに保存したとしますよね。
このファイルを読み込むとき、
fscanf("%d%d%d%d%d%d",&year,・・・以下略という風に読み込んだとき、
何故yearという変数にはしっかりとyearで保存した数字が格納されるのですか?
説明下手ですみません。

528 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 11:07:05 ]
fprintf("%d %d %d %d %d %d\n",local->tm_year・・・
で書き込むと当然、
2007 09 06 ・・・
となるから、fscanf("%d%d%d%d%d%d",&year,・・・で読み込むときは
空白か改行まで読まれるので
2007
09
06
・・・
と順に読み込まれる

529 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 11:08:05 ]
なぜって言われても、それが fscanf という関数の機能なんだし。
どういう結果になると思ってた?

530 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 11:10:00 ]
なるほど・・・左上から順に変数に格納されるんですね。それなら呼び出す
順番に気をつけないとメチャクチャになりますね。分かって良かった。
ありがとうございました。



531 名前: mailto:sage [2007/09/06(木) 16:45:10 ]
すいません。gccの拡張命令について知りたいのですが
どこかに命令一覧が載ってるサイトってありますか?

532 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 16:52:09 ]
配列を引数として関数にいれて、関数でその配列の中身を表示しておいて
mainでその関数を100回くらいまわしたら
値がかわってくるんだけど何が原因だと思われますか?

配列は20要素で
引数は4つ使ってます。

533 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 16:56:09 ]
>>532
そりゃプログラムのバグでしょ
具体的にコード見せてくれないとそれ以上はわからん

534 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:09:10 ]
void makemake(---){ (これをmainと思ってください)
double ma[120][20];
double h1[20],h2[20],n[120];
int num;

fileinput(h1,h2,num);
for(i=0;i<120;i++){
n[i]=fmake(ma[i],h1,h2,num);
}
}

そしてfmake関数に渡します
double fmake(double a[20],double b1[20],double b2[20],int n){
int i;

for(i=0;i<20;i++){
printf("b1:%lf b2:%lf",b1[i],b2[i]);
}

}

まー一部なんでわかりにくいかもしれませんが。
fmake関数のprintfで20ループくらいまでは
きちんと表示されるんですけど途中でnanとかおかしな数字が表示されるんです。



535 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:10:21 ]
not a number

536 名前:532 mailto:sage [2007/09/06(木) 17:13:30 ]
534ですけどお願いします。

537 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:25:07 ]
そのファイルがおかしいんじゃないの

538 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:26:57 ]
>>536
思わず笑ってしまった。
>>535の not a number は>>534の nan を指してる。

NaN (Not a number)、日本語だと非数。

浮動小数点演算で、0除算など計算結果が正しく求められない計算を
したときに、値が正常でないことを示す特別な値が格納される。その値のこと。

繰り返しはまったく同じものを表示しているわけではないみたいだけど、
fileinputで読んできた値がすでにおかしいんじゃないの?

539 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:45:24 ]
>>534
fileinput をでっちあげて動かしてみたが、まったく問題ない。
省略した部分がおかしいと思われ。

540 名前:532 mailto:sage [2007/09/06(木) 17:46:27 ]
ファイル入力が間違ってるんじゃないかって指摘するってことは
プログラムはあってるってことですか
ありがとうございます。

どうしようもなくなったら直接fmakeにb1,b2のファイルいれますわ。



541 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 17:49:45 ]
>>540
プログラムもなにも、挙げられた断片だけでは何もしないコードに見え
る。fmake()は何も返してないし。


542 名前:532 mailto:sage [2007/09/06(木) 17:53:22 ]
正規分布のプログラムなんすよ。
double a[20],  データ120X20
double b1[20],  20次元の平均
double b2[20],  20次元の分散
int n      平均・分散の組。
式は書くの大変だから省いてるだけです。

543 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 18:02:25 ]
予想ではたぶんその式が悪い

544 名前:532 mailto:sage [2007/09/06(木) 18:04:15 ]
double fmake(double a[20],double b1[20],double b2[20],int n){
int i;

for(i=0;i<20;i++){
printf("b1:%lf b2:%lf",b1[i],b2[i]);
}

以上

545 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 18:06:14 ]
わからなければ計算したり配列弄るごとに中身出力してみ

546 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 18:30:27 ]
どこが悪いかわかんないのに、なんでそこが悪いと思うのか理解できない。

547 名前:デフォルトの名無しさん [2007/09/06(木) 19:15:12 ]
このソースがコンパイルできないんですけど
どこに問題があるんですかね?
コンパイラはgcc3.3.6です。
ttp://www8.uploader.jp/user/vipprog/images/vipprog_uljp00020.txt

548 名前:532 mailto:sage [2007/09/06(木) 19:33:26 ]
>>532て書いてるんですけど。
式はあってるんだよ確認ずみだから。
入力のプログラムがあやふやだからここで聞いただけ。

549 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:35:12 ]
はいはい。コンパイラのバグかなんかじゃねえの。

550 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:39:09 ]
そろそろ荒らし化しそうな予感



551 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:48:25 ]
こんなアホ相手にするお前ら優しいな

552 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:48:45 ]
よく言われる

553 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:51:32 ]
>>547
配列の宣言の仕方とsizeの扱い直せばいけると思う

554 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 19:53:07 ]
>>553追加でコンパイルするだけならsizeはそのままでもいいかも
連投スマン

555 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 20:18:46 ]
どんどん本性が出てきたな

556 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 21:39:02 ]
>>510 が、もう見てないだろうから、書いてみる
#include<stdio.h>

int main(void){
int x, y, width=3, height=4;

for(y=0;;y++){
for(x=0;x<width;x++) printf("+---");
printf("+\n");
if(y>=height) break;
for(x=0;x<width;x++) printf("| "" "" "); // コピペ用
printf("|\n");
}
return 0;
}

557 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 22:38:24 ]
殆どのネットゲームのBOTは C言語で開発されてるんでしょうか?
サイトありましたらおしえてください m)_ _m)

558 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 22:43:18 ]
無い

559 名前:デフォルトの名無しさん mailto:sage [2007/09/06(木) 23:16:50 ]
www.google.co.jp/

560 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 10:46:15 ]
>>559
ありがとうございました



561 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 12:55:50 ]
ネトゲのBots全てがCで作成されているかは知らんが
Cで作成できないことはない。
まぁ開発にあたっては、Cの知識だけでなく、それ以上の多くの知識が求められます。

562 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 14:31:57 ]
UWSCあたりならすぐに書けそうだな。

563 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 16:02:02 ]
関数は自分で積極的に作ったほうがいいですか?
それとも既存のものの効率的な組み合わせにこだわったほうがいいですか?

564 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 16:59:44 ]
既存のものの効率的な組み合わせをする関数を自分で積極的に作ったほうがいい

565 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 19:00:20 ]
>>564
ありがとうございます。なるほど!積極的に作ります

566 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 19:21:22 ]
グローバル変数として宣言する場合と、staticを付けて関数内で宣言する場合は
どういう違いがあるんでしょう?いくつかの説明文見たところ自分では同じように
思えるんですが、グローバル変数にstaticを付けるプログラムの例を見かけたので気になりました。

567 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 19:27:15 ]
static を付けないグローバル変数 → 他のファイルからでも参照できる
static を付けたグローバル変数 → 他のファイルからは参照できないが、同じソースファイル内ならどの関数からでも参照できる
static を付けた関数内の変数 → 他の関数からは参照できない

間違って書き換えたりしないように、見える範囲をなるべく最小限にする方が良い。

568 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 19:40:10 ]
>>567
ありがとうございます、アクセスできる範囲に違いがあるんですね。
つい値を保持できる期間ばかりに目が言ってたみたいです

569 名前:デフォルトの名無しさん [2007/09/07(金) 23:03:28 ]
入力された文字列が正しい文字列かを判断するプログラムなんですけど

#include <stdio.h>
#include <string.h>

int getflg(char wd);
main()
{
int n;
char word;
printf("文字入力:");
scanf("%s",&word);
n=getflg(word);
printf("flg=%d",n);
}
int getflg(char wd)
{
int flg=0;
if ( strcmp(wd,"あいうえお")==0 ){
flg=1;
}

return flg;
}

これだとエラーがでるのですがどうすればよいのでしょうか;;

570 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:06:22 ]
>char word;
>printf("文字入力:");
>scanf("%s",&word);

え?w



571 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:08:53 ]
>>569
「文字」ではなく「文字列」だから

#include <stdio.h>
#include <string.h>

int getflg(char *wd);
main()
{
int n;
char word[20];
printf("文字入力:");
scanf("%s",word);
n=getflg(word);
printf("flg=%d",n);
}

int getflg(char *wd)
{
int flg=0;
if ( strcmp(wd,"あいうえお")==0 ){
flg=1;
}
return flg;
}

だね

572 名前:569 [2007/09/07(金) 23:13:04 ]
>>570
すいません

>>571
文字だと&が必要で
文字列だと&は必要ないということですかね?

あと*wdにするのはなんでですかね?汗

573 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:18:20 ]
>>572
>文字列だと&は必要ないということですかね?
必要ない

>scanf("%s",word);
>if ( strcmp(wd,"あいうえお")==0 )
文字列同士の比較をしたいわけでしょ

char wd だと1文字だけしか渡せない、文字列として渡したいならポインタとして渡すしかない
char *wd は文字列のポインタを渡している

574 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:30:21 ]
#include <stdio.h>
#include <string.h>

int getflg(char *wd);
main()
{
int n;
char word[20];
printf("文字入力:");
scanf("%s",word);
n=getflg(word);
printf("flg=%d",n);
}

int getflg(char *wd)
{
return !strcmp(wd,"あいうえお") ? 1 : 0;
}

575 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:34:11 ]
>>534
> double ma[120][20];
これでスタックフレームを何byte消費しているか理解しているか?

static double ma[120][20];
static double h1[20]
static double h2[20]
static double n[120];
にしてみろ

これで結果がお前の予想通りになったなら
コンパイラはお前の予想通りには動かないということを知っておけ


576 名前:569 [2007/09/07(金) 23:35:04 ]
>>573
char wdだと1文字だけなんですか?

577 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:41:55 ]
>>575
> これでスタックフレームを何byte消費しているか理解しているか? 

たった、18,9Kじゃん。


578 名前:569 [2007/09/07(金) 23:47:17 ]
>>576をちと言い換えたいんですが、

int getflg(char wd[])
と違いは何かありますか??

579 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:52:06 ]
>>578
int getflg(char wd[]);

int getflg(char wd);
の違いが理解できない奴はCをする資格が無い

VBかJavaScriptあたりで妥協しておくことをお勧めする


580 名前:デフォルトの名無しさん mailto:sage [2007/09/07(金) 23:54:25 ]
理解できないっていうか、こういう基本的なところをネットで訊きながら進めるのって、効率悪すぎだろ。
入門書でも買えばいいのに。



581 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 00:14:43 ]
Cでは文字列変数というのはなくてバイト(char)の配列として扱っているんだよね
ほかの言語ではまずありえないことだけど

582 名前:569 [2007/09/08(土) 00:33:22 ]
>>580
基礎的なHPをいろいろ探してみてきたが

int getflg(char *wd);
これだと、ポインタによる引渡しで

int getflg(char wd[]);
これだと、wdに文字列を直接代入する的なものですか?

583 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 00:33:43 ]
haskellもそうじゃなかったっけ

584 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 00:34:39 ]
>>582
いや、ややこしいことに
int getflg(char *wd);

int getflg(char wd[]);
は同じ

585 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 00:38:23 ]
>>582
C FAQのポインタあたりを一通り読んでみるとか。

www.kouno.jp/home/c_faq/

586 名前:581 mailto:sage [2007/09/08(土) 00:38:56 ]
>>582
ちがいます

Cではchar wd[]とchar *wdはほぼ同じ扱いです

587 名前: mailto:sage [2007/09/08(土) 00:41:32 ]
でも配列とポインタだと&かましたときの値が違うんじゃないの?

588 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 00:45:14 ]
関数の宣言で使用する場合は同じ(ポインタと解釈)。

589 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 01:04:12 ]
>>586
ちがいます

Cでは関数の引き数の宣言において、char wd[]とchar * wdは全く同じ扱いです。

590 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 01:10:48 ]
char wd[10]
とか書くとまた変わって来るからややこしい。



591 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 01:45:54 ]
int getflg(char *wd); も
int getflg(char wd[]); も
int getflg(char wd[10]); も
int getflg(char wd[42]); も一緒

592 名前:デフォルトの名無しさん [2007/09/08(土) 02:30:12 ]
すみません、質問です。C言語でmallocによる動的な領域確保の勉強をしています。
char型の領域を動的に確保してそこにコマンドライン引数のargv[i]を格納していきます。

void main(int argc, char *argv[]){
  int i;
  char *hikisu;

  for(i=0; i<argc; i++){
    hikisu[i] = (char *)malloc(sizeof(char));
    memset(hikisu[i], NULL, sizeof(char));
    strcpy(hikisuu[i], argv[i]);
  }
}

これでコンパイルが通らないのですが、何が悪いのかよくわかりません。
ご教授お願いします。


593 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 02:38:44 ]
>>592
動的確保以前のポインタの勉強をしなおせ。
--
// インクルードファイルを適切にインクルードしていない
void main(int argc, char *argv[]){
// mainの戻り値型はintにするべき
// 中括弧は別の行に書くのが一般的
  int i;
// 一文字変数はインクリメンタルサーチしにくいからお勧めしない
  char *hikisu;
// ポインタ変数は、ポインタ一個しか保持できない。引き数を複数保持したいなら、これではダメ

  for(i=0; i<argc; i++){
    hikisu[i] = (char *)malloc(sizeof(char));
// malloc()の引き数はバイト数。これでは1バイトしか確保できない
    memset(hikisu[i], NULL, sizeof(char));
// malloc()したエリアをmemset()で潰してしまうのはナンセンス(一部に妄信者はいるが)
// つーか、引き数が無茶苦茶
    strcpy(hikisuu[i], argv[i]);
// これも引き数が間違っている
  }
}
--
まぁ、取り敢えずこの辺にしておいてやるかw

594 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 02:44:46 ]
>>592
stdlib.hがincludeされてない。
strcpy(hikisuu[i], argv[i]);
「hikisuu」はどっから出てきた?(タイプミス?)

この2つ直すととりあえずコンパイルは通るかもしれない。(コンパイラ次第)
が、落ちる可能性が高いな。

ていうかコンパイルのエラーを書け。

595 名前:デフォルトの名無しさん mailto:age [2007/09/08(土) 21:00:46 ]
Javaにはメソッドのコメントの書き方で、
/**
@param
@return
*/
のようなのが決まっていて、これでHTMLのドキュメントを自動作成できますが、
Cにはそのようなものはありますか?

596 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 21:03:28 ]
つ[Doxygen]

597 名前:595 mailto:age [2007/09/08(土) 21:25:58 ]
レスありがとうございます。
できるだけ標準的なものを使いたいのですが、そのDoxygenというのはよく使われていますか?
もしJISやISOやその他の標準化団体の制定した書式があるようならば、教えて欲しいのですが。

598 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 21:28:38 ]
標準化はされてない

デファクトスタンダードには近いかも

599 名前:デフォルトの名無しさん [2007/09/08(土) 23:08:08 ]
戻り値で成功か失敗かの判定だけ必要なとき、
成功は0で、失敗は-1で返すのがいいんでしょうか?
古いCの関数はこれが多いですよね。
成功は1で失敗は0にすると、判定側でif(!func()){ printf("error"); }
のような書き方ができるので、これの方が便利な気もするのですが、
どっちがいいんでしょうか。

600 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:16:04 ]
>>599
古いCの関数っていうか、unixのシステムコールだろ。



601 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:24:16 ]
>>599
俺は自分でSUCCESSとFAILUREをdefineして使うのが好き。
SUCCESSが1でも0でもif(func!=SUCCESS)と書く。

この辺は好みじゃね?

602 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:40:14 ]
シンプルに0か0以外がいいよ。
いろいろ値が定義してあると、読むのに負担がかかる。

単純なTRUE,FALSEでも、0以外と0になっているかとか、定義が一箇所かとか気にする必要あるし。
いまやってる仕事なんて、RTN_OKとRTN_ERRだけかと思ってたら、RTN_NODATAとか返してたり返した無かったり
するし。

603 名前:デフォルトの名無しさん [2007/09/08(土) 23:55:20 ]
あるディレクトリにある、大量のファイル(ファイル名は***1.dat、***2.dat、***3.datと1000個ぐらい続く)
を順番に読み込みたいのですが、どのようにすれば良いのでしょうか?
通常のファイルを開く方法(fopen)では、指定ファイル名をしてforループで回して変更するとかいう事が出来ない
みたいなので困っています。どなたかご教授よろしくお願い致します。

604 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:58:01 ]
普通に一個ずつ順番に読めばいいんじゃないの?

605 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:58:21 ]
>>603
OSのAPIに頼ってディレクトリのファイル名一覧を作る。
で、順番にfopenか何かで開く。

606 名前:デフォルトの名無しさん [2007/09/08(土) 23:58:49 ]
ファイルシステムを直接読めばいいのでは?

607 名前:デフォルトの名無しさん mailto:sage [2007/09/08(土) 23:59:52 ]
ファイル名が連番になってるのならforループで舞わせばいいい。

608 名前:デフォルトの名無しさん [2007/09/09(日) 00:00:30 ]
つ system

609 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 00:00:39 ]
>>603
ファイル名が規則的なら、、ループで回して処理できるよ。

610 名前:デフォルトの名無しさん [2007/09/09(日) 00:10:34 ]
age



611 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 00:31:10 ]
***1.dat、***2.dat、***3.dat てことは連番だな

612 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 00:42:52 ]
int i;
FILE *fp;
char filename[12];
for (i = 1; i <= 1000; i++) {
sprintf(filename, "***%d.dat", i);
fp = fopen(filename, "r");
以下略

613 名前:603 [2007/09/09(日) 00:50:17 ]
>>612
どうもありがとうございます。
sprintfという関数を知りませんでした。
非常に助かりました。

614 名前:デフォルトの名無しさん [2007/09/09(日) 12:21:33 ]
すみません 初心者です。
この最後のFor文は何をしているのですか?
よろしくお願いします。

int wk1;
char DateT[10+1];
char bufs[128];

DateT[0] = "2007/10/01"
memset( bufs, 0x0, sizeof(bufs) );
memcpy( bufs, DateT+ 5, 2 );
wk1= atoi(bufs); wk1-= 1;

for( i=6; i>=5; i--, wk1/=10 )
DateT[i]= (char)((wk1%10)+'0');

615 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 12:31:14 ]
10 月を 09 月に変えてるんじゃね?

616 名前:デフォルトの名無しさん [2007/09/09(日) 12:33:45 ]
月の値、01〜12を00〜11に置き換えている。

617 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 12:37:52 ]
>614
とりあえずそのコード、コンパイル通らなくない?
質問するくらいだから自分で書いたコードじゃないんだろうけど、あんまり参考にしたくないコードだと思う。
で、for 文限定だと

短い答え:数値を文字列に変換している。
もうちょっと長い答え:
wk1 % 10 で wk1 の一の位の数値を得る。
これに '0' ('0' の文字コード値を足すと 0 なら '0' に 1 なら '1' と数値→文字の変換が出来る。
wk1 /= 10 で十の位が一の位に移って繰り返し。

618 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 12:51:37 ]
>>614
?? DataT[0] = "2007/10/01"
そいつは、通らねえよ。

それにしても、俺の現場にあるソースに似てるwまさかww



619 名前:sage [2007/09/09(日) 13:47:36 ]
>>615
>>616
>>617
>>618
どうもありがとうございました。助かりました。
私の知り合いが解析しているソースを
出来ないなりに私も手伝おうかと思って頭から調べているときに
ひっかかった次第です。
自分はもう少しCの勉強が必要ですね。orz






620 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 13:50:39 ]
恥ずかしいんでsageます。
失礼しました。




621 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 20:40:55 ]
2chのスレッドの仕組みについても学んでください
sageで書き込んでもスレッドは下がりません

622 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 21:54:44 ]
いまリストでキューを実現しようと考えてるのですが、うまくデータを入れることができません
どうすれば改善できるか見てもらえないでしょうか?

www.dotup.org/ C言語ってコメント入れているファイルです

623 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:06:18 ]
普通、キューに入れるときに動的にメモリ確保するんでない?

624 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:08:41 ]
>>622
根本的に改善する余地あり
改善案は次の通り(命名に付いては適当に変えたほうが良い)

QUE *queue_init(void);
void queue_terminate(QUE *que);

int queue_enque(QUE *que, void *data);
void *queue_deque(QUE *que);

int queue_size(QUE *que);

625 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:12:52 ]
キューのデータそのものと頭とケツの位置とかを保持する管理構造体を作って、それをQUE構造体とすべき

626 名前:622 mailto:sage [2007/09/09(日) 22:17:55 ]
>>623
確かにそうですね。とりあえず今回はって事で書きました
>>623
queue_terminateはどういう処理をしますか?
>>625
そうします

627 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:21:08 ]
>>624じゃないが、
QUE *queue_init(void); → QUE型のメモリ割り当て、初期化
void queue_terminate(QUE *que); → 保持しているキューデータのメモリ解放、QUE型をメモリ解放
だと思う。まぁC++のあれだよね^^

628 名前:622 mailto:sage [2007/09/09(日) 22:42:24 ]
>>627
そういう事ですか、わかりました

根本的な改善はわかったんですが、今回のデータを入れることができないっていう事の
改善策はありませんか?
また次も同じことになりかねないので・・・

629 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:57:07 ]
>>626
いそいで作ってみた
バグあるかも
ttp://2sen.dip.jp:81/cgi-bin/upgun/up1/source/up8249.lzh

630 名前:デフォルトの名無しさん mailto:sage [2007/09/09(日) 22:57:11 ]
構造が悪いから分かりにくくなってるだけ



631 名前:624=629 mailto:sage [2007/09/09(日) 23:04:25 ]
引数チェックが甘かった orz
まあいっか

632 名前:622 mailto:sage [2007/09/09(日) 23:15:53 ]
>>629
拝見しました。管理用とデータ用の構造体を作ったほうがいいことがよくわかりました
参考にさせてもらいます。ありがとうございます〜

633 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 00:00:07 ]
>>632
>>629 の不完全型はデータを隠蔽するのに便利!
オススメのテクニックだよ

634 名前:デフォルトの名無しさん [2007/09/10(月) 13:51:08 ]
西暦と月を入力すると,以下のようなカレンダーを出力するプログラムを作成せよ
閏年にも対応すること.
西暦年が4で割り切れる年は閏年
ただし、西暦年が100で割り切れる年は平年
ただし、西暦年が400で割り切れる年は閏年
指定された年,月の一日の曜日を求めると良い.曜日を求めるには,Zellerの公式を使う.年も月も整数型の変数を用い,日の部分は1に置き換えること.
(年+年/4-年/100+年/400+(13*月+8)/5+日 )%7
1月と2月は前年の13月,14月として考える.
この式の答えと曜日の関係は以下の通り.
0:日曜日,1:月曜日,2:火曜日....,6:土曜日
Sun Mon Tue Wed Thu Fri Sat
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31


このようなプログラムを作りたいのですがちんぷんかんぷんでまったくできません。

よろしければ見本のようなものを作ってもらえないでしょうか。
お願いします。





635 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 13:54:01 ]
丸投げは宿題スレ

636 名前:デフォルトの名無しさん [2007/09/10(月) 14:01:37 ]
すれ違い申し訳ありませんでした。

637 名前:デフォルトの名無しさん [2007/09/10(月) 14:04:46 ]
Cで構造体を初期化するとき {0}を代入するのと、memsetで0をセットすることの違いはなんでしょうか?
typedef struct tagAAA {
 int a;
 int b;
 int c;
} AAA, * PAAA;

AAA aaa1 = {0};
AAA aaa2;
memset(&aaa2, 0, sizeof(AAA));

おしえてください。

638 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:27:28 ]
浮動小数点型やポインタ型のビット表現がゼロとは限らない

639 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:38:39 ]
>>638
memsetでもそれは同じではないの?
両方、構造体のサイズ分、0 でクリアされるとおもってるんだけど。

640 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:43:38 ]
>>637
memsetで0をセットは百害あって一利なし。使わないほうがよい。
構造体を初期化したいときには、各々の構造体メンバー変数に対し、
決められた初期変数を代入すること。

memsetが唯一有効なのは、メモリーをバイナリーエディッターで除くとき。

反論↓↓↓



641 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:45:29 ]
>>639
doubleの0x00000000は0.0と保障されているわけではない。
ということでしょ。

642 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:46:49 ]
えーと↑↑↑

エディッターのあたりがよくわからない

643 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 14:50:06 ]
初期化でBYTEレベルでALL 0 にしたい場合は、
= {0} での初期化と、 memset での初期化の違いはあるの?

@ AAA aaa1 = {0};
A AAA aaa2; memset(&aaa2, 0, sizeof(AAA));

は同じことをしているのかということです。

644 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 15:17:06 ]
構造体は知らないけど、配列の場合はコンパイルすると同じコードになるって前にみかけた気がする。

645 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 15:28:18 ]
>>643
コンパイラによっては、{0}の方が、より最適化される可能性が高い。


646 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 15:29:45 ]
>643
@ graceful
A rude

647 名前:デフォルトの名無しさん [2007/09/10(月) 15:58:29 ]
指定の行の削除方法が分かりません

例えば下記のようなファイルがあり

あいう
あああ
いいい
ううう

これを「いいい」だけ削除して下記のようにしたいのですが、1行だけ削除するようなやり方がわかりません

あいう
あああ
ううう

やりかたをご教授いただけないでしょうか


648 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 15:59:05 ]
サンプルとかみても memset のほうがおおい。
AAA aaa1 = {0}; とかで構造体を初期化しているのってほとんどみないような。

649 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:01:45 ]
>>648
なんで、構造体を初期化する必要があるの?
構造体メンバーを初期化する必要はあると思うが、構造体全体の初期化はあまり意味がないだろう。

650 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:03:13 ]
そもそも、初期値が0とは限らない。



651 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:04:28 ]
windows api つかうときってmemsetで初期化することあるでしょ。
CRITICALSECTIONとか、RECTとか。いちいちメンバごとに初期値いれるソースとかみたことないよ。
いったん初期化してから個別に値いれることはあるけど。

652 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:11:33 ]
@ AAA aaa1 = {0};
A AAA aaa1; memset(&aaa1, 0, sizeof(AAA));

@=A FA?

653 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:18:14 ]
={0} は浮動小数点やポインタも正しく 0.0 や NULL に初期化される。
memset で全ビットを 0 にする方法では、処理系によっては浮動小数点やポインタが 0.0 や NULL にならない場合がある。
@≠A

654 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 16:45:34 ]
>>653
ありがとう。すっきりしました。

655 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 17:37:39 ]
>>647
改行コードで区切って、消す行の後を違う領域に分けた後、消す行のところに繋げる

656 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 20:07:43 ]
memsetで初期化のクセを覚えてしまうと、
C++のクラスのオブジェクトに対してもそれをやりそう。

657 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 20:45:13 ]
コンストラクタがまさかのmemset呼び?

658 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 20:49:28 ]
>>657
うちの連中ならやりそうだw
ところで、>>637のは
AAAA aaa1 = {}; //{0}の0省略
はできないの?C++の本に乗ってたんだけど、Cでも試したら出来てそうなんだけど。

659 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 21:05:36 ]
>>658
エラー E2264 式が必要といわれた

@BCC5.5


660 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 21:06:25 ]
>>658
C++ならできた。CL.EXE



661 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 21:09:58 ]
>>658
ANSI C的には文法違反。
{}の中には少なくとも一つの式がいる。

662 名前:658 mailto:sage [2007/09/10(月) 22:42:45 ]
>>659-661 なるほど。情報サンクス。
gccではc89,c99モードにしてやっても出来るみたいなんだけど、
c99はまだ完全なサポートではないし、ことさら制限する様なことはしないのかも。
jiscのサイトから拾ったC言語の文書では、省略可を表すopt記号が無かったからやはり省略不可みたい。
参考)ttp://www.jisc.go.jp/app/pager?id=123813

663 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 22:49:09 ]
Cを無料でダウンロード出来るトコなんてないですかそうですか

やっぱり電気屋とかで買うんですかね?

664 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 22:50:54 ]
てめぇ〜〜〜ら、一生に一度の俺の質問に答えてくれ!
どうしてC言語の勉強を始めたの?

665 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 22:52:24 ]
日本語を無料でダウンロード出来るトコなんてないですかそうですか

やっぱり日本とかで買うんですかね?

666 名前:663 mailto:sage [2007/09/10(月) 23:11:01 ]
>>665
楽しいか?

667 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:14:07 ]
>>664
遊ぶのに理由がいるのかい?

668 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:17:54 ]
>>667
遊びというのは個人的な理由。ではなぜ C言語を選んだ かの理由は???

669 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:19:06 ]
>>667
君、そういうことを言ってしまうと、自分にとって遊びだからという理由で
なぜその遊びを選んだかの理由は関係ないじゃ〜〜んって無責任な人間になってしまうよ?
なぜなら、殺人を遊びに選んだら、なぜ殺人をしたんですか?という質問に対して
君は常に「遊びだから」という身勝手な言い訳をし続けることになるから。

670 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:19:58 ]
身勝手かどうかは主観に依存するよな。



671 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:30:07 ]
>>670
殺人を遊びという理由は身勝手。なんで殺人をしてしまったのか?
という理由が述べられていない。ただの愉快犯なら情状酌量の余地なし。
すぐさま死刑で良いでしょうw

672 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:31:01 ]
>>670
要するにお前は理由もなくC言語をやっていたんだ。まぁあれだろ
通っていた学校でやらされた程度で、実は面白くないと?w

673 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:31:47 ]
同意。身勝手かどうかを判断する客観的な主体は存在し得ない。

深読みしてみると質問の趣旨は、なぜ数あるプログラミング言語の中から
Cを選んだのか?ってことなんかな。つか複数使える人のほうが多いと思うがね。

674 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:34:14 ]
>>664
単位取得に必要だったからやった
今も後悔はしていない

675 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:36:05 ]
まぁ、普通に答えると始めたきっかけは高校でやらされたからに他ならない。

676 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:38:04 ]
何も知らないころよく聞く言語名がCだったから、かなぁ

677 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:39:48 ]
>>663
環境書かないと分からんだろが!
サンプルソースが欲しいのか
コンパイラが欲しいのか
何が欲しいのかもよく分からん

フリー
コンパイラ
www.google.co.jp/

678 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:42:10 ]
>>677
>>665

679 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:43:09 ]
>>664
きっかけは、情報処理技術者試験のためデス。
学校でFORTRAN習ったけど、当時自宅のMS-DOS環境で開発環境を入手できたのがCだった。

680 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:52:47 ]
>>664
最初は高校でやったMS-BASIC(だったか?)によってプログラミングが楽しくなり
学校においてあった8ビットCPUのポケコンをさわり、欲しくなったので先生に頼んで取り寄せ、16ビットCPUのポケコンを購入
インタプリタで動作するCが組み込まれていてBASICより面白いと思う
大学で自分のPCを買えるようになってコンパイラ方式のCをはじめる



681 名前:デフォルトの名無しさん mailto:sage [2007/09/10(月) 23:59:48 ]
>>673
遊びこそ主観だろ、答えたくないバカは黙ってろよ。歩インポイントでお前を
名指しして質問されているわけじゃないだろ?w お前みたいな基地外にはむしろ聞いてないって。
それから、何が主観かなんてどうでも良いんだよ。理由がいえないなら黙ってろ

682 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:00:22 ]
うひょっ、わけわからない入力をしてたw
歩インポイント > お前にピンポイント

683 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:05:49 ]
動的に確保した領域の大きさってどうやったらわかりますか?

684 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:08:23 ]
>>667
全員が全員、遊びでC言語をやっているわけじゃないと思うんだが?
勝手にC言語=遊びみたいなことを言うなよw
お前の場合は遊びに理由がって関係ない話をしているだけ。
お前にとっては遊びで始めたというのが理由であって、C言語は遊びじゃないぞ。

685 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:23:04 ]
>>683
どこかに書いておけばいい

686 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:26:06 ]
自転車置き(ry

687 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:26:39 ]
int *a;

のとき、
aはポインタのアドレス
*aはポインタに格納された値
なんですよね?
じゃあ
&aだと何を表すんですか?

688 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:27:33 ]
>aはポインタのアドレス
いいえ

689 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:28:22 ]
じゃあなによ?

690 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:34:50 ]
aはポインタ型の変数
また、&aはaという変数へのポインタ





691 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 00:34:52 ]
ポインタ

692 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 01:01:04 ]
>>687
*aはポインタが指し示すオブジェクト。とでもいった方がよいかな。
値といっても=の左辺になれる事を理解すること。

693 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 01:20:04 ]
aは、int型のオブジェクトのアドレスを格納するポインタ型の変数=ポインタ。
*aはポインタが指し示すオブジェクト。
&aで、int型のポインタ変数aのアドレスを参照できる。

int a = 10;
int *p;
p = &a;
printf("aのアドレスは%p\n", p);
printf("aのアドレスは%p\n", &a);
printf("aの値は%d\n", *p);
printf("aのポインタのアドレスは%p\n", &p);

これであってますか?

694 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 01:25:53 ]
おk

695 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 01:27:08 ]
>>695
*p = 20;
などの操作をして、aの値を確認してみるのも良い。

696 名前:695 mailto:sage [2007/09/11(火) 01:28:16 ]
ミスった
>>693ね。

697 名前:687 mailto:sage [2007/09/11(火) 01:39:59 ]
なるほどよくわかりました
ありがd

698 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 02:53:25 ]
コンパイラがVisual C++ 2005 Express Edisionでstring,hが開けないって出るんだけど何ででしょう?

定義は#include <string,h>って書いてるんですけど他に何か設定しないとダメですか?

699 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 02:56:20 ]
string,hじゃなくてstring.hじゃないか?

700 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 02:57:25 ]
×string,h
○string.h
というオチじゃないだろうな?



701 名前:698 mailto:sage [2007/09/11(火) 03:02:51 ]
そ れ だ

メモに貼り付けてフォント変えたら違いが判った
ありがとう!

702 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 06:39:00 ]
>>680
> 16ビットCPUのポケコンを購入
> インタプリタで動作するCが組み込まれていて

メーカー教えて


703 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 06:51:08 ]
文字配列とポインタで質問です

char *str[]={”山田”、”井之上”、”御手洗”、”鈴木”};

とした場合
配列は

char
str[0][0]="山", str[0][1]="田", str[0][2]="\0", str[0][3]="\0"
str[1][0]="井", str[1][1]="之", str[1][2]="上", str[1][3]="\0"
str[2][0]="御", str[2][1]="手", str[2][2]="洗", str[2][3]="\0"
str[3][0]="鈴", str[3][1]="木", str[3][2]="\0", str[3][3]="\0"
str[4][0]="\0", str[4][1]="\0", str[4][2]="\0", str[3][3]="\0"

と自動で入って各行の配列の先頭のアドレスが*str[1]や*str[2]に入ってるんでしょうか

704 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 06:59:57 ]
いいえ

705 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:04:34 ]
という事は

> char *str[]={”山田”、”井之上”、”御手洗”、”鈴木”};

これはどういう状態でしょう?

706 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:06:51 ]
文法エラーの状態です

707 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:10:23 ]
本に載ってる型の定義をそのまま写してみたんですがorz

ちょっとそのまま書いてみて試してみます

708 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:12:47 ]
全角/半角、クォーテーション/ダブルクォーテーションに注意

709 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:19:55 ]
char *str[]={"山田","井之上","御手洗","鈴木"};

文法ってそっちでしたかorz
これでよろしいですか?

710 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 07:55:59 ]
ちょっと眠気で頭が鈍くなってきたけど

山田、井之上、御手洗、鈴木はそれぞれメモリのどこかに書き込んで
*str[0]〜[3]にはメモリのそれぞれの文字列の先頭アドレスが入ってるってことかな




711 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 08:18:26 ]
>>710
str[0]〜[3]にはメモリのそれぞれの文字列の先頭アドレスが入ってるってこと
だと思うよ

712 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 08:26:49 ]
あぁそっか*をつけるとアドレス先の中身だっけ
まだ微妙に疑問点あるけどひとまず寝ます
頭が動いてないorz
ありがとう

713 名前:デフォルトの名無しさん [2007/09/11(火) 13:47:31 ]
文字列の質問です。

1から100の自然数を”1”から”100”という文字列に変換せよ

って問題ですけど、どんなプログラムになりますか?

714 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 13:53:24 ]
for文で回してsprintf使うとか。

715 名前:デフォルトの名無しさん [2007/09/11(火) 14:16:56 ]
char** func()
{
int i,j = 0;
char *cp[100]={'\0'};

for(i = 0; i < 100; i++)
cp[i] = ( char *)malloc(sizeof(char)*4);

for(j = 0,i = 1; i <= 100; i++,j++)
sprintf(cp[j],"%d",i);

return cp;
}


716 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 14:46:08 ]
そりゃないだろw

717 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 14:52:54 ]
>>715
変数の寿命を…

718 名前:デフォルトの名無しさん [2007/09/11(火) 15:50:26 ]
>>715
さっきは適当に書いて張りました
以下ソース
char** func(char **cp, size_t n)
{
int i,j = 0;

for(i = 0; i < n; i++)
cp[i] = ( char *)malloc(sizeof(char)*4);

for(j = 0,i = 1; i <= 100; i++,j++)
sprintf(cp[j],"%d ",i);

return cp;
}

719 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 15:57:14 ]
for(i = 0; i < 100; i++)
sprintf(cp[i],"%d ",i+1);

これでいいじゃん

720 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 16:08:13 ]
>>718
nが配列のサイズならループの最大値100にすんな
引数で渡してる奴を戻り値にすんな



721 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 16:28:09 ]
ポインタの100個の配列もmallocすればいいのだ
でも質問者は完全版を求めてるの?

722 名前:718 mailto:sage [2007/09/11(火) 16:29:51 ]
>>720
たしかにそうだね
オナニーしようかしまいか迷ってる最中に
書き込んだクソソースなんで
あんま吟味しないでね

723 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 16:39:01 ]
何かアプリケーションを作ろうと思ったらCとC++どっちがいい?

724 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 17:10:17 ]
伺系アプリの間違いだと信じたい

725 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 17:57:45 ]
>>702
また難儀な・・・
押入れから引っ張り出してきたよ
あ〜なつかしぃい

CASIO PERSONAL COMPUTER FX-890P 16-bit CPU
(液晶の枠部分に書かれている文字)
しかもこれ専用(?)のフロッピーディスクドライブ&そして(確か)増設メモリまで買ってしまったはず
起動したらまだ動く(リチウム電池は空)

(スレチスマソ)

726 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 18:09:21 ]
>>725
姉妹品?のZ-1ならもってた
捨てちゃったけど

727 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 18:17:14 ]
>>726
これかな?
ttp://www5.plala.or.jp/igjhmc/calc/z-1.html
っていうかキー配列とか同じだ
FX-890Pの文字がZ-1になってるぐらい

728 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 19:04:06 ]
bcc32を使っているのですが、c言語のソースプログラムのファイル名に、
list1-1.cのように「-」を使ってもいいのでしょうか?

729 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 19:06:40 ]
いいよ

730 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 19:59:08 ]
>>723
C++のほうがお勧めかな。

理由
C++を勉強すると、Cも勉強できる。
C++を知っているとJavaとかも簡単に理解できる。



731 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 20:39:29 ]
C#

732 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 20:44:32 ]
printfとputsはどっち使えばいいですか?
皆さんどっち使ってます?

733 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 20:48:28 ]
>>732
用途による

734 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 20:50:23 ]
>>732
使っているのは断然 printf だよ
printf を使うことで処理速度に問題が出るようなコードは書いてないから

735 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 20:58:22 ]
賢いコンパイラは適当に最適化してくれるから、printfつかっとけ。

736 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 22:44:59 ]
<double>
43 23
<apple>
100E+02 102E-8 102E-12
<leon>
23E+01 12E-02
<kon>
24 23.3

とかいうファイルからE表記の数値だけを抜き取るにはどうすればいいですかね?


737 名前:736 mailto:sage [2007/09/11(火) 22:45:47 ]
<double>
43 23
<apple>
100E+02 102E-8 102E-12
<leon>
23E+01 12E-02
<kon>
24 23.3
とかかれたファイルからですね。ファイル名はlist.txtとしておきます。

738 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 22:52:38 ]
>>737
// 使用法 a.exe < list.txt
#include<stdio.h>
#include<string.h>

int main(void)
{
char buf[100];
double value;
int pos;

while(scanf("%s", buf)==1)
{
if(strchr(buf, 'E')!=NULL)
if(sscanf(buf, "%le%n", &value, &pos)>=1)
if(buf[pos]=='\0')
printf("%e\n", value);;
}
return 0;
}

739 名前:736 mailto:sage [2007/09/11(火) 23:13:38 ]
やってみます

740 名前:736 mailto:sage [2007/09/11(火) 23:14:44 ]
ありがとうございます



741 名前:デフォルトの名無しさん mailto:sage [2007/09/11(火) 23:16:58 ]
(゚Д゚≡゚Д゚)エッナニナニ?

742 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 02:40:36 ]
入力した文字を逆にして出力したいのですが
#include <stdio.h>
#include <string.h>
int rev (char *);
int main()
{
char str[100];

printf("文字を入力してください\n");
gets_s(str);
rev(str);
printf("逆にしたのはこれです\n");
printf(str);

return 0;
}
int rev (char *str)
{
int i=0;
char str2[100];
size_t len;
len=strlen(str);
while(len>=0){
str2[i]=str[len];
i++;
len--;
}
str=str2;
return 0;
}



743 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 02:41:11 ]
なぜかlenのカウントも増えていくんですけど何処がおかしいですか?

744 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 02:49:36 ]
>char str2[100];
>str=str2;
とりあえずこれはまずい
「C言語 スコープ」とかでぐぐれ

745 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 02:50:27 ]
関数からの見える範囲でしたっけ
ちょっと調べてみます

746 名前:問題 [2007/09/12(水) 03:04:16 ]
問題:ポインタで操作しなさい
char moji[] ="ABCDEF〜XYZ"; /*最大文字26文字*/
char *pc;
pc=moji;

結果
moji:ABCDEF〜XYZ
開始位置==>B
終了位置==>F
表示:BCDEF

moji:ABCEF〜XYZ
開始位置==>D
終了位置==>D
表示:D

moji:ABCDEF〜XYZ
開始位置==>E
終了位置==>B
表示:EF〜XYZAB


747 名前:746の続き [2007/09/12(水) 03:05:46 ]
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void print(char* s, char* e)
{
printf("表示:");
for( ; s <= e ; s++ ) putchar(*s);
puts("");
}
int main(void)
{
char moji[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
char *pc = moji, *pcstart, *pcend, start, end;

while(1) {
printf("moji:%s\n開始位置==>", moji); scanf("%c", &start);
printf("終了位置==>"); scanf("%c", &end);
pcstart = strchr(moji, start);
pcend = strchr(moji, end);
if( pcstart == NULL || pcend == NULL ) break;
if( pcstart <= pcend ) print(pcstart, pcend);
else print(pcend, pcstart);
}
}

この問題でどうしてもエラーが出るんですが何方かわかる方がいましたら教えてください



748 名前:デフォルトの名無しさん [2007/09/12(水) 03:14:23 ]
>>742
void rev(char *str)
{
int len = strlen(str);
int i;
char temp;
for(i = 0; i<len/2; i++)
{
temp = ary[i];
ary[i] = ary[len -i-1];
ary[len -i-1] = temp;
}
}

749 名前:742 mailto:sage [2007/09/12(水) 03:16:21 ]
>>746
ちょ・・・ヒントかなぁって思って頑張って書いてたよorz

750 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 03:21:16 ]
>>747
エラーってどんなエラー?
scanf("%c"〜の挙動を理解してないとかそんなオチ?



751 名前:742 mailto:sage [2007/09/12(水) 03:26:59 ]
>>748
sry[i]って初めて見るんですけどこれはなんでしょう?
参考に組ませて頂きます

752 名前:742 mailto:sage [2007/09/12(水) 03:27:42 ]
×ary[i]
○ary[i]
でしたね

753 名前:746の者です [2007/09/12(水) 03:29:31 ]
警告 W8012 07.cpp 7: 符号付き値と符号なし値の比較(関数 MojiSearch(char *,char *) )
警告 W8012 07.cpp 8: 符号付き値と符号なし値の比較(関数 MojiSearch(char *,char *) )
警告 W8004 07.cpp 5: 'j' に代入した値は使われていない(関数 MojiSearch(char *,char *) )

↑がエラー内容です
6ヶ月ぶりにCに触れたんですが仕組みを忘れちゃってどう直せばいいのかわからなくなってしまったんですよ^^;

754 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 03:31:52 ]
まずそのソースうpしる
>>747にMojiSearchなんて関数ないだろ

755 名前:デフォルトの名無しさん [2007/09/12(水) 03:32:34 ]
>>747
scanf実行後stdinには'\n'が残っていて
後のscanfが'\n'をとりこんでしまってる。
一応getc(stdin)で取り繕って変更したソース
の一部を載っける
int temp;

while(1) {
printf("moji:%s\n開始位置==>", moji);
scanf("%c", &start);
temp =getc(stdin);
printf("終了位置==>");
scanf("%c", &end);
temp =getc(stdin);

756 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 03:40:33 ]
>>753
それはエラーじゃなくて警告って言うんだよ

757 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 04:30:43 ]
>>753
signedとunsigned比較してんだろ
3つ目の警告は見たまんま

758 名前:742 mailto:sage [2007/09/12(水) 05:06:22 ]
>>748
#include <stdio.h>
#include <string.h>
void rev (char *);
int main()
{
char str[100];

printf("文字を入力してください\n");
gets_s(str);
rev(str);
printf("逆にしたのはこれです\n");
printf(str);

return 0;
}
void rev (char *str)
{
int i=0,len=strlen(str);
char str2;

printf("文字の長さは%dです\n",len);
for(i=0;i<len/2;i++){
str2=str[i];
str[i]=str[len-i-1];
str[len-i-1]=str2;
}
}
ary[i]がまだ謎だけど出来たよ、ありがとう

759 名前:746 [2007/09/12(水) 10:35:45 ]
自分で書いた方のソースがvoid rev (char *ary)だったんで
レス欄にコピペしたとき、「ああ、strか」と思い
aryの部分をstrに全部書き換えたつもりだったが
中途半端に書き換えちった
というわけ

760 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 10:48:01 ]
警告を無視する奴は、とりあえず渓谷に行って来い



761 名前:742 mailto:sage [2007/09/12(水) 15:41:36 ]
>>759
なるほど
あえて自分で考える事が出来たし結果オーライだったw
lenの-1も気づかなかったしなorz

スコープについてはまだ良くわかってないけど・・・

762 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 22:46:17 ]
スマソ スコープについて調べろってのは勘違い
str2へのポインタを関数の外で使おうとしてるのかと思った

763 名前:デフォルトの名無しさん [2007/09/12(水) 22:55:14 ]
2点質問があります。
1.関数で配列全体を呼び出しもとに帰すにはどう記述すればよいのでしょうか?
例)a[0],a[1],a[2],a[3]といった、算出した値を配列要素としてではなく、配列全体をreturn文で返す
方法がわからずにおります。
2. 1+X+X^15で生成する疑似ランダムデータの作製法がわからずにおります。
どうかご教示願います。

764 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 22:58:17 ]
>>763
マルチポストですか?
ttp://pc11.2ch.net/test/read.cgi/tech/1188748806/278

765 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 23:03:43 ]
やさしいCを打ち込み終了し他の本も色々調べたのですが、
ポインタとかを理解するにはPICを勉強したほうが分かりやすいですか?

766 名前:デフォルトの名無しさん [2007/09/12(水) 23:05:53 ]
>>764
急いでいるのでマルチポストをしてしまいました。申し訳ございません。


767 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 23:07:33 ]
>>765
問題をやった方が良い

768 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 23:31:22 ]
>>764
大体、関連した話題を扱うスレッドには同じ人が見にきているものだ。
だからマルチポストするとすぐに見つかってしまう。しかも反感を買い回答が得られなくなる。
だから1箇所に投稿し、回答が得られるまで自分でも必死こいて調べるべし。

769 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 23:33:34 ]
>>765
問題をやるのがいいな。

770 名前:デフォルトの名無しさん mailto:sage [2007/09/12(水) 23:56:35 ]
>>767,769
ありがとうございます。問題を解くことからはじめます。



771 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 02:41:58 ]
>>771
宿題スレの問題をやってみるとか。

いろんな人が同じ問題を問いて解答も出してくれるので、
自分とここが違う、とか、これはこうやって実現するのか、とか、
いろいろ気づくところがあるかも知れないよ。


772 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 02:42:28 ]
>>771>>770にだよう。自分に言ってどうする。


773 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 02:49:26 ]
標準ライブラリ関数を使わずに、コンソールに文字列を出力してみようと思い
システムコールのwriteを使ってみたつもりです。

#include <unistd.h>
int main(void) {
char s[] = "test\n";
write(1, s, sizeof(s));
return 0;
}

Cygwin の gcc 3.3.3 で、-ansi -Wall -pedantic -fno-builtin で
コンパイルできて、期待した動作になりました。

で、glibc-2.6.1の io/write.c を見ると

/*
続く


774 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 02:54:40 ]
続き、少しインデントを変えています。
*/

#include <sysdep.h>
#include <errno.h>
#include <unistd.h>
#include <stddef.h>
ssize_t __libc_write (int fd, const void *buf, size_t nbytes)
{
if (nbytes == 0) return 0;
if (fd < 0) {__set_errno (EBADF); return -1;}
if (buf == NULL) {__set_errno (EINVAL); return -1;}
__set_errno (ENOSYS); return -1;
}
libc_hidden_def (__libc_write)
stub_warning (write)

weak_alias (__libc_write, __write)
libc_hidden_weak (__write)
weak_alias (__libc_write, write)
#include <stub-tag.h>


write.c にはこれだけしかないのですが、
fd の値や *buf 内のデータなどは、どこで使われているんでしょうか?

たとえば buf は NULL とだけ比較していますが、
実際に fd に向かって buf を書き込む(?)処理は、どこでやっているんですか?


775 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 11:37:00 ]
>>773
www.sixnine.net/cygwin/translation/faq/faq_3.html#SEC88
>Cygwin は glibc を提供しません。
>代わりに、同じ機能の大部分(全てではありません)を提供する newlib を使用します。
>glibc を Cygwin へ移植するのは難しいでしょう。

776 名前:問題 [2007/09/13(木) 11:59:26 ]
何方か今から掲示する4問の問題が合ってるか教えてください(パソをメンテに出していて手元になくて調べられないんです^^;)
キーボードより表示開始文字と表示終了文字を入力し、開始〜終了までの文字を表示しなさい
char moji[]="ABCDEF〜XYZ"; /*大文字26文字*/
実行画面
moji:ABCDEF〜XYZ
開始位置==>B
終了位置==>F
表示:BCDEF

moji:ABCDEF〜XYZ
開始位置==>D
終了位置==>D
表示:D

moji:ABCDEF〜XYZ
開始位置==>E
終了位置==>B
表示:EF〜XYZAB









777 名前:776の答え [2007/09/13(木) 12:00:14 ]
moji:ABCDEF〜XYZ
開始位置==>B
終了位置==>F
表示:BCDEF



778 名前:776の答え(777ミスです) [2007/09/13(木) 12:01:06 ]
#include <stdio.h>
#include <ctype.h>

int main(void)
{
char moji[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; /*大文字26文字*/
char start, end, *p;

printf("moji:%s\n", moji);
printf("開始位置==>");
scanf("%c", &start);
fflush(stdin);
printf("終了位置==>");
scanf("%c", &end);
fflush(stdin);

if(!isalpha((int)start) || !isalpha(end)) return 1;
start = (char)toupper(start);
end = (char)toupper(end);

p = moji + start - 'A';
for(;;)
{
putchar(*p);
if(*p == end) break;
if(*(++p) == '\0') p = moji;
}
return 0;
}


779 名前:問題2 [2007/09/13(木) 12:04:11 ]
文字列と削除文字列を入力し文字列中から削除文字を排除しなさい
実行画面
文字列入力(m1)==>ABCDEFAABCDABC
削除文字==>A
結果文字列(m2):BCDEFBCDBC

780 名前:問題2の答え [2007/09/13(木) 12:05:38 ]
#include <stdio.h>
#include <string.h>

#define MAX 256

int main(void)
{
char str[MAX],ch;
size_t sz_str,i;
printf("文字配列入力(m1)==>");
fgets(str,sizeof(str)/sizeof(str[0]),stdin);
sz_str=strlen(str);
printf("排除文字==>");
ch=getchar();

for(i=0; i<sz_str; i++) {
if(str[i]!=ch) putchar(str[i]);
}

return 0;
}




781 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 12:25:21 ]
この形式の問題何回目だよwwwww

782 名前:デフォルトの名無しさん [2007/09/13(木) 12:34:12 ]
くだらん質問なんだけど
バッファサイズを256とか512みたいな16の倍数にしてるコードよく見るけど
そうするとどういう効果があるの?

783 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 12:34:49 ]
単にキリがいいから使ってるだけ

784 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 13:12:50 ]
どっちかっつうと2の乗数だが、キリが良いから

785 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 13:17:36 ]
>>784
2の乗数っていうか、2の羃だね。

786 名前:デフォルトの名無しさん [2007/09/13(木) 13:23:03 ]
キリがいいからか
漏れもなんとなくキリがいいから使ってたよw
サソクス

787 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 13:33:44 ]
文系グラマは100とか1000使うのかな

788 名前:デフォルトの名無しさん [2007/09/13(木) 13:46:38 ]
main関数の戻り値ってどういう時使うんですか?

789 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 13:55:42 ]
>>788
コマンドインタプリタで該当プログラムの終了ステータスとして利用する。

790 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 15:03:30 ]
>>788
他のプログラムから起動させたとき



791 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 16:22:48 ]
>>788
#!/bin/sh

if ./a.out; then
 echo "成功" # main が 0 を返した時
else
 echo "失敗..." # main が 1 を返した時
fi

792 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 20:54:10 ]
printf("%6.1f",123.45);
を実行すると
123.5
となるのはなぜですか?
123.4になぜなりませんか?

793 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 20:57:12 ]
一つしたの桁を四捨五入するから。

794 名前:デフォルトの名無しさん mailto:sage [2007/09/13(木) 21:01:27 ]
>>793
thx

795 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 01:02:02 ]
>>775
ありがとうございます。newlibですか。

ではCygwinはおいといて、>>774はglibcの実装についての質問とさせてください。
glibcのwrite.cで定義されている __libc_write の仮引数の使われ方について
なぜこの引数でfdへ書き込みがおこなわれるのでしょうか?

796 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 02:17:33 ]
たぶんそのソースは実際にコンパイルされるコードじゃない。
システムコールをどうやって呼ぶかはOSやCPUによって異なるから、それはただのプレースホルダだろう。

ざっとみてみたところ、sysdeps/unix/syscalls.listからmake-syscalls.shで自動生成されるんじゃないかと思った。
でも複雑すぎて追いきれん。
実際に特定のターゲット向けにビルドしてみて、生成されたファイルを見なきゃ判らなさそう。

797 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 02:41:12 ]
>>795
その関数はターゲット用のwrite()が存在しない場合に使われるダミー関数。
writeしても呼ばれない。

798 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 08:46:05 ]
0: -19.312 -0.144 -0.996 1.412 -0.173 1.933 3.954 4.917 6.333 1.552
-1.515 -1.667 -0.151 0.230 -0.024 0.083 0.377 0.665 0.722 -0.195
-2.321 -1.814 -0.133 0.515 1.343 0.000
1: -19.304 -0.162 -1.799 4.184 1.255 -0.393 -0.335 0.469 1.268 -2.177
-2.390 0.198 -0.151 -0.086 0.111 0.100 0.038 1.462 0.937 -0.569
-0.975 -1.590 -0.486 -0.450 0.133 0.000
2: -18.166 -0.254 -0.178 1.909 2.438 6.705 5.126 -4.463 -0.205 2.752
1.499 4.116 -0.151 0.167 -0.024 -0.312 -0.069 1.179 0.724 -0.214
0.460 -0.921 0.742 0.284 -0.377 0.000

こうかかれたファイルから小数点のところだけ
とりだして二次元配列にいれるにはどうすればいいすかね?
小数点のところ26個あるんですけど。



799 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 09:33:40 ]
コロンの後まで飛ばして読み込め

800 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 11:16:37 ]
指定したパスに、ある拡張子のファイルが存在するか調べるために
_dos_findfirstを使用して、BCCでコンパイルしたら
> Warning W8053 2007-09-14_1.c 11: '_dos_findfirst(const signed char *,unsigned int,find_t *)'
> is obsolete in function main
という警告が出ました。obsoleteとは「旧式の、廃れた」という意味です。
これに代わるものはありますか?



801 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 11:26:11 ]
>>800
dos.hの_dos_findfirst()か、_dos_xxxは古いわなあ。
io.hの_findfirst()でどうか。

802 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 11:32:30 ]
>>801
なるほど、ありがとうございました。

803 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:01:30 ]
ものすごく初歩的な質問で申し訳ありません。
C言語の入門書にそって勉強していたのですがすぐに躓いてしまいました。
hello worldを表示するソースファイルをコンパイルしようとしたのですが下のエラーが出てきてしまいました。

C:\cwork>bcc32 sample.c
Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland
sample.c:
エラー E2209 sample.c 2: インクルードファイル 'stdio.h' をオープンできない
警告 W8065 sample.c 6: プロトタイプ宣言のない関数 'printf' の呼び出し(関数 main
)
*** 1 errors in Compile ***

何かと思い検索してみて確認したのですが原因がわかりません。
なにか分かる方いらっしゃればアドバイスよろしくお願いします。

804 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:18:24 ]
>>803
C:\borland\bcc55\Include\ の中にファイルはあるか?
インストールはどのファイルをどうやって実行した?

805 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:24:35 ]
>>803
www.google.co.jp/search?q=bcc32.cfg

806 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:27:54 ]
>>803
PATHを通してないんでしょうな、多分。

807 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:41:49 ]
PATH通してなかったらbcc32自体出来ないだろ

808 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 14:55:56 ]
オレもそう思った。
cfgもデフォルトだろうし、アップデート用のインストーラ使ったんじゃないかと予想。

809 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:13:25 ]
皆様すばやいレスありがとうございます。

>>804
C:\borland\bcc55\Includeの中にstdio.hはありました。
インストールはその入門書についてあるCDに収録されていた
freecommandlinetools2.exeというファイルを実行しました。

>>807
Pathは通したつもりでいます。
入門書に書かれてあることをそのまま行っただけなので間違いないとは言い切れませんが。

810 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:20:23 ]
C:\borland\bcc55\Bin に、
bcc32.cfg、ilink32.cfg はあるか?
テキストエディタで開いて、以下に設定されているか確認。無ければ以下のをそれぞれ保存

・bcc32.cfg
-I"c:\Borland\Bcc55\include"
-L"c:\Borland\Bcc55\lib;c:\Borland\Bcc55\lib\PSDK"

・ilink32.cfg
-L"c:\Borland\Bcc55\lib;c:\Borland\Bcc55\lib\PSDK"



811 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:22:48 ]
結局、インクルードパスか、、、cfgが確実だな

812 名前:803 mailto:sage [2007/09/14(金) 15:36:19 ]
>>810
bcc32.cfg、ilink32.cfg はC:\borland\bcc55\Binにあります。
bcc32.cfg、ilink32.cfg ともに;c:\Borland\Bcc55\lib\PSDK"の部分はありませんでした。
そこで;c:\Borland\Bcc55\lib\PSDK" を追加してみましたがやはりエラーでした。


813 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:36:28 ]
>>807 >>808
知ったかぶるなら黙ってろ。お前らの頭じゃPATHの意味すらわかってなさそうだから。

814 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:39:02 ]
>>812
面倒くさいんでこれ使っちゃいな
ttp://www.vector.co.jp/soft/dl/win95/prog/se141451.html

815 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:41:25 ]
>>812
どうしても嫌ならこれで
ttp://www.enri.go.jp/~fks442/K_MUSEN/bcc.htm

816 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:43:39 ]
>>807
カレントディレクトリをコンパイラのある場所に移動すりゃ良いんじゃね?
エラーメッセージから推測できるのは、必要なファイルのある場所の
設定がされていないということ。つまり、そういうことだ。
PATHが必要なものに設定されていればどうなるか、分かるよね?

817 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:43:57 ]
>>813
おまえ、名指しで何か言うなら知ったかしないほうがいいぞ
PATHの意味を言ってみ?

818 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:44:54 ]
>>816
>C:\cwork>bcc32 sample.c
>Borland C++ 5.5.1 for Win32 Copyright (c) 1993, 2000 Borland

この2つからPATHが通っているのは明白

819 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:46:34 ]
>>817
味方にボールを送る事に決まってんだろうが

820 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:53:56 ]
それはPASS



821 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 15:56:07 ]
>>819
アホか
ヤマハの電動アシスト自転車の事だろ

822 名前:803 mailto:sage [2007/09/14(金) 15:57:16 ]
>>814-815
ありがとうございます。
試してみようと思います。

>>816
ソースファイルを作成したc:\cworkというディレクトリに移動しているのですが、こういうことでしょうか? 

823 名前:803 mailto:sage [2007/09/14(金) 16:10:52 ]
>>814様のソフトをダウンロードして自動設定したら解決できました。
皆様お忙しいところくだらない質問に時間を割いていただき本当にありがとうございました。


824 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 16:13:02 ]
結局、原因はなんだったんだろうな

825 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 16:19:23 ]
どういたしまして
がんばって

826 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 16:21:01 ]
cfgのタイプミスだろうなあ・・・

827 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 16:36:51 ]
>>821の言っている事がわからない

828 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 16:41:00 ]
知らないならレスしなくていいよ
つーか知っててもスルーしてるが

829 名前:デフォルトの名無しさん [2007/09/14(金) 18:49:34 ]
FFFFFF80を2進数に直すと、どうして
11111111 11111111 11111111 1000000になるのかわかりません
特に、80は 0101000では?

830 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 18:51:39 ]
>>829
(0101)2 → (5)10



831 名前:デフォルトの名無しさん [2007/09/14(金) 18:56:10 ]
レス、ありがとうございます
???
間違っているのですか?

832 名前:デフォルトの名無しさん [2007/09/14(金) 18:56:41 ]
16進の80
2進だと1000000
10進の80と誤解してると思われ

833 名前:デフォルトの名無しさん [2007/09/14(金) 18:59:02 ]
0一個たんなかった

834 名前:デフォルトの名無しさん [2007/09/14(金) 19:02:19 ]
>>832
ん〜どうしてもわかりません

では、2進数の80では、0101000で合っていて
16進数の80では、どうして1000000になるのでしょうか?

835 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:10:41 ]
2進数の80なんかあるか。2進数は1と0だけ。

836 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:12:30 ]
(x)y を y進法で表すxとする

(80)10 = (0101000)2
(80)16 = (128)10 = (10000000)2

837 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:13:01 ]
16進数の80 = 10進数の128 = 2進数の10000000

16進数の50 = 10進数の80 = 2進数の10100000

838 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:16:47 ]
>>836 >>837
計算違くね
(80)10 = (0101 0000)2

839 名前:837 mailto:sage [2007/09/14(金) 19:18:05 ]
うぁ。みすorz

840 名前:829 [2007/09/14(金) 19:23:39 ]
皆さん、レスありがとうございます。

>>16進数の80 = 10進数の128 = 2進数の10000000

   16進数の50 = 10進数の80 = 2進数の10100000

では、一旦10進数に置き換えてから、2進ぬするのでしょうか?
どうやれば、16進数の80は10進数の128に、又は16進数の50は10進数の80に
直せるのでしょうか?



841 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:31:21 ]
>>840
ググれば解説しているサイトはたくさんある

842 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:32:12 ]
>>840
16進から2進の場合、は分割するんよ

FFFFFF80
F=1111 , 8 = 1000 , 0=0
あとはくっつける

1111 1111 1111 1111 1111 1111 1000 0000

FFFFFF80(16)=11111111111111111111111110000000(2)
って感じ

843 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:34:44 ]
>>840
失礼、ちょっと訂正

FFFFFF80
F(16)=1111(2) , 8(16)=1000(2) , 0(16)=0000(2)  ね

10進に直すより16進→2進 、2進→16進の方が楽(のはず)

844 名前:デフォルトの名無しさん [2007/09/14(金) 19:42:23 ]
さすがにゆとり教育杉な気もしてきた

845 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 19:44:21 ]
C言語がいいらしいんですが無料でできますか?

846 名前:デフォルトの名無しさん [2007/09/14(金) 19:46:33 ]
はい

847 名前:デフォルトの名無しさん [2007/09/14(金) 20:11:41 ]
ありがとうございましm(__)m
これで先に進めます

848 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 20:49:08 ]
>>840の解説に同意。

16って2^4(二の四乗)の事ですよね。
つまり、2進数表現4ビットの最大値(1111)
が、16進数Fに相当している事もわかりますよね。

したがって、>>840の解説を御借りすると、

FFFFFF80
F=1111 , 8 = 1000 , 0=0

【|】(パイプ)で区切ると

1111 | 1111 | 1111 | 1111 | 1111 | 1111 | 1000 | 0000 (2)
F F F F F F 8 0 (10)

となります。

849 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 20:50:17 ]
>>840じゃなくて、>>842でした。

850 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 22:59:14 ]
C言語なんですが、ファイルに書き込むときって自分でEOF書き込むんですか??
それとも、閉じるときに勝手にやってくれるんでしょうか。



851 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 23:03:47 ]
>>850
閉じるときに勝手にやってくれる。
つか、EOFというデータはないんだけど。
ファイルの最後まで読んだときfreadなどのファイル入出力関数がEOFを返すだけ。

852 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 23:24:22 ]
あ、そうなんですか!
てっきり、改行コードみたいにEOFっていう記号があるのかと思いました。。。

853 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 23:37:45 ]
URL

854 名前:デフォルトの名無しさん mailto:sage [2007/09/14(金) 23:59:28 ]
>>796 >>797
超ありがとうございます。
勉強します。


855 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 00:25:48 ]
>>852
EOF=1A じゃなかったかな。昔のテキストファイルには使っていたと聞くよ。

856 名前:852 mailto:sage [2007/09/15(土) 00:40:18 ]
>>855
MS-DOSのテキストファイルにはEOF(1Ah)が書かれていたようですね。

EOF(1Ah)がファイル内に実際にデータとして書かれているものと書かれていないもの
さらに、書かれているもののうちアプリケーションがこのEOF(1Ah)をデータとして
意識すべきものと意識しなくてよいもの

があるようですね。

ファイルのデータをレングスで管理しているファイルシステムはEOFがなくて、
このレングスがないファイルシステムにはEOFがデータとしてある。

ということでしょうか。

857 名前:852 mailto:sage [2007/09/15(土) 00:45:30 ]
ということで>>850さん

EOFをアプリケーションで書き出す必要があるかないかは、
「ファイルの仕様による」ということです。

Windowsのハードディスクのファイルは書き出す必要はありません。

858 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 00:51:53 ]
>>852、855
ありがとうございます〜 むっちゃわかりやすかったっす。


859 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 01:47:18 ]
CのライブラリのEOFとアプリが使う終了のマークを一緒にしたらだめでしょ。

860 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:08:55 ]
>>817
お前とかうぜーよ、偉そうに。英語すら理解していないだろ。
ttp://dictionary.goo.ne.jp/search.php?MT=path&kind=ej&mode=0&base=1&row=0
必要なデータやプログラムのある場所へPATHを通しておくことで
どこのディレクトリからでも扱えるようにできるようになることくらい知っているだろ。
っつかお前、DOSとかその他そういった仕組みを持ったシステムを使ったことないだろ?



861 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:12:21 ]
>>857
>Windowsのハードディスクのファイルは書き出す必要はありません。
判っていないのならレスしなくてもよろしいのでは?

862 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:13:29 ]
どうやらPATHの意味をそれぞれ勝手に解釈している同士が罵り合っている模様。
仲のいいことで。

863 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:17:01 ]
>>861
そういうレスはいけないと思うよ。

間違っているを指摘すべきだと思う。

864 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:41:12 ]
猫でもわかるC言語プログラミングP.196によると下記のようなプログラムはだめ
ということですがBCCではコンパイルが通り、実行しても問題は見られませんでした
char *strではなくchar str[32]なら可とのこと
なぜでしょうか?
もうひとつ
下記のプログラムでprintf("%sの長さは%dです\n",*str,len);
のように%sに対して*strとすると実行時にエラーになりますが
*strなら中身のASCIIコードが入っているはずで問題ないと思うのですが…
ご教示願います。

#include <stdio.h>
#include <string.h>

int main()
{
char *str;
size_t len;

printf("文字列を入力してください。--");
scanf("%s", str);

len = strlen(str);

printf("%sの長さは%dです\n",str,len);

return 0;
}

865 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:41:52 ]
>>864
%s→%c

866 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:43:37 ]
char str[32]でも不可です

867 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 02:48:22 ]
>>864
> 猫でもわかるC言語プログラミングP.196によると下記のようなプログラムはだめ
> ということですがBCCではコンパイルが通り、実行しても問題は見られませんでした
> char *strではなくchar str[32]なら可とのこと
問題が無かったのは str の指す先が*偶然*致命的な場所で無かっただけで
予期しない場所が書き換えられています
str が指す先がちゃんと確保されている場合には問題は無いです

868 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 03:05:22 ]
>>864
その本には、なぜダメかってのは書いてないのか。

869 名前:デフォルトの名無しさん [2007/09/15(土) 04:39:20 ]
scanfとprintfの関数の違いと働きを教えてください。お願いします。

870 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 04:41:45 ]
ja.wikipedia.org/wiki/Scanf
ja.wikipedia.org/wiki/Printf



871 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 04:48:43 ]
>>869
scanf - scan with format
printf - print with format

872 名前:デフォルトの名無しさん mailto:sage [2007/09/15(土) 14:13:04 ]
さすが猫ですね

873 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:32:08 ]
データが1個増えるたびにreallocしてることが発覚しましたw
バカすぎますか?

874 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:34:36 ]
はい

875 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:34:40 ]
データが増える間隔とデータ量による

876 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:38:15 ]
>>873
実装が楽なので使い捨てコードのときにはそうします

877 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:42:30 ]
>>873
一個ごとでも、まったくOK。
データの複数個ずつぶんのメモリを確保しても、ほとんどの場合は、
スピードアップしません。

878 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 00:48:01 ]
vectorとかでも中では一回ごとにrealloc的なことしてるんだっけ?

879 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 01:24:37 ]
>>878
ここは C のスレですぜ
> vector
ってなに?


880 名前:デフォルトの名無しさん [2007/09/16(日) 01:34:48 ]
ここは東京だぜ



881 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 02:19:19 ]
読み込んだ数式を逆ポーランド記法に変換しようとしてるんですが、
1+(3+(4-2)+1)*4
のようにすると、1342-+1+4*-という式になってしまいます。

else if(source[i] == ')'){
while( now > 0 && stack[now -1] != '('){
rpn[r++] = stack[--now];
}
--now;
}

原因がわかりません。教えてください。
できれば解決策もm(_ _)m

882 名前:864 mailto:sage [2007/09/16(日) 02:45:34 ]
レスありがとうございます

>>865
確かに%cとすると一文字だけですが表示されます
JavaをかじってたこともあってString型がCにもあると思い込み,いわゆる文字列がポインタであることを理解していませんでした
pritf("%d",i);のようにカンマの後には変数名を書けばよいと思っていましたが
%sの場合は例外でポインタを書かないといけないのですね
確かにそうすると表記上はすべて変数名のように見えて綺麗ですから、そのためにそのような設計になったのでしょうか…


>>866
31文字以上は入力しないという前提でも不可なのでしょうか?

>>867
char *str ではポインタ(アドレス変数)が確保されただけでその中身については未定義で
さらに、その中身のアドレスの後ろが他のことに使われていないという保証もないから不可で
char str[32]なら31文字分については安全な場所が確保されるからOKという理解で正しいでしょうか

>>869
本文をそのまま引用すると
『strはchar型へのポインタですね。ということはアドレスを格納する変数なのです。これではだめですね。』
とのことです。
しかし、scanfやstrlenについては、渡すべきものはアドレスであり間違えているようには考えられず
printfについても%sにはポインタを渡すのであっているようなので理由が私にはわかりませんでした。

883 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 03:18:00 ]
適当な本だな

884 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 03:34:24 ]
渡すべきものはアドレスだが、その渡しているアドレスの値が適切なのかどうかということだ。
scanfは、渡されたアドレスが示すメモリ領域を書き換えるのだから、適当なアドレスを渡してはいけない。
特に、初期化してないポインタ (どのアドレスを指してるか不定) を渡すなんて、もってのほか。
書き換えられても安全な領域 (char[32]とか) を用意して、そのアドレスを渡す必要がある。

885 名前:881 mailto:sage [2007/09/16(日) 04:01:59 ]
すみません自己解決しましたm(_ _)m

886 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 04:12:05 ]
1+(3+(4-2)+1)*4 は逆ポーランド記法で
4 2 - 3 + 1 + 4 * 1 + で合ってますか?

887 名前:デフォルトの名無しさん [2007/09/16(日) 04:22:14 ]
車輪の再開発は止めましょう

その程度の計算なら電卓でできます。
暗算でもできるでしょ?

作る意味無いよ

888 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 04:28:51 ]
            ∩_
           〈〈〈 ヽ
          〈⊃  }
   ∩___∩  |   |
   | ノ      ヽ !   !
  /  ●   ● |  /
  |    ( _●_)  ミ/ <こいつ最高にアホ
 彡、   |∪|  /
/ __  ヽノ /
(___)   /

889 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 04:58:38 ]
   ∩___∩
   | ノ      ヽ !
  /  ●   ● |   こいつも最高にアホ
  |    ( _●_)  ミ
 彡、   |∪|   / .\
/ __  ヽノ / \ ...\
(___)   /   .│ ..│
            /  ヽ
            l..lUUU
            .U

890 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 05:19:03 ]
そんな餌に俺様が釣られクマーー



891 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 06:42:36 ]
>>886
1342-+1+4*+ かな。

892 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 08:17:49 ]
>>886
適当に作ってみた。
やっぱり 1342-+1+4*+ になる。
sund1.sakura.ne.jp/uploader/source/up11687.c

893 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 09:03:32 ]
>>886
1+(2+3) と 2+3+1 が同じだというならそれでも合ってる

894 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 12:10:01 ]
>>873-879
おれの居る現場の既存のコードでは、
最終的に300〜400MBのメモリを確保するのに、reallocを繰り返して、
延べ 2.5GBぶんコピーを繰り返している事が分かったよ。

DBのテーブルのデータを一度メモリーに全部取り出すんだ...orz


895 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 12:12:34 ]
>>894
それだとDBの意味ががが
元からなさそうな感じではあるけど

896 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 12:32:44 ]
realloc()を使うと、毎回確保し直すと思っている馬鹿が多いのか?
自分でわざわざ回数まとめてからrealloc()するようなコード書くより、
毎回realloc()する方が速いかもしれないぞw

897 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 12:39:00 ]
そんな当たり前の事言われても。

898 名前:894 mailto:sage [2007/09/16(日) 13:03:07 ]
>>895
まあ100%無意味って訳じゃないんだけどね。一応SQLの恩恵は受けているから。
でもバッチ系が全部、「始めてプログラムを組んだんじゃないか?」ってレベルなんだ。
>>894のコードも基本的に集計するだけだから、DBの設計さえ良ければ単純なSQLで済むはずなのになー。

ハッ、ここは愚痴スレじゃなかったなスマソ。

899 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 13:10:10 ]
気づいたんなら送信するな

900 名前:894 mailto:sage [2007/09/16(日) 13:16:21 ]
>>896
その話は聞いたことあるが、そういうレベルじゃない。
reallocその物を使わないで済ませられるような場面でやってるだよ。





901 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 15:00:29 ]
realloc()って新たに確保した場所にそれ以前のものをコピーするんじゃなかったっけ?
毎回やっているかは知らんが

902 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 15:06:55 ]
>>901
元の領域に連続した領域を確保できれば、単純な拡張でよいので、
コピーは省略出来る。

903 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 15:09:04 ]
>>901
#include <stdio.h>
#include <stdlib.h>

int main(int argc, char *argv[]){
void *ptr=NULL, *new_ptr;
int i, count=0;

for(i=1;i<=1000;i++){
new_ptr=realloc(ptr, i*100);
if(ptr!=new_ptr){
fprintf(stderr, "pointer changed. [%d]\n", i);
ptr=new_ptr;
count++;
}
}
printf("change count : %d\n", count);
free(ptr);
return 0;
}

904 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 18:10:12 ]
巨大な配列を宣言時に同じ値で初期化したいんですけどこういう場合に簡略化する書き方とかないですかね
void func()
{
static int array[3000] = { 0, .. ,0};
}

的な…


905 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 18:20:31 ]
{0}
っていうかstaticって自動的に0で初期化されなかったっけ?

906 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 18:33:31 ]
サンクス。うまくいきますた。

907 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 18:43:25 ]
グローバル変数、静的変数は宣言時に全ての要素が 0 で初期化される。
ローカルな配列は、宣言時に1つ(1要素)でも初期化を行うと残りが全て 0 で初期化される。

int a[3000]; // a[0]〜a[2999] まで全て 0
int b[3000] = {1, 2, 3}; // b[0]=1, b[1]=2, b[2]=3, b[3]〜b[2999]=0
int c[3000] = {1}; // c[0]=1, c[1]〜c[2999]=0
main(){
int d[3000]; // d[0]〜d[2999] まで全て不定値(適当な値)
static int e[3000]; // a と同じ
int f[3000] = {1, 2}; // bとかcと同じ
}

よく、ローカルな配列を 0 で初期化するために array[256] = {0}; とか書くが、
1要素でも初期化すると残りが 0 で初期化されることを利用しているだけ。
array[256] = {1}; と書いて全ての要素が 1 で初期化されると誤解するやつが多い。

任意の値で初期化させたければ、n次元の配列はn重のループを普通に書く。
C++ならalgorithmのfillなんかを使えばいい。


908 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 20:37:21 ]
>>904
staticなら自動的に0で初期化される。
関数内staticにするなら、他の値は難しいな。
呼び出しの都度初期化でいいならmemsetとかでも良いだろうけど。



909 名前:デフォルトの名無しさん mailto:sage [2007/09/16(日) 20:39:25 ]
複数ファイルにソースを書くときのお作法を知りたいんだけど、わかりやすいところないかな

910 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 01:00:33 ]
>>909
ヘッダファイルから書き始める



911 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 02:30:43 ]
新しくコード書くとき
既存のファイルに加えるか
新しくファイル作成するか迷うんだけど
どういう基準でやったらいいですか?

912 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 10:25:01 ]
設計上モジュールが分かれてたらファイルを分ける。
CUnit使うなら1ファイルに1関数。

913 名前: ◆7qRx8xrwgo [2007/09/17(月) 11:51:39 ]
質問させていただきます。


円記号を表示します。 :\
アポストロフィを表示します。:\

と、出力したくて
#include <stdio.h>

int main(void)
{
    printf("円記号を表示します。 :%c\n", '\\');
    printf("アポストロフィを表示します。:%c\n", '\'');

    return 0;
}

でコンパイルしてみたのですが、
Sample5.c:5:12: warning: unknown escape sequence: '\216'
Sample5.c:6:12: warning: unknown escape sequence: '\216'
とエラーが出たのですが、どうすればエラーが表示されなくなりますか?

914 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 11:53:04 ]
>>913
表示

出力

915 名前:デフォルトの名無しさん [2007/09/17(月) 11:55:23 ]
「表」の後ろに¥を入れれば直るかも。

916 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 11:59:13 ]
OSとコンパイラは何?

917 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:03:44 ]
>>913
文字コード Shift-Jis の時
[表示] = 0x95 0x5C 0x8E 0xA6
0x5C = '\\'
0x8E = 0216 <- 8進数

\216 を解釈しようとして、そんなエスケープシーケンスがないという
*警告*がでているだけ

日本語対応しているコンパイラを使うほうが楽

918 名前:913 ◆7qRx8xrwgo [2007/09/17(月) 12:16:57 ]
>>914
本に表示と書いてありました

>>915
失礼ながら半信半疑で試したところ、仰るとおり直りました。

>>916
OS:Wndows XP HE SP2
コンパイラ: gcc(Cygwin)

>>917
解説ありがとうございます。今はコンパイラを変えたくないのでこのままでいこうと思います。
もしよろしければ、「表示」のように、気をつけた方がいい単語が他にもありましたら教えてください。

919 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:22:35 ]
>>918
―ソЫ\噂浬欺圭構蚕十申曾箪貼能表暴予禄兔喀媾彌拿杤歃

920 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:26:19 ]
gcc に --input-charset=cp932 --exec-charset=cp932 オプションをつけてみ



921 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:32:32 ]
>>920 thx
MinGW (GCC.EXE (GCC) 3.4.2 (mingw-special)) でもいけたよ
さっそく CFLAGS に追加しておいた

922 名前:918 ◆7qRx8xrwgo [2007/09/17(月) 12:36:56 ]
>>920
仰るとおりに実行した所エラーが表示されることも無くコンパイルできました。感謝です。

923 名前:デフォルトの名無しさん [2007/09/17(月) 12:41:51 ]
皆さん、実際にC言語でどのようなソフトを書かれているんですか?



924 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:51:00 ]
OS書いていますけど?

925 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 12:53:14 ]
通信プロトコル。
OSIでデータリンクからセッションぐらいまで

926 名前:デフォルトの名無しさん [2007/09/17(月) 12:55:28 ]
どこにもしようしているおえすめいかいてない
あおえすをしいでかいてるのか
すごいなおまえ

927 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 13:01:33 ]
C言語は学校の授業や課題でしか使わんな
普段使うのはVC++かJavaかC#

928 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 14:43:27 ]
>>923
去年、一年くらい、10年くらい前に作られたシステムの保守要員やらされて、辟易した。

929 名前:デフォルトの名無しさん [2007/09/17(月) 16:20:36 ]
保守ってどんなことやるの?

930 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 16:40:25 ]
>>929
お客さんとこのシステムの構成が変わったりなんか要望があったら、それにあわせてコードを書き換えたりとか。
新規のお客さんもあったけど、すでにあるコードから必要なコードをコピペして、ちょっといじって
もって行ったりとかするだけ。



931 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 16:45:13 ]
ものすごくつまんなそうな仕事ですね

932 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 16:57:41 ]
つまらないうえに、すごいつらかった。
基本的にソースコードぐちゃぐちゃだし。


933 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 17:06:15 ]
今の現場、つまらないうえに、すごいつらい。
基本的にソースぐちゃぐちゃだし。

934 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 18:32:30 ]
既存のファイルのファイルスコープにある変数や関数を使いたい、
っていうんじゃないんだろうから、迷ったら別ファイルでいいんじゃないでしょうか?

ファイルを分ける弊害って、なにかあるでしょうか?


935 名前:934 mailto:sage [2007/09/17(月) 18:35:31 ]
リロードわすれてたっはっは〜

936 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 21:35:29 ]
>>933
でも、大事な仕事だよ。
今後はC言語でも保守の仕事が増えるんじゃないか!?
COBOLはすでにそうなっている。

しっかりとしたコーディング規約があって、その通りに作られていればいいんだが、
Cでの開発プロジェクトにはコーディング規約がないくて、各自各様のスタイルでコーディング
していることが多い。最近はそうでもないかもしれないけどね。

937 名前:933 mailto:sage [2007/09/17(月) 22:09:47 ]
>>934>>911に対するレス?

>>936
スタイル云々以前の問題でね、多分プログラミング自体の経験が無い人か、
少なくとも、スコープを分かってない人が書いたプログラムで、それが原因のバグとかもある。
おそらくテストもマトモにしてないと思われるよ。orz

>>911
で、「分ける分けない」て話は、スコープとも関わる話なのでスコープを理解すること。
関連性が強い物、似たような機能のものを集めるという分け方もある。
「モジュール強度 結合度 独立性」という言葉を調べると何かわかるかも。


938 名前:デフォルトの名無しさん mailto:sage [2007/09/17(月) 22:18:54 ]
>>937
「モジュール強度 結合度 独立性」
なつかしい言葉だね

939 名前:デフォルトの名無しさん [2007/09/18(火) 01:53:17 ]
何方か、標準関数とポインタ変数についてを詳しく教えてくださる方はいらっしゃいますか?
自分が持ったいた参考書がこの2つの内容が掲載されてた部分が破けていて分からなくて困っています^^;



940 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:00:19 ]
>>939
ポインタ
www.geocities.jp/ky_webid/c/028.html
標準関数
always-pg.com/c/runtime_rd/



941 名前:デフォルトの名無しさん [2007/09/18(火) 02:05:59 ]
940>有難う御座います

942 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:07:38 ]
>>940
>「&」をアドレス演算子といいます。「&」がアドレスを表すので「"アンド"レス」と覚えておくと分かりやすいかも知れません。
なごんだ(´ー`)

943 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:10:59 ]
今更Cなんて初めて使う機会ないよ
OSやドライバを作るなら必要だが、そのレベルに達するまで恐らく5年以上は掛かるだろう




944 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:13:02 ]
がんばれば30日でできるらしいぞ

945 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:14:40 ]
あれかw

946 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:23:30 ]
C言語の言うことなら何でも聞きます

947 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 02:58:03 ]
ttp://always-pg.com/c/runtime_rd/string/wcslen.html
こちらの「文字列の文字数を求める」サンプルプログラムですが、
"Cプログラム" の長さは 6 が返るはずなんですが 11 が返ります。
なぜでしょうか? 環境は、linuxで gcc 3.3.6 です。


948 名前:デフォルトの名無しさん [2007/09/18(火) 03:01:06 ]
全角は2文字

949 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 03:26:23 ]
ちょっと語弊を招きかねない回答だなw
全角文字は2バイトなのでC標準のstrlenのようにバイト数を返す関数を使用した場合、文字数が得られるとは限らない。
ちゃんとロケールを設定すれば6になるはずだが?一字一句間違えずにコピペした?

950 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 03:31:49 ]
>>949
ダウンロードして展開した wcslen.c というファイルを euc-jp-unix にしてから
そのままコンパイルして実行してます。



951 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 03:58:59 ]
>>947-950
試してみたが、VC++では 6 が返ってきた。
cygwin gcc 3.4.4 ではコンパイルできなかった。
L"Cプログラム"; の L でパースエラー。

952 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 04:14:27 ]
え?ってかCなの?C++じゃなくて?
C標準に2バイト文字なんて概念あったっけ?

953 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 04:22:59 ]
wchat_t

954 名前:デフォルトの名無しさん [2007/09/18(火) 07:52:09 ]
質問させてくださりませ。
void parse_long_options (int _argc,
char **_argv,
const char *_command_name,
...);
の中の"..."の点三つはどういう意味なのでしょうか?
ご教授宜しくお願い致します。


955 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 08:01:23 ]
>>954
教授じゃなくて教示な

www.geocities.jp/ky_webid/c/057.html

956 名前:デフォルトの名無しさん mailto:sage [2007/09/18(火) 08:30:14 ]
引数の数が可変であるってこと。






[ 新着レスの取得/表示 (agate) ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<232KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef