08/11/01 00:13:27
高速な文字列置き換えはどのようにしたら出来ますか?
3:デフォルトの名無しさん
08/11/01 00:17:57
>>2
高速なCPUとメモリを用意してRTOSを使いDMA転送や1クロックでも速くアセンブラでコールするなどハードウェアの限界までチューンすると出来る
4:デフォルトの名無しさん
08/11/01 00:24:59
最近プログラミングを始めたんですが
コマンドプロンプトの画面ばかりで、最近食傷気味です。
別のウィンドウを表示したり、そこで文字やグラフィックを表示させるような命令文の例などはありますか?
あるいは、SDLやDXライブラリなどを使用して
それ用にプログラムを組むしかないんでしょうか?
5:デフォルトの名無しさん
08/11/01 00:28:01
ちょっとお聞きしたいのですが、先ほどコマンドプロントでの主要なコマンドなどを見ていたのですが
ディレクトリ削除をあつかうrdコマンドで
rd /s \ とやったらcドライブのすべてのファイルとフォルダが削除されるってことでいいんでしょうか?
6:デフォルトの名無しさん
08/11/01 00:28:02
>>4
ライブラリ使うか、直でAPI呼ぶしかない。
7:デフォルトの名無しさん
08/11/01 00:29:36
>>5
管理者アカウントでやってたらほとんどきえるんじゃねーのかな。
起動中のexeとか、消えないのもあるだろうけど。
8:デフォルトの名無しさん
08/11/01 00:30:05
ビットフィールドでこんな定義はだめなんでしょうか?
struct bitTST {
bool bit[8];
};
bitTST->bit[0]を参照するとboolではなくcharとして値が返ってきます。
↓これだとboolとして参照できますがループで処理したいと思っています。
struct bitTST {
bool bit0 : 1;
bool bit1 : 1;
bool bit2 : 1;
bool bit3 : 1;
bool bit4 : 1;
bool bit5 : 1;
bool bit6 : 1;
bool bit7 : 1;
};
9:デフォルトの名無しさん
08/11/01 00:30:10
>>5
いいえ
消えないかもしれません
10:デフォルトの名無しさん
08/11/01 00:31:24
>>6
なるほど、自分で打ち込むだけではやはり厳しいのですね
諦めてDXライブラリ使うことにします。
ご返答有難うございました
11:デフォルトの名無しさん
08/11/01 00:31:47
たかだか8bitくらいループで書かなくてもいいじゃん
12:デフォルトの名無しさん
08/11/01 00:32:38
摂氏から華氏を求めるプログラムを作っているのですが
小数点以下を入力しても整数部分しか認識してくれません
#include <stdio.h>
float convC2F(double C)
{
double F;
F = (double)C*(double)1.8+(double)32.0;
return F;
}
int main()
{
int C;
float F;
printf("摂氏は何度ですか?\n");
scanf("%d", &C);
F = convC2F(C);
printf("華氏は%6.3fです\n", F);
return 0;
どなたか助けれくれないでしょうか
13:デフォルトの名無しさん
08/11/01 00:35:03
>>8
先ず第一に、boolはビット変数ではありません。
第二に、ビットフィールドは配列にはなりません。
第三に、ビット単位で処理をしたいのなら素直にビット演算した方が無難です。
14:デフォルトの名無しさん
08/11/01 00:36:29
>>12
宿題は宿題スレへ
15:デフォルトの名無しさん
08/11/01 00:36:55
>>12
scanf()で%dを指定した場合、小数値を代入することはできません。
大人しく、%lfを指定してdoubleへのポインタを渡してください。
尚、特に必要がない限りfloat型は使わない方が無難です。
また、(double)1.8のような記述には殆ど意味がありません。素直に1.8と書きましょう。
16:デフォルトの名無しさん
08/11/01 00:38:38
>>7
なるほど、やっぱりですか、危うく試しに実行してみるところでした。
上のコマンドで検索したところ
URLリンク(oshiete1.goo.ne.jp) において
cmd /c rd /s /q c: という文が書いてあり
CMD /C ○○ ・・・ ○○のコマンドを実行する
と説明されているのですが、 cmdを書く理由がよくわからないのですがどういうことなのでしょうか?
helpを使うと新しいインスタンスを開始します。とは書いてあるのですが・・・
17:デフォルトの名無しさん
08/11/01 00:40:11
>>14
すいません。
以後気を付けます。
>>15
アドイスありがとうございました。
18:デフォルトの名無しさん
08/11/01 00:40:29
>>16
スレ違い……いや、鼬害だ。
19:8
08/11/01 00:44:13
ありがとうございました。
20:デフォルトの名無しさん
08/11/01 02:21:49
最近のCPUにとってはメモリの読み書きさえ大きなコストになります
…本当?
21:デフォルトの名無しさん
08/11/01 02:28:39
>>20
それなりに
これでも読んで見る?
URLリンク(www.atmarkit.co.jp)
22:デフォルトの名無しさん
08/11/01 02:54:06
ヘ⌒ヽフ
( ・ω・) ㌧㌧
/ ~つと)
参考にしてみるね
23:デフォルトの名無しさん
08/11/01 03:52:14
sprintf(info,"%*.s",sizeof(str),str);
サイズ指定でこんな使い方できるんだな
24:デフォルトの名無しさん
08/11/01 04:25:20
bitってどんなときに使うの?
25:デフォルトの名無しさん
08/11/01 04:40:53
>>20
CPUの速度は飛躍的に向上したけど、メモリーアクセスの速度はそれほど向上していない。
遅い時代のCPUならメモリーアクセスの遅さは目立たないけれど
CPUは速くなっちゃったせいで、遅さは目立ってきている。
ということだろ。
26:デフォルトの名無しさん
08/11/01 04:42:15
>>24
ノード6000くらいの線形リストでアクセス速度ぅpに使う
27:デフォルトの名無しさん
08/11/01 04:43:11
すまん、>>26はビット演算
28:デフォルトの名無しさん
08/11/01 04:55:39
>>24
制御系でビットをフラグとして使う場合があるますよね
0ビット目が1ならどうとか、1ビット目が1ならああだとか
そういう場合の該当ビットの読み書きに使います。
29:28
08/11/01 04:57:18
ビット演算でも代行できるので、あまり使わない機能かな?
30:デフォルトの名無しさん
08/11/01 05:26:26
memsetで構造体をゼロクリアしたいのだけど整数型以外の結果は保障されないらしいのですが、何故ですか?
31:デフォルトの名無しさん
08/11/01 05:34:28
C言語の次に言語が出るとしたならば、言語名はP言語ですか?
32:デフォルトの名無しさん
08/11/01 05:38:06
>>30
何を持って結果の保証とするのかがわからないが
たとえば構造体にfloatのメンバーがあったとする、
0でmemsetすると中身は0x00000000となるわけだが、0x00000000=0.0はすべての環境で
保障されているわけではない。
ポインタも同じ。NULLが0でない処理系では0でmemsetした場合、そのポインタ変数
はNULLにはならない。
じゃまいか
33:デフォルトの名無しさん
08/11/01 06:23:32
NULL==0
という決まりがなかったっけ。memsetで強引に入れたときは別かもしれんが。
34:デフォルトの名無しさん
08/11/01 07:55:08
>>31
最低の屑
35:デフォルトの名無しさん
08/11/01 08:00:11
NULLが0なんじゃない。0がNULLなんだ。
つまり、比較はできるが、ポインタの中身がどうなっているかは想定外。
極端な話、仮想メモリがなくてアドレス空間として0番地を使わざるを得ない環境だとしたら、
中身0をNULLとは使い難い。
36:デフォルトの名無しさん
08/11/01 08:07:05
NULLはあくまでポインタの先が存在しないこと示してるわけであって必ずしも0ではない
だがNULLは0番地のアドレスをさすことが多い(仕様?)からキャストされてNULL==0は真になる
と、初心者のおれは解釈してるんだが、ホントのところはどうなんですか?
37:デフォルトの名無しさん
08/11/01 08:11:15
>>36
いやだから、NULLがどこを指していようとも、0と比較する限り真にならないといけない。
38:デフォルトの名無しさん
08/11/01 11:16:37
>>36
何度も出ているように、NULLのビットパタンがオール0であることは保証されてない
だからキャストされて0になることも保証されない。
あなたが実験したら0になるかもしれないけど、それはそれだけのこと
39:デフォルトの名無しさん
08/11/01 12:08:44
ヌルポインタだと判別するにはどうしたらいいんだ
40:デフォルトの名無しさん
08/11/01 12:15:27
0はヌルポインタだから0と比較すればいい
41:デフォルトの名無しさん
08/11/01 12:18:30
いいえ
42:デフォルトの名無しさん
08/11/01 12:20:43
>>33
NULLが0か(-1)の環境なら問題ないけどそうでない中間の値の場合問題になるな。
そんな環境はないと思うけど。
>>39
== NULLで比較するのが確実
43:デフォルトの名無しさん
08/11/01 12:57:05
>>41
嘘を言うな、直接触れるmemsetとかを別にすれば
0でいいだろうがカス
44:デフォルトの名無しさん
08/11/01 13:18:52
複数行マクロにつかう\ってなんのためにつけてるんですか?
45:デフォルトの名無しさん
08/11/01 13:21:46
自分のため
46:デフォルトの名無しさん
08/11/01 13:28:53
えんため
47:デフォルトの名無しさん
08/11/01 14:06:52
質問がわるかったですね
文字列リテラルいがいで\を使うとどういう意味になるのですか?
48:デフォルトの名無しさん
08/11/01 14:37:54
fopenについて聞きたいのですが、例えばfopen("c:\a.txt","r");と書いてもCドライブ直下にあるa.txtが開けないのですが
どうすれば解決できますか?
49:48
08/11/01 14:39:48
自己解決しました
50:デフォルトの名無しさん
08/11/01 14:40:54
>>48
なんで開けないの?
51:デフォルトの名無しさん
08/11/01 14:40:56
>>47
その質問は更に悪い。
defineディレクティブの行末のバックスラッシュは、改行文字をエスケープしてdefineディレクティブの継続を意味する。
文字列リテラルまたは文字リテラルのバックスラッシュは、次の文字をエスケープする。
52:デフォルトの名無しさん
08/11/01 14:41:46
>>48
Cドライブ直下というからにはMS-DOS系だと思うが、その場合はバックスラッシュを自分自身でエスケープしておく必要がある。
53:デフォルトの名無しさん
08/11/01 14:49:36
>>51
いえ、文字列や文字リテラル内での扱いは聞いていません
行末で使うと改行がエスケープされるんですねわかりましあ
行末以外で使うとどうなりますか
54:デフォルトの名無しさん
08/11/01 14:53:51
バックスラッシュの次の文字がエスケープされる。
55:デフォルトの名無しさん
08/11/01 15:02:17
>>48
fopen("c:\\a.txt","r");
56:デフォルトの名無しさん
08/11/01 15:13:28
超初心者です。
c言語の勉強を始めたばかりなんですが・・・
#incllude <stdio.h>
main()
{
printf("%d");
}
とすると1687って表示されるんですがこの「1687」って何ですか?
57:デフォルトの名無しさん
08/11/01 15:15:29
printf呼んだときに誰も使ってないエリアにたまたま入ってた数字
58:デフォルトの名無しさん
08/11/01 15:16:58
つーか後ろからつむから別の用途に使われてるか
59:56
08/11/01 15:31:39
>>57
ありがとうございます。
意味のない数字ってことですね。
>>58
ありがとうございます。
何を書いているのかもわからない・・・(^^;;
とりあえず気にしなくてもいいんだって理解して次に進むことにします。
お騒がせしました。
60:56
08/11/01 16:02:04
もう少し質問させてください。
#include <stdio.h>
main()
{
printf("%d","hello!"):
}
とすると「106」と表示されるんですけど、これも意味がない数字ですか?
整数を表示する%dなんだから式自体が不当な気もするけど。
61:デフォルトの名無しさん
08/11/01 16:16:38
初心者なら教科書通りにやっとけ。
自分で工夫しようなんて思うな。
62:デフォルトの名無しさん
08/11/01 16:22:09
アドレス
63:デフォルトの名無しさん
08/11/01 16:36:18
初心者がC言語学習の最初に触れる printf、scanfなどの書式指定関数は
C言語的には必要悪な関数であって邪道ともいえる仕組みで作られている。
初心者は printf について深く考えてはいけない。
書式文字列と正しい使い方だけを考えればよい。
書かれているようなイレギュラーケースの理解は初心者の範疇を越えている。
どうしても理解したければ、可変長引数(stdarg.h)を調べてみればいい。
64:デフォルトの名無しさん
08/11/01 17:04:33
> 邪道
<stdarg.h> で保証されている機能は邪道ではない
間違えやすいことを「邪道」と言っているならプログラム言語自体が邪道だと言っていることになる
65:デフォルトの名無しさん
08/11/01 17:52:53
邪道というか型安全じゃないから積極的に使いたくは無いな
66:デフォルトの名無しさん
08/11/01 18:07:30
型安全でないなら、低レベル処理も一切「使いたくない」わけか
そんならCなんかやめとけつーの
67:デフォルトの名無しさん
08/11/01 18:08:39
>38 は大嘘。
ANSI-Cでは、キャストされて0になることは保証されている。
Cを高級アセンブラだと思い込んでいるようなヤツには信じがたいかも知れんが。
68:デフォルトの名無しさん
08/11/01 18:14:04
int i, *p;
p = 0;
i = p;
の結果が i == 0 になることが保証されていることと
union {
int i, *p;
};
p = 0;
の結果が i == 0 になるかどうかは全く別問題
# ANSI, ANSI とほえる奴ほど ANSI の何ページの何行目かを言えない法則
69:デフォルトの名無しさん
08/11/01 18:18:13
URLリンク(c-faq.com)
70:デフォルトの名無しさん
08/11/01 18:21:44
>68
何ページの何行目?
71:デフォルトの名無しさん
08/11/01 18:29:27
国内・国際規格があるのを差し置いて他国の国内規格を持ち出している時点でβακαフラグ立ってるんだよ
72:デフォルトの名無しさん
08/11/01 18:30:37
>>66
ニホンゴよめてます
73:デフォルトの名無しさん
08/11/01 18:31:03
>>72
それは
報告
しなくても
いいです
74:デフォルトの名無しさん
08/11/01 18:37:44
>>71
ウンコ訳のJISなんか持ち出すやつのほうがバカっぽい。
75:デフォルトの名無しさん
08/11/01 19:05:08
関数の事で質問なのですが、
呼び出すときに、呼び出し先で出力しているのでしょうか?
returnを付ける事で、呼び出し元に値を返して出力しているのでしょうか?
76:デフォルトの名無しさん
08/11/01 19:07:18
>>75
出力、って何をだ?
日本語でおk、って言いたくなるんだが。
77:デフォルトの名無しさん
08/11/01 19:08:02
呼び出し先で出力することもあるし、
呼び出し元で出力することもあります。
78:デフォルトの名無しさん
08/11/01 19:13:55
if文の比較部分で
if(a==b){xxx;}
って書くところを間違えて
if(a=b){xxx;}
って書いてもコンパイルできますが、この場合ifの処理はどうなるんですか?
79:デフォルトの名無しさん
08/11/01 19:15:11
bをa に代入した後その値を見る
そして、0なら偽、0以外なら真
80:デフォルトの名無しさん
08/11/01 19:16:33
>>78
警告がでたらエラーと思え。
81:デフォルトの名無しさん
08/11/01 19:17:03
>>74
国際規格って書いてあるだろ、知らないのか ISO を?
82:デフォルトの名無しさん
08/11/01 19:18:16
どうせそれぞれの差異にかかわるような話なんてしないんだから
どれでもいーじゃねーか
他でやれ
83:デフォルトの名無しさん
08/11/01 19:29:01
>>81
最初に書いてある国内ってのは、脳内では無かったことになってるのか。
84:デフォルトの名無しさん
08/11/01 19:32:52
>>75
質問は返り値(戻り値)のことでの疑問でしょうか?
それなら簡単です。関数の戻り値は、通常の変数の値と同じ理解でいいんですよ。
int func( int a, int b )
{
return ( a + b ); // int型の関数func は常に a + b の値を返します。
// つまり関数func は a + b というint型の値を持つ変数と同じ性質です。
}
void main( void )
{
int n;
int a = 1;
int b = 2;
n = func( a, b ); // n には関数funcが返す値 a + b が代入されます。n = a + b; と同じです。
}
85:デフォルトの名無しさん
08/11/01 19:46:51
>>83
国際って書いてあるのを見落としたお前の失態
86:デフォルトの名無しさん
08/11/01 19:51:55
>>85
『「国内・国際」って書いちゃったけど、やっぱ国内のほうは無しで、国際だけね」ってこと?
87:デフォルトの名無しさん
08/11/01 19:52:34
揚げ足取りみたいなバカがいるようで、やはりここは
回答者のレベルが低い、知能も知識も、精神レベルもw
こんな腐った場所で質問する初心者は、場所を変えた方が良い。
まともな学校に通いなってことだ。所詮、ここは偽善有志者による
無責任で、一部の人間の自己満足で運営されていますからw
88:デフォルトの名無しさん
08/11/01 19:54:47
あと 俺は英語なんて読めなくてJISの訳がどの程度の質か知らんし、 >>74 は適当に思いつきで煽っただけだから、
あわてて「国際」の話だとか言い訳する必要も無いよ。
89:デフォルトの名無しさん
08/11/01 19:54:48
>>86
ISO とも書いたがそれも読めてないようだな
>>87
学校というより収容所のせいだろう
90:デフォルトの名無しさん
08/11/01 19:57:50
そもそも >>71 が激しくどうでもいい揚げ足とりだしな。
91:デフォルトの名無しさん
08/11/01 19:58:52
>>89
それくらいは読めてますよ。
92:デフォルトの名無しさん
08/11/01 20:55:12
Borland C++ Compilerがダウンロードできないんですけど
どうすればいいですか?
93:デフォルトの名無しさん
08/11/01 20:55:55
がんばってもっと探しましょう
94:デフォルトの名無しさん
08/11/01 21:08:19
他のコンパイラ探せってことですか?
95:デフォルトの名無しさん
08/11/01 21:13:15
Borland C++ Compilerでググって最初に出てくるページは違うのか。
96:デフォルトの名無しさん
08/11/01 21:19:56
URLリンク(www.codegear.com)
ここで C++Compiler / Turbo Debugger をダウンロードしたいんだけど
ユーザー登録してダウンロードのできるページに行こうとすると
表示するページがないって出る。ユーザー登録したメアドには
Zip解凍パス届いてるのに…。
97:デフォルトの名無しさん
08/11/01 21:22:40
BCCは時代遅れだからVC++にしておけ。
98:デフォルトの名無しさん
08/11/01 21:25:50
>>96
俺もダウンロードできないな。
> 上記のダウンロードサイトにアクセスできないときは、CodeCentral のダウンロードページをお試しください。
> CodeCentralのダウンロードページを利用するには、CDNへのログインが必要です。
ダウソのページに↑と書いてあるけど、CDNの登録とか面倒だから、これ以上はためさないけど。
99:デフォルトの名無しさん
08/11/01 21:26:55
Cコンパイラとして使うなら、どっちでもそう変わりないと思う。
100:デフォルトの名無しさん
08/11/01 21:27:42
でもダウンロードの敷居が違う。
だったらめんどくさい思いしてまでして使う理由が見当たらない。
101:デフォルトの名無しさん
08/11/01 21:31:11
>>97
win2kなんでVC++使えないです…。OS自体が時代遅れなんで。
>>96
みんなそうなんだ?なんとかならないかな…。
102:デフォルトの名無しさん
08/11/01 21:38:31
cygwinやmingwなら登録いらずだよ。
103:デフォルトの名無しさん
08/11/01 22:07:57
>>101
URLリンク(phys.cool.ne.jp)
なら一応bcc入りだよ?
104:103
08/11/01 22:14:09
見つけた
URLリンク(clove.rye.tama.ac.jp)
105:デフォルトの名無しさん
08/11/02 04:48:43
FILE型はどうしてオブジェクト型なの?
106:デフォルトの名無しさん
08/11/02 05:00:12
>>34
BCPL
Cの次はP言語
107:デフォルトの名無しさん
08/11/02 05:14:43
>>105
オブジェクトで何か問題が?まさか関数型だとでも?
108:デフォルトの名無しさん
08/11/02 05:30:37
>>107
どうして構造体型じゃないの?
109:デフォルトの名無しさん
08/11/02 05:32:34
FILEのメンバーを気にしたことある?
110:デフォルトの名無しさん
08/11/02 05:33:31
うわぁ・・・
111:デフォルトの名無しさん
08/11/02 05:42:23
>>109-110
何故オブジェクト型にする必要があったの?
112:デフォルトの名無しさん
08/11/02 05:43:45
Cでは整数もポインタも構造体もオブジェクトなわけだが…。
113:デフォルトの名無しさん
08/11/02 05:46:16
>>112
オブジェクト型は総称じゃないの?
114:デフォルトの名無しさん
08/11/02 08:48:57
電気代を算出するようなプログラムを作っているのですが
電気代の方が正常に表示されません(有り得ない桁数が表示される)。
他の部分も、まだまだ作りこまれておらず稚拙な内容ですが
とりあえず今は、電気代がきちんと出る事を目的としています。
使用しているコンパイラはVisual C++ 2008です。
どなたかご教授お願いします。
115:114
08/11/02 08:49:54
すいません、ソースコードを張り忘れていました。
URLリンク(kansai2channeler.hp.infoseek.co.jp)
宜しくお願いします。
116:デフォルトの名無しさん
08/11/02 08:57:22
scanf・・・恐ろしい子・・・
117:デフォルトの名無しさん
08/11/02 09:07:04
とにかくdoubleとの相性が最悪よね。どうしたのかしら。
118:114
08/11/02 09:13:07
>>116-117
つまりプログラムでのミスというよりは、仕様での異常という事でしょうか?
そうなると、別の入力方法を考えないといけないわけですね・・・
ご解答有難うございました。
119:デフォルトの名無しさん
08/11/02 09:19:02
>>118
アホかい。自分が使い方間違っているだけだって。
つーか、そのミスに警告も出てないとしたら、コンパイラの使い方も間違っているかもしれないぞ。
120:114
08/11/02 09:31:16
>>119
そうだったのですか。
コンパイラはVisualC++2008の方に混同されているものですが
使い方などは考えたことありませんでした。
もう一度よく調べて見ます。
有難うございました。
121:デフォルトの名無しさん
08/11/02 09:40:45
誰か>>105について教えて下さい
122:デフォルトの名無しさん
08/11/02 09:42:15
>>121
struct です
123:デフォルトの名無しさん
08/11/02 09:57:31
1 は何故 int型なの?
'A' は何故 char 型なの?
0は何故偽値なの?
if文は何故式じゃないの?
124:デフォルトの名無しさん
08/11/02 09:58:46
>>122
何故オブジェクト型なのですか?
何故構造体型では無いのですか?
125:デフォルトの名無しさん
08/11/02 10:01:37
構造体だって書いてあるじゃん。
バカなの?
126:デフォルトの名無しさん
08/11/02 10:07:09
>>125
JIS X3010:2003にはオブジェクト型であると説明されているのですが、
あなたは構造体型であると言いたいのですか?
127:デフォルトの名無しさん
08/11/02 10:08:12
YES
128:デフォルトの名無しさん
08/11/02 10:12:13
>>127
どうして構造体型なの?
129:デフォルトの名無しさん
08/11/02 10:17:02
いや、間違った。別に構造体である必要は無いか。
規格でそこまでは決められてないな。
構造体以外で実装されている処理系は見たこと無いが。
Q.なぜ構造体ではなくオブジェクト型なのか?
A.構造体です。
Q.なぜオブジェクト型なのか。
A.規格でそう決められてるから。
130:デフォルトの名無しさん
08/11/02 10:18:58
>>129
、別に構造体型じゃなくても構わないッスw適当にやっちゃってよw、
って事?
131:デフォルトの名無しさん
08/11/02 10:21:37
規格に書かれていないことは実装者の自由。
もっとも規格に沿ってない実装だってあるわけだから、
目指すものによって守るべきルールも決まってくる。
規格に無くても、世の中にはデファクトスタンダートと言うものもあるしな。
132:デフォルトの名無しさん
08/11/02 10:21:57
ポインティンガーから構造体にアクセスするときだけ -> で
いいのですか
133:デフォルトの名無しさん
08/11/02 10:25:09
>>131
なるほど、ありがとうございます。
134:デフォルトの名無しさん
08/11/02 13:00:04
っていうか、Cの規格のオブジェクトってのは、オブジェクト指向のオブジェクトとは別物だろ。
135:デフォルトの名無しさん
08/11/02 14:27:09
perlの処理系をC言語で作る事はできますか?
136:デフォルトの名無しさん
08/11/02 14:28:18
できますというかできてます
137:デフォルトの名無しさん
08/11/02 14:30:26
Perlの処理系はLarryの優しさから出来ています
とりあえずこちらをご覧下さい
URLリンク(www.cpan.org)
138:デフォルトの名無しさん
08/11/02 14:36:02
他にもC言語でできてる、代表的なソフトを教えて下さい。
139:デフォルトの名無しさん
08/11/02 14:39:41
Unix系OS
140:デフォルトの名無しさん
08/11/02 14:51:23
Cの処理系
141:デフォルトの名無しさん
08/11/02 14:57:40
YO YO エビバーデー
142:デフォルトの名無しさん
08/11/02 15:29:45
フィンガー5じゃないが、リンリンしなくて良いからw
143:デフォルトの名無しさん
08/11/02 16:02:55
>>115
scanf("%f",&y);
↓ ^^
scanf("%lf",&y);
^^
printf("その電化製品で掛かる月の電気代は%e¥で、基本料金は%d¥です\n",ene,x);
↓ ^^^
printf("その電化製品で掛かる月の電気代は%.3f¥で、基本料金は%d¥です\n",ene,x);
^^^
これでいかがでしょう?(printfのほうは自分の好みで変更しました)
ただ、xが使われていないような・・・
144:デフォルトの名無しさん
08/11/02 16:08:18
>>143です
思いきりずれました
つまり、scanfのフォーマット指定を"%f"→"%lf"
pritnfのフォーマット指定を"%e"→"%.3f"(この3は小数点以下桁数なのでお好みで)
でいかがでしょう?
145:デフォルトの名無しさん
08/11/02 17:49:25
いまひとつ有り得ない桁数というのが分からないのと
それであってるのか分からないのだが
eneは電気代じゃなくて一ヶ月分の消費電力しか計算して無くないか?
146:デフォルトの名無しさん
08/11/02 17:51:19
普通、¥は接頭です。
147:デフォルトの名無しさん
08/11/02 17:55:35
計算するときは、常に単位を意識するといい。
y * z * 30は、即ち y[W] * z[h/day] * 30[days/month]だからつまり、ene[Wh/month]となる。
つまり、月当たりの電力量と言うことだ。
148:デフォルトの名無しさん
08/11/02 18:10:45
unsigned charの変数は初期化をしなくても問題は無いのですか?
大学の課題のサンプルプログラムの中に初期化も代入もせずに
値を参照している部分を見つけたもので気になって質問しました
試したところ確かに初期値?として0が格納されているみたいなんですが
これをそのまま利用していいんでしょうか?
自分の知識や習慣だと変数を初期化等をしないまま参照するのは
おかしい気がするのですが何かこうすることで問題が発生したりはしますか?
149:デフォルトの名無しさん
08/11/02 18:14:53
グローバルスコープやstaticな変数なら0で初期化される。
ローカル変数ならゴミが入ってる。
150:デフォルトの名無しさん
08/11/02 18:15:40
型の問題ではなく、定義されている場所の問題。
関数内のローカル変数でstaticでないなら、初期化しないと不定値になる。
151:デフォルトの名無しさん
08/11/02 18:16:34
グローバル変数なら0で初期化される
152:デフォルトの名無しさん
08/11/02 18:19:43
>>149
あれ?関数内のstaticな変数は0初期化されないんじゃなかったっけ?
153:デフォルトの名無しさん
08/11/02 18:22:04
されます。
154:デフォルトの名無しさん
08/11/02 18:26:30
>>149->>151
おお、ありがとうございます!
なるほど、型ではなくスコープの問題だったんですね
確かにそのプログラムではグローバル変数でした
今までそんなこと全く知らずに使ってました^^;
勉強になりました
155:デフォルトの名無しさん
08/11/02 18:32:39
スコープっていうか静的か動的かの話じゃないかな
コンパイル時なら0で初期化とかやっても遅くならないし
156:152
08/11/02 18:36:12
>>153
確かにそうみたい。なんか勘違いしてた
157:デフォルトの名無しさん
08/11/02 18:40:33
テキストファイルから1行ずつ読み込んで、
それをスペースを間に入れて表示したいです。
例えばテキストファイルの中身が
a
b
だったら「a b」という感じに表示したいのですが、
以下のコーディングで正しいでしょうか?
環境はWindowsXP、VisualC++2008 ExpressEditionです。
char buf[1024];
FILE *fp = fopen("test.txt", "r");
while(fgets(buf, sizeof(buf), fp) != NULL){
buf[strlen(buf)-1] = '\0';
printf("%s ", buf);
}
158:デフォルトの名無しさん
08/11/02 18:49:43
>>157
だいたいそれでいいんじゃないの?
一行が1024文字以上だったらどうするとか、細かいことは考えないで。
159:デフォルトの名無しさん
08/11/02 18:56:06
>>158
大丈夫そうですか?
あ、でもこれだとテキストファイルの最後に空白行
入れないと駄目っぽいですね。
160:デフォルトの名無しさん
08/11/02 19:09:00
聞く前に試せよ
161:デフォルトの名無しさん
08/11/02 19:24:35
俺に聞けスレで試せで終わらすなんて。
162:デフォルトの名無しさん
08/11/02 19:33:25
何故ダメなのか聞くためのスレだろ
163:デフォルトの名無しさん
08/11/02 19:35:35
>>159
fgetc()とfputc()で、一文字単位でしょりして、\nだったら空白に置き換えるってほうが、
簡単なんじゃね?
164:デフォルトの名無しさん
08/11/02 19:36:01
できることできるだけやってから質問するのは当たり前だろ
165:デフォルトの名無しさん
08/11/02 19:38:22
一番ダメな考え方
「動くからこれでいい」
動くからと言って、CPUの演算処理を独占するようなコードはクソである。
だから動くからいいと言うものではない
166:デフォルトの名無しさん
08/11/02 19:38:39
>143です
>>145-146さん
皆さん指摘の通り、中途半端な回答になっていました。
>>115さん
URLリンク(kansai2channeler.hp.infoseek.co.jp)
に修正版をうpしたので許してください
167:デフォルトの名無しさん
08/11/02 19:45:17
>>163
その方が簡単ですね。効率性も考えるとfgetsですかね?
168:デフォルトの名無しさん
08/11/02 19:50:27
>>167
たぶん、大差ないんじゃないの?
昔、setvbuf()ってので、バッファのサイズを増やしたら速度が向上してたけど、
Windowsの時代になってから、同じようなことをやってもあんまり変わらなかった。
OSレベルでのバッファリングされてるからだと思うけど。
169:デフォルトの名無しさん
08/11/02 20:19:51
仮に、CPUの処理速度が無限大あって
ビットシフトなんか使っても速くならないとしても
常に最適化を忘れてはいけない
コンパイラが最適化してくれるとしても
自分の手で最適なコードを書くことを忘れてはいけない
これが出来ない奴はルータも携帯電話も作れない
170:デフォルトの名無しさん
08/11/02 20:21:34
携帯やルータってCで出来てるの?
171:デフォルトの名無しさん
08/11/02 20:29:30
基本は読みやすさ。
要件をみたせないときに、最適化。
172:デフォルトの名無しさん
08/11/02 20:32:53
Cではありません。スパゲッティーで出来てます。
。。。ごめん
173:デフォルトの名無しさん
08/11/02 20:35:12
またド忘れしちゃった。。
左シフト演算って、常に論理シフトするんだっけ。
signed でも unsigned でも正値でも負値でも。
右シフト演算がちょっとめんどくさいことになってることは
覚えてるんだけど。
174:デフォルトの名無しさん
08/11/02 20:37:28
なぜコードを最適化するのですか?
175:デフォルトの名無しさん
08/11/02 20:40:24
めんどくさいものは使わない。
176:デフォルトの名無しさん
08/11/02 20:48:13
組み込みは未だに、CとASMで出来ている
177:デフォルトの名無しさん
08/11/02 20:59:00
>>172
ざる蕎麦ではできていないのか
178:デフォルトの名無しさん
08/11/02 20:59:47
>>173
#include <stdio.h>
#include <limits.h>
#define UPPER_BIT (1 << (sizeof(int) * CHAR_BIT - 1))
void print_bit_s(int n){
unsigned int mask = UPPER_BIT;
for(;mask; mask >>=1) putchar(mask & n ? '1' : '0');
putchar('\n');
}
void print_bit_u(unsigned int n){
unsigned int mask = UPPER_BIT;
for(;mask; mask >>=1) putchar(mask & n ? '1' : '0');
putchar('\n');
}
int main(){
int n1 = (-1);
int n2 = n1 & ~UPPER_BIT;
unsigned int m1 = n1;
unsigned int m2 = n2;
print_bit_s(n1 >> 1);
print_bit_u(m1 >> 1);
print_bit_s(n2 << 1);
print_bit_u(m2 << 1);
return 0;
}
// output
11111111111111111111111111111111
01111111111111111111111111111111
11111111111111111111111111111110
11111111111111111111111111111110
179:デフォルトの名無しさん
08/11/02 21:25:30
>>174
そこにコードがあるから
180:173
08/11/02 21:44:14
んー、たとえば右シフト演算について言えば、符号付き整数型の負値に対して演算を
適用した結果は処理系に依存しますよね。output の1行目でいうと、算術シフトするか
論理シフトするかは処理系に依存すると。。
上の2行は
01111111111111111111111111111111
01111111111111111111111111111111
こうなる可能性があるわけですよね。下の2行に関しては同様に処理系依存の問題は
大丈夫なのでしょうか。コードを解読し切れてないので結論が良く見えないのですが。
181:デフォルトの名無しさん
08/11/02 21:50:37
>>173
っMSDN
と思ったけど、検索しても見つけにくかったので、ローカルから。
Shift Operators: >> and << (ごめん、英語なんだ)
とりあえず適当訳。
左シフトは0埋め。論理シフト。
右シフトはunsignedは0埋め。signedは符号ビットで埋める。
unsignedは論理シフト。signedは算術シフト。
・Microsoft Specific
signed の負の数の右シフトは、実装によります。
MicrosoftのC++の場合は、MSBで空いたビットを埋めます。
MSのC++以外の場合は知らん。
だそうです。
182:デフォルトの名無しさん
08/11/02 21:53:03
なんでこういう細かいところ統一しないの?
183:173
08/11/02 22:12:18
わざわざ和訳までしてもらってすいません。Cの規格的な部分ではどうなんでしょうね。。
Microsoft仕様ではCとC++とでまた違うんですか。こちらでももうちっとしらべてみます。
あふん。。
184:デフォルトの名無しさん
08/11/02 22:20:14
>>182
なんでOSは統一しないの?なんで通貨も、言語も。
所詮、こんなものは、規格化した集団が幅広い用途を考慮して
決めるか、一部の団体の意見の押し付けでしかないってことだよ。
そして俺らはそれを使うだけ。開発、発案、研究するわけでもない・・・
まぁ、俺はとある有名大学で研究、実験はしたがな。
185:デフォルトの名無しさん
08/11/02 22:28:45
>>182
効率を重視するから
186:デフォルトの名無しさん
08/11/02 22:32:34
>>183
MSの場合Cでも>>181と同じ。
そこに書いてある「MSのC++以外」とは、MS以外のC++という意味。
規格上は、負の値の左シフトは未定義。
正の数なら符号付き・符号無しいずれの型でも0埋めで定義されている。
CはJIS X3010、C++はJIS X 3014が国際規格の翻訳として存在する。
URLリンク(www.jisc.go.jp)
187:173
08/11/02 22:57:15
おお!そのものズバリのご回答ありがとうございます。
負値の左シフトは未定義でしたか。
正値ならば符号付き・無しに関わらず論理シフトすると、こういうことですね。
ややこしいなあ。。
ともかくこれでスッキリしました。
ありがとうございました。
188:デフォルトの名無しさん
08/11/02 23:05:13
左シフト?
189:デフォルトの名無しさん
08/11/02 23:06:46
「右も左も分かりません」
190:デフォルトの名無しさん
08/11/02 23:14:23
アホか
191:デフォルトの名無しさん
08/11/02 23:16:59
↑うん、お前アホ。
192:デフォルトの名無しさん
08/11/02 23:27:23
肝心のシフト演算子について話せない奴はすっこんでろ
193:デフォルトの名無しさん
08/11/02 23:28:34
>>187
算術左シフトという言葉があったとしても、負の値のそれはやっぱり0埋めだよ。
論理左シフトと全く同じだから、わざわざ算術と言わないだけ。
算術右シフトが負値で1埋めするのは符号を維持するための結果であって、
1埋めするから算術というわけではない。
194:デフォルトの名無しさん
08/11/02 23:29:41
自分の論理を自分に適用できない奴はすっこんでろ
195:デフォルトの名無しさん
08/11/02 23:49:20
そんなに符号のことが気になるなら、unsignedをしっかり指定しとけ、な?
196:デフォルトの名無しさん
08/11/02 23:53:00
>>177
ざる蕎麦ではだめです。 もり蕎麦に、のりを盛るところから始めなくては。
きしめんでも可。 たぶん、時期的に、そうめんはだめだと思う。
(って何の話だっけ
197:187
08/11/02 23:55:37
言葉の定義って難しいですね。。ややこしくて頭がパンクしそうです。
単純に 0埋め=論理シフト、1埋め=算術シフトと覚えてました。
算術(右シフト)だから符号を維持する必要がある→結果として1埋めになる
論理(右シフト)だから符号を維持する必要がない→結果として0埋めになる
こういうことなのかな。考えたことも無かった。
198:デフォルトの名無しさん
08/11/03 00:00:01
そんなに心配なら shl, sal, shr, sar を直に使えよ
199:デフォルトの名無しさん
08/11/03 00:04:35
算術シフトは
左にnビットシフトすると,元の数の2^n 倍
右にnビットシフトすると,元の数の1/2^n倍
これを保障するシフト演算。だから算術という。
200:デフォルトの名無しさん
08/11/03 00:10:33
RCL、RCR、ROL、RORとか混ぜると、さらにパンク。
201:187
08/11/03 00:20:29
なんで知らなかったんだろう今まで。。恥ずかしい。
算術って言うのは単に符号を維持するっていうことじゃなくて、そういうことなのね。。
それを保証するために符号の維持も当然必要で、その結果1埋めになる(右シフトの
場合)ということかな。
202:デフォルトの名無しさん
08/11/03 11:49:20
>>184
多様性のもつ可能性を吟味しなければなりません。
203:デフォルトの名無しさん
08/11/03 13:53:42
scanfで入力してもらった数字、例えば1234を合計した数字を変数に入れる方法を教えて下さい。(入門者にも理解できる範囲でお願いします)
204:デフォルトの名無しさん
08/11/03 13:59:03
数字は1 2 3 4とバラバラに入力するのかそれとも連続で1234と入れるのか?
205:203
08/11/03 14:02:37
連続で入力するほうでお願いします。
206:デフォルトの名無しさん
08/11/03 14:06:53
文字列で受け取って、一文字づつバラして、数値に変換して、全部足す
207:デフォルトの名無しさん
08/11/03 14:16:20
>205
まず、%d指定子を使って1234という数字をまるごとあるint変数(仮にt)に読み込む
次に、合計を得る変数(仮にs)をゼロに初期化する
そして、以後tが0より大きい間、tを10で割った余り(%演算子を使うこと)をsに加算してからtを10で割るということを繰り返す
※Cでは、正の整数の割り算は端数を切り捨てる
流れ:
s:0 t:1234(読み込み)
s:4 t:123(1234を10で割った余り4をsに足しtを123に)
s:7 t:12(123を10で割った余り3をsに足しtを12に)
s:9 t:1(12を10で割った余り2をsに足しtを1に)
s:10 t:0(1を10で割った余り1をsに足しtを0に)
(tが0になったので終了)
208:デフォルトの名無しさん
08/11/03 14:21:45
int a;
scanf("%d", &a);
printf("%dの合計を暗算して入力してください");
scanf("%d", &a);
printf("はい、ご名算!");
209:デフォルトの名無しさん
08/11/03 14:50:08
宿題は宿題スレへ じゃないのか?
210:デフォルトの名無しさん
08/11/03 15:04:53
そういうのって、getchar() ループの方が楽じゃね?
#include <stdio.h>
void main( void )
{
int loop = TRUE;
int sum = 0;
char c;
while ( loop ) {
c = (char)getchar(); // 1文字入力
switch ( c ) {
case '0': // 0~9が入力された場合、sumに足しこむ
case '1':
case '2':
case '3':
case '4':
case '5':
case '6':
case '7':
case '8':
case '9':
sum += (int)( c - '0' );
break;
case EOF:
loop = FALSE;
break;
}
printf( "合計値は %d \nです。", sum );
}
}
211:デフォルトの名無しさん
08/11/03 15:08:52
'0'-'9'は連続が保障されてるから、そんなことしなくても
212:デフォルトの名無しさん
08/11/03 15:22:36
int c, sum = 0;
while (isdigit(c = getchar())) sum += c - '0';
printf("%d\n", sum);
これだけでいいじゃん
213:>212
08/11/03 15:25:30
0~9以外を無視していないから却下
214:デフォルトの名無しさん
08/11/03 15:27:06
え?
215:デフォルトの名無しさん
08/11/03 15:29:13
123x4 と入力したら 10 が返ってくる仕様が求められてるのか?
216:デフォルトの名無しさん
08/11/03 15:30:18
>>209
丸投げでなければわからないことを聞くのは一向にかまわない
>>210-212
scanfでって言ってるのにgetcharはないだろ
217:デフォルトの名無しさん
08/11/03 15:41:17
こういうので、質問者にscanf()が必須条件なのか、それ以外でもいいのかって質問してもめったに返事が返ってこないよな。
218:210
08/11/03 15:43:37
>>216
こういうのはふつうキーイベントループ制御だべよー。
WindowsのようなGUIでもテキストボックスに「1234」なんて連続して入力させるかぁ?
219:203
08/11/03 15:49:26
みなさん、お答えいただきありがとうございます。
アドバイスを受け、色々と試してはいるのですが、一向にうまくいきません。
ここで質問なんですが、1234を
char str[5];
scanf("%s",str);
で文字列として受け取って
atoi(str)で整数値に変換
その後に1234を一文字ずつにバラす方法がさっぱりわかりません
アドバイスお願いします。
220:デフォルトの名無しさん
08/11/03 15:52:30
>>219
4 = 1234 % 10;
123 = 1234 / 10;
221:デフォルトの名無しさん
08/11/03 16:07:33
文字列入力ってテーマを見ると、すぐにgetchar()で一文字ずつ判断するロジック書く奴っているよね。
そういう奴に限ってろくでもないバグを仕込むから笑えない。
222:デフォルトの名無しさん
08/11/03 16:09:19
例えば、>212はまぁ無難な方で、>210なんてわざわざバグを埋め込むための無駄な努力の跡さえ見えてしまう事実。
223:デフォルトの名無しさん
08/11/03 16:23:58
>>221
本番では2バイト文字に気を付ければいいだけだろ
>>222
レビューでデバッグしてくれ
224:デフォルトの名無しさん
08/11/03 16:35:49
標準入力から0xffを入力すると、EOFと誤解釈して終了してしまうね。
この程度のサンプルならどうでもいいけど、ファイルをリダイレクトして使うようなツールだと恐怖だね。
225:デフォルトの名無しさん
08/11/03 16:42:38
>219
ソースはれ
あと、ほかに制約がないのなら、%sからatoi()なんかしないで素直に%dで読みなさい
226:デフォルトの名無しさん
08/11/03 17:00:30
>>224
それ、0xffイコールEOFだから誤解釈じゃないよ。それも正常系の解釈と処理。
まあサンプルプログラムだし、EOFは入力の終了条件のために設けた
だけだから、そこは削除して他の方法に置き換えても構わないし。
227:デフォルトの名無しさん
08/11/03 17:06:47
違います
EOFは決して0xffではありません
228:203
08/11/03 17:07:34
#include<stdio.h>
int main()
{
int w,x,y,z,goukei;
int w2,x2,y2,z2,goukei2;
int yosou[4];
int yosou2;
printf("前回の当選数字を入力:\n");
scanf("%d,%d,%d,%d",&w,&x,&y,&z);
goukei = w + x + y + z;
printf("前々回の当選数字を入力:\n");
scanf("%d,%d,%d,%d",&w2,&x2,&y2,&z2);
goukei2 = w2 + x2 + y2 + z2;
printf("今回予想した数字を入力:\n");
scanf("%d,%d,%d,%d",&yosou[0],&yosou[1],&yosou[2],&yosou[3]);
yosou2 = yosou[0] + yosou[1] + yosou[2] + yosou[3];
if(goukei == yosou2 || goukei2 == yosou2){
printf("%d Is a NG\n",yosou2);
}else if(yosou2 > 9 || yosou2 < 27){
printf("%d NG",yosou2);
}else{
printf("%d OK\n",yosou2);
}
return 0;
}
ナンバー4の当たり数字過去2回の合計値と一致した場合、NGと出力するプログラムです。
また、予想した数字の合計値が9~27に入ってなくてもNGと出力します。
ほんとくだらなくてすいません。
229:デフォルトの名無しさん
08/11/03 17:13:14
>>226
いや、大誤解だと思いますね。>>224 ではなくて、>>>226 が。
>>210 は getchar() の戻り値を char でうけているのが、センスがないというか、そもそも本質を理解していない、というべきか。
もしかして、いつものあなたですか?これはつり?
230:デフォルトの名無しさん
08/11/03 17:17:14
いつものあなたって・・
お前は誰と戦ってるんだ
231:デフォルトの名無しさん
08/11/03 17:22:56
非科学的=厨はマ板にまではびこっている
232:デフォルトの名無しさん
08/11/03 17:25:19
糖質かこいつ
233:デフォルトの名無しさん
08/11/03 17:33:18
どいつ?
234:デフォルトの名無しさん
08/11/03 17:34:13
229
235:デフォルトの名無しさん
08/11/03 17:34:35
>>228
scanfを使うことは必須条件?
あと入力するのは「1234」なのか「1,2,3,4」なのか
前者だったら>>207でできないかな
後者だったらsscanfとかを調べてみるといいかも
236:デフォルトの名無しさん
08/11/03 17:51:07
>>227
ですよね。というか、標準入力からの入力値が、つうつうで getchar() ≒ fgetc() の返り値になるわけではないのですが。
>>230-234
やっぱりIDをつけたほうがいいのでしょうかね。
237:デフォルトの名無しさん
08/11/03 18:04:03
>>228
"%d,%d,%d,%d"と書いたら、それは1,2,3,4と入力させることを意味する
1234と入力するのなら>>207のようにすること
238:デフォルトの名無しさん
08/11/03 18:21:31
fgetsじゃなくてgetsでいいよ
どうせ両関数の仕様すら理解していないんだろ
239:203
08/11/03 18:26:55
スレ汚しすいませんでした。
>>207の方法で1から作り直します。
皆さんご回答本当にありがとうございます。
240:デフォルトの名無しさん
08/11/03 19:38:12
URLリンク(kansai2channeler.hp.infoseek.co.jp)
画面内の球をクリックすると初速度v0で鉛直投げ上げするプログラムです
空中にある状態の球をクリックするとまたその位置から投げ上げされて
球をクリックするたびにどんどん球が上がるようにしたいんですが、
空中の球をクリックしても何も起こしません。
ボールが跳んでるときに、最初にボールがあった場所をクリックするとおかしなことに。
241:デフォルトの名無しさん
08/11/03 19:43:31
あっそう
242:240
08/11/03 20:22:33
どこが間違ってますかね?
243:受付番号001
08/11/03 20:25:58
>>242
いま診てやるから待ってろ
244:デフォルトの名無しさん
08/11/03 20:34:54
たぶんここだな
if(bally+ball >= 500){
KillTimer(hWnd,ID_MYTIMER);
bTimer = FALSE;
mytime = 0;
}
245:質問
08/11/03 20:55:23
ファイルの直ぐ下に任意のファイルの内容を
そのままコピー、連結できる関数ありますか?お願いしますm(__)m
246:デフォルトの名無しさん
08/11/03 20:58:55
>>245
ないです。
247:デフォルトの名無しさん
08/11/03 21:00:06
自分でアペンドモードで開いてコピーしる
248:デフォルトの名無しさん
08/11/03 21:00:38
下はどっちだ?
249:デフォルトの名無しさん
08/11/03 21:02:24
>>245
C/C++の宿題を片付けます 117代目
スレリンク(tech板)
250:245
08/11/03 21:02:52
ということはファイルの内容を読み込んで
fopenのaで逐一書き込んでいくのが最良の方法ですね?
251:デフォルトの名無しさん
08/11/03 21:03:23
system
252:デフォルトの名無しさん
08/11/03 21:06:56
読み込みながらの方が良いだろう。
char buf[4096];
f = fopen(path, "r");
g = fopen(paht, "a");
while (c = fread(buf, 1, sizeof buf, f))
fwrite(buf, 1, c, g)
253:245
08/11/03 21:12:33
ありがとうございましたm(__)m
254:240
08/11/03 21:18:46
>>244
問題ないような気が・・?すみません分からないです
255:受付番号001
08/11/03 22:24:32
>>254
診ましたよ~。
えーと、これはですね、、、もう手遅れです。 (←うそ)
問題点はボールのY座標の扱いですね。 WndProc内の変数ballyで保持しているY座標と
WM_TIMERメッセージ内で一時的に計算しているY座標とが一致していません。
ballyはウィンドウメッセージを受けるたびに480に初期化されていますので、上に飛んでいる
ボールをクリックしても反応しなく、地面をクリックすると反応してしまうのです。
ballyはWM_CREATメッセージ内だけで初期化しましょう。
また、WM_TIMERメッセージ内では常に地面からの座標計算でボールの高さを計算して
しまっているので、上手くボールにヒットしたらballyの位置から計算しなおす様に変更する
必要があります。
256:デフォルトの名無しさん
08/11/03 22:25:18
>>245
COPYやcatで連結は駄目なの?
257:デフォルトの名無しさん
08/11/03 22:35:13
ソースを読むって言うのはさ
自分とソースを一体化させる作業なんだ
「俺は今どうなっているのか」と考えながら読むんだ
無意識にみんなやってると思うぜ
他の何かがどうなってるかではない、自分がどうなってるか
258:質問
08/11/03 23:27:00
下記の違いを教えていただけますでしょうか?
return
exit
あ、あと
EXIT_FAILUER
ってなんですか?
259:デフォルトの名無しさん
08/11/03 23:28:00
FAILUARE
260:デフォルトの名無しさん
08/11/03 23:28:50
こういう人にはgoogleの使い方を教えたほうが親切なんでしょうか?
261:デフォルトの名無しさん
08/11/03 23:29:38
return は予約語
exit はライブラリ関数
EXIT_FAILURE はマクロ定数
です。
262:デフォルトの名無しさん
08/11/03 23:40:04
return は関数から抜ける
exit はプロセスから抜ける
EXIT_FAILUER は書いた者に聞け(煽り口調で)
263:デフォルトの名無しさん
08/11/03 23:41:28
EXIT_FAILURE はマクロ定数の意味が分りません
264:240
08/11/03 23:44:28
>>255
うまくいきました!
大変わかりやすい説明ありがとうございます!
265:デフォルトの名無しさん
08/11/03 23:51:02
>>257
空気を読むって言うのはさ
自分と空気を一体化させる作業なんだ
「俺は今どうなっているのか」と考えながら読むんだ
無意識にみんなやってると思うぜ
他の何かがどうなってるかではない、自分がどうなってるか
しかし、鏡を見ると、場に合わない容姿・・・
266:デフォルトの名無しさん
08/11/04 00:02:17
int main (void){
int i;
int vx[5];
for(i=0;i<5;i++){
printf("vx[%d]:",i);
scanf("%d", &vx[i]);
}
putchar('\n');
for(i=0;i<5;i++){
printf("vx[%d]=%d\n",i,vx[i]);
}
return (0);
}
上記の配列の要素を読み込んで表示のプログラムを実行したところ
1
2
3
4
5
vx[0]:vx[1]:vx[2]:vx[3]:vx[4]:
vx[0]=1
vx[1]=2
vx[2]=3
vx[3]=4
vx[4]=5
と変な形になってしまい、試行錯誤したところどうやら実行の際に
ファイル名 | more
としていたのが原因のようでした。 moreはその前に書いてたプログラムの際に利用していてそのままでした。
moreは単に一画面ずつ表示するようにするだけなのになぜこのようなことが起きたのでしょうか?
267:受付番号001
08/11/04 00:06:58
>>264
乙! 面白いトレーニングプログラムだねw
わしもSetTimer、KillTimer、WM_TIMERメッセージは、テトリスを作ってみた時に使ったよ。
同じように素のWindows SDKとC言語だけでね。
>>265
大人になれば空気なんて読まなくなる。いや読む必要がなくなるのだ。
その代わり、盤面の様子や流れ、相手のニーズや考えを読むように変化する。
268:デフォルトの名無しさん
08/11/04 00:30:14
自分がmainになるんだよ
mainになって、forなどで値の計算や操作をやっていると考えると
どこがおかしいのか分かりやすい
元々俺がアセンブラ屋だったから
自分に置き換えて「イメージ」する癖がついた
っていうか、みんなイメージしてると思うが!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
269:デフォルトの名無しさん
08/11/04 00:35:49
>>266
printf() の後に fflush(stdout); をおいてみるとどうなりますか?fflush(NULL); ではどうなりますか?
270:デフォルトの名無しさん
08/11/04 00:36:28
>>268
新しい芸ですか?
271:デフォルトの名無しさん
08/11/04 00:36:54
みなさん、Cのソースを組むとき、分かりやすく汎用的に組む為に、具体的にどういうことに気を付けてますか?
たとえば、、、
僕の場合なんですが、
・一行は80文字。
・strcpyよりmemcpy
・独自関数ライブラリのプロトタイプは必ず書く。
・関数の引数が多くなりすぎる時は構造対で渡す。
・関数名はキャメル式に統一。
・入れこは3つ以上にしない。
・繰り返し文は使い分ける。
・構造化プログラミング。mainは目次みたいな感じで、全体が把握でくるような作りに。
・C言語についてのコメントは書かない。
・インクルードヘッダはは使用するものだけ書く。(まとめたりしない)
まだあると思うけど、とりあえずこれくらいかな~
みんなのも教えてください。
272:デフォルトの名無しさん
08/11/04 00:39:26
>>271
> ・strcpyよりmemcpy
状況にもよりますが、これは賛同しかねます。
273:デフォルトの名無しさん
08/11/04 00:45:27
>>272
あ、すいません。
そうですね。\0つけたい時ありますもんね。
strcpy→strncpyに訂正します。
274:デフォルトの名無しさん
08/11/04 00:50:17
>>271
入れ子2つだけじゃ厳しいなぁ
275:デフォルトの名無しさん
08/11/04 00:52:42
memcpy()でコピーしてるのに、コピーの長さをstrlen()で取ってるコードをこのまえ見たな。
strcpy()でいいじゃんって思うけど。
276:デフォルトの名無しさん
08/11/04 00:53:10
>>271
>一行は80文字。
まあほとんどないことですが、意味の上で 80文字を超えるようであれば、それはそれでこだわりません。
>プロトタイプは必ず書く
前方参照をほとんど行わないので、特に必要性を感じません。
>入れこは3つ以上にしない。
それはそうなんですが、まあ、ええ、ときどき、しばしばやってしまいます。
>キャメル式
初耳です。よろしければ意味を教えてください。
277:デフォルトの名無しさん
08/11/04 00:56:34
>・一行は80文字。
これは無い
278:デフォルトの名無しさん
08/11/04 00:57:33
>>276
URLリンク(ja.wikipedia.org)
279:デフォルトの名無しさん
08/11/04 00:59:40
>>277
そういうスタイルの人もいるよ。
Cだと80くらいでも十分書けるし。
280:デフォルトの名無しさん
08/11/04 01:04:14
いや居るのは知ってるよ
281:デフォルトの名無しさん
08/11/04 01:06:24
>>276
動的独自ライブラリから独自関数を使う場合、引数間違っててもコンパイルが通る。んで、実行時にコア吐いて初めて気付く事がある。プロトタイプ書いてると、コンパイルエラーでるから、書くようにしてる。好みかな。
キャメル式は、確か、ラクダみたいな意味だったかな。大文字と小文字だけでつけるやつ。こういうの。
FileCopy()
区切り方の違いかな。変数はアンダーバー使うし、マクロは大文字とか。
282:デフォルトの名無しさん
08/11/04 01:06:58
ああそう。
283:デフォルトの名無しさん
08/11/04 01:08:54
うん
284:デフォルトの名無しさん
08/11/04 01:08:55
>>281
下位のサブルーチンから書いていって、main()を最後に書くってスタイルの人なんじゃないの?
285:デフォルトの名無しさん
08/11/04 01:09:11
コーディング規約のスレがあったような
ここでもいいんですよ、はい
286:デフォルトの名無しさん
08/11/04 01:10:53
>>281
ん、了解。たしかに分割コンパイルですすめるときは .h にプロトタイプをまとめる、というのは日常的にしますね。読みが浅かったです。
>>278 >>281
キャメル式+ハンガリアンでかいてみることもあります。気分しだいですが。
287:デフォルトの名無しさん
08/11/04 01:16:37
>>284
昔はそういう人も居たし俺もそうだった。技巧賞ノミネート作品のように。
でもある時から改めた。
288:デフォルトの名無しさん
08/11/04 01:18:18
>>275は>>273を読んでないのか
289:デフォルトの名無しさん
08/11/04 01:20:25
>>287
技巧賞とあるんだ
ぐぐるわ
290:デフォルトの名無しさん
08/11/04 01:25:01
>>288
別に責めてるわけじゃないから、気にしなくていいよ。
291:デフォルトの名無しさん
08/11/04 01:25:48
>>287
技巧賞っていうか、Pascalの影響も多分にあると思う。
292:デフォルトの名無しさん
08/11/04 01:28:07
>>286 ハンガリアン記法はダメだろ
293:デフォルトの名無しさん
08/11/04 01:30:20
>>287
さしつかえなければ、かえた理由を教えてください。
たしかに私も厳密な意味で下から上にかいているわけではなく、コンパイルOKれべるですので、技巧賞はむりですね。
294:デフォルトの名無しさん
08/11/04 01:32:58
>>292
私のはいわゆる「アプリケーションハンガリアン」ってやつですね。MicroSoft 流 pszXXX とかいうのは私も嫌いで、これはやらないです。
そもそも全部の変数をハンガリアンにするわけではありません。
節操がないといえば、それまでですが。
295:デフォルトの名無しさん
08/11/04 01:36:38
しかしアプリケーションハンガリアンって、あんまり使う機会がないっていうか。
システムハンガリアンはダメだって言われてるけど、Cのときは、ポインタはpをつけてる。
296:デフォルトの名無しさん
08/11/04 01:41:43
>>269
どちらでも実行結果は変わりませんでした。
297:デフォルトの名無しさん
08/11/04 01:52:53
>>296
more の内容をください。more にも fflush(NULL) をいれるとどうなりますか?
298:デフォルトの名無しさん
08/11/04 01:58:06
fflush(stdout); を入れるのは一つ目のprintfですよね?
C:\081103>1 |more fflush(NULL)
ファイル C:\081103\fflush(NULL) にアクセスできません
1
2
3
4
5
となりました。
299:デフォルトの名無しさん
08/11/04 02:10:06
>>298
いえいえ、more も自作しているのかな、と思って、 fflush() で more のバッファリングも殺してしまおうと思ったわけで、
コマンドラインで fflush を指定するつもりはありませんでした。
more が標準出力をバッファリングしており、自作のプログラムの出力をその都度画面に出力していないのでは?と思いますが、いかがでしょう。
300:デフォルトの名無しさん
08/11/04 02:14:20
ごめんなさい、何言ってるか分かりません・・・
自分の不勉強のようなので出直してきます。
301:デフォルトの名無しさん
08/11/04 02:19:23
>>300
いえいえ、そんなつもりはないです。
バッファリングについてかいておきますね。
printf() で出力した時点で、それが画面にそのままでるわけではなくて、いったん別のところにたくわえられており、
ある程度たまった時点で画面に出力される、という仕組みになっているのが普通です。
たとえば、これは画面ではなくてディスクなんですが、printf()などで一文字ずつ書き込む、なんてディスクがカリカリいって
(ハードウェアの操作には時間がかかることは直感的に感じていただけるものと思います。)なんだか非効率だと思いませんか?
なにかわからないことがあれば遠慮なくきいていただいていいと思いますよ。レスポンスがあるかどうかは運まかせかもしれませんが。
302:デフォルトの名無しさん
08/11/04 03:00:02
strncpyは仕様が腐ってるので使うのやめとき。
303:デフォルトの名無しさん
08/11/04 03:08:05
どう腐ってるの?
304:デフォルトの名無しさん
08/11/04 03:09:44
終端文字列の扱いのこといってんだろう多分
305:デフォルトの名無しさん
08/11/04 09:28:37
strncpy()を使うくらいなら、spritf()を使いこなすか、いっそ自前で管理した方がいい希ガス。
306:デフォルトの名無しさん
08/11/04 13:08:21
つ strncat()
307:デフォルトの名無しさん
08/11/04 16:12:50
spritf
308:デフォルトの名無しさん
08/11/04 16:32:53
>305s/spritf/sprintf/
309:デフォルトの名無しさん
08/11/04 18:24:34
int i,j,k,count;
printf("何段?");
scanf("%d",&count);
for(i = 1;i <= count;i++){
for(j = 1;j <= count-i;j++){
putchar(' ');
}
for(k = 1;k <= i;k++);{
printf("*");
}
putchar('\n');
}
上記のプログラムで右下が直角の三角形が表示されるつもりなのですが
何段?5
----*
---*
--*
-*
*
となってしまいました(半角スペースを-としました)。kがうまくいってないような気がするのですが、ご指摘お願いします。
310:デフォルトの名無しさん
08/11/04 18:35:29
>for(k = 1;k <= i;k++);{
この行に注目。
311:デフォルトの名無しさん
08/11/04 18:44:17
>>310
printf("* %d",k);にしたところ
----*2
---* 3
--* 4
-* 5
* 6
となりました・・・なぜ毎回k=1にならないんだ。
312:デフォルトの名無しさん
08/11/04 18:45:47
>>311
>310
他は見なくていい。
313:デフォルトの名無しさん
08/11/04 18:47:45
>>312
注目したのですがとくにおかしくないような・・・
i回の繰り返し文のはずです。
314:デフォルトの名無しさん
08/11/04 18:53:12
やっと気付きました。 for(k = 1;k <= i;k++);←ここですね{
くだらない質問で失礼致しました。ご指摘ありがとうございました。
315:デフォルトの名無しさん
08/11/05 01:32:51
int k,i,j,n;
printf("何段?");
scanf("%d",&n);
for(k=0;k<=n;k++){
for(i=0;i<(n-k);i++){
printf(" ");
}
for(j=0;j<k;j++){
printf("*");
}
printf("\n");
}
布団入ってから作ったから動くかどうかわからん。
316:デフォルトの名無しさん
08/11/05 01:42:04
do{
if(){
break;
}
if(){
break;
}
}while(0)
時々みるこれどうなのよ?テクッてて見易いとかいうやつは程がしれてるな
317:デフォルトの名無しさん
08/11/05 01:53:25
>>316
while (1) {if()break; if() break;}
とか
for(;;) {if () break; if () break; }
はよくみます。lint にひっかからないように for(;;) {} を使う、ていう意見も。
ループの脱出条件が2つ以上ある、というのであれば、これらのやり方もありだと思います。
318:デフォルトの名無しさん
08/11/05 02:18:01
>>317
論点がずれてる
319:デフォルトの名無しさん
08/11/05 02:22:47
大文字と小文字を区別しないコンパイラはありませんか?
320:デフォルトの名無しさん
08/11/05 02:24:46
そこまで大胆に規格を逸脱した実装は見たことないな。
せいぜいDOS/Windowsでヘッダ名が大文字でも行けるくらいしか知らない。
321:デフォルトの名無しさん
08/11/05 02:39:26
>316
どうなのよってお前の感想どおりだ
322:デフォルトの名無しさん
08/11/05 03:13:09
>>316
別にテクッてるとは思わないがいいんじゃないの
323:デフォルトの名無しさん
08/11/05 08:06:33
>>316
その書き方は嫌いだが goto 禁止なら仕方ないな
324:デフォルトの名無しさん
08/11/05 10:25:39
int main(){
(略)
printf("test\n");
関数(Dname);
}
void 関数(char *fname){
printf("2\n");
}
というプログラムがあったときに、testが表示されて
2が表示されずにセグメンテーションエラーでるのはどこに原因があると考えられますか?
325:デフォルトの名無しさん
08/11/05 10:27:13
略されたところに魔物が棲んでいると考えられます
326:デフォルトの名無しさん
08/11/05 10:58:22
324ですけど解決しました
関数の中の定義した配列のサイズがおおきすぎたためでした。
327:デフォルトの名無しさん
08/11/05 11:33:44
>>316
美しくないとは思ってたんだがそれに近い書き方だ
0じゃなくて条件1個だけど
どう書くべきなの?
条件をいっぱい書くとして抜けるタイミングが異なる場合はどうしたらいい?
328:デフォルトの名無しさん
08/11/05 11:37:59
>>316
初心者なのでよくわからないのですが
これはif ・・・・・ else if ・・・
じゃだめなんですか?
329:デフォルトの名無しさん
08/11/05 11:39:58
>>328
それで組んでもさほど代わらないと思うよ。
むしろネストが増えるし
330:デフォルトの名無しさん
08/11/05 12:04:32
qsortでIPアドレスをキーにソートしたいんですが、うまくいきません。
IPアドレスとchar型の文字列を要素に持つ構造体のソートをしたいのですが
比較関数内にprintfを置いてみると、どうやら比較関数を数回参照しただけで
デバッガが立ち上がってしまいます。
IPアドレスはCSVから読み込んでいますが、5MB程度のCSVなら問題なく読み込み、ソートまでできます。
全く同じフォーマットの150MBのCSVからIPアドレスを全て読み込んでソートしようとするとデバッガが立ち上がります。
比較関数内の数箇所にprintfを置いてみたところ、比較関数の先頭と最後のprintfはセットで表示されるので、
比較関数内ではデバッガは出ていません。
どうやら割り当てされていないメモリ領域を参照しているみたいなんですけど、qsortをする際に変な領域を参照することとかあるのでしょうか。
331:デフォルトの名無しさん
08/11/05 12:08:08
・複数プラットフォームで運用するものでない
・仮に複数プラットフォームがあるとしても、ウチは個別にソースを用意する
・社風なのか、ソースの流用は好まない
なのに、「typedefで調べろよ!んったく何やってんだよもー」
とかグチグチ言い出す不満の塊
お前ストレス解消するために会社来てんのか
332:デフォルトの名無しさん
08/11/05 12:55:18
>>330
デバッガってのはデバッグするためのツールなんだけどね・・・
まぁたぶんスタックが足りないんだろう。どーんと増やしてみては?
333:デフォルトの名無しさん
08/11/05 13:05:48
>>327
ループ条件が存在するならループで書いたって問題ないだろ
334:デフォルトの名無しさん
08/11/05 14:34:11
while(条件式)
if(){
continue;
}
if(){
}
}
1個目のifでcontinueした場合2個目のifはとばされて、whileの頭にもどりますよね?
335:デフォルトの名無しさん
08/11/05 14:46:20
やってみれ
336:デフォルトの名無しさん
08/11/05 14:47:34
なんでその程度の規模のプログラムで聞くかね・・・
さくっとサンプル作って、どういう動きするか
テストしてみればいいじゃん。
337:デフォルトの名無しさん
08/11/05 15:02:59
それがゆとり
338:デフォルトの名無しさん
08/11/05 15:18:58
何度も言うけど、Cは動作の詳細を網羅しない言語だから「やってみろ」はダメ
i=i++とか、やってみてその結果が正しいと思い込んだらどうすんの?
こういうのに素直に答える気がないなら「教科書読み直せ」でいいんだよ
>>334
そうだよ
339:デフォルトの名無しさん
08/11/05 15:22:50
どうもしねーよゆとり
340:デフォルトの名無しさん
08/11/05 15:25:46
>>338
ここで散々論争になってきたようなところは
はまったときに聞けばいいんだよ。
どうせはまるところはそういうところって大体結論でてるんだし。
341:デフォルトの名無しさん
08/11/05 16:21:34
>>340
いつどこでそんな結論が出たの?
むしろ最初から正しい知識を与えないからそういうところではまるんじゃないの
問題にしているのは「やってみて確かめる」という姿勢はトラブルの種を抱えているということで
後になってトラブルが起きてから解決できるかどうかではない
342:デフォルトの名無しさん
08/11/05 17:57:50
>>341
それを言うなら、動作保証の有無を 2ch で聞く姿勢にこそ問題があるだろう
正しい知識だ? そもそもそんなのを与える義理がない者をつかまえて何を説くやら
343:デフォルトの名無しさん
08/11/05 18:57:39
質問です。
プログラムの練習で数のべき乗を計算するプログラムをCで作ってみたのですが、ちゃんと計算してくれません。
出来れば、どこが間違っているか教えていただけないでしょうか?
コードは下記のとおりです。
#include <stdio.h>
double multi(double x,int y);
int main(void){
double a,b,mul;
printf("数字aを入力してください\n");
scanf("%d",&a);
printf("aを何乗するか入力してください\n");
scanf("%d",&b);
mul = multi(a,b);
printf("%d",mul);
return 0;
}
double multi(double x,int y)
{
int i;
double mu;
for(i=1;i<=y;i=i+1)
{
mu*=x ;
}
return mu;
}
344:デフォルトの名無しさん
08/11/05 19:01:12
>>343
scanf("%d",&a); → scanf("%lf",&a);
scanf("%d",&b); → scanf("%lf",&b);
printf("%d",mul); → printf("%f",mul);
double mu; → double mu=1;
345:343
08/11/05 19:10:21
>>344
ありがとうございました。
桶下で、ちゃんと動作するようになりました。
346:343
08/11/05 19:11:26
桶下→おかげ
です。
失礼しました・・・・・
347:デフォルトの名無しさん
08/11/05 19:41:50
%fより%gを使おう。
348:デフォルトの名無しさん
08/11/05 19:45:36
なんかちがうんでげすか?
349:デフォルトの名無しさん
08/11/05 19:55:55
if ( (a=Func()) == 8 )
aにFuncの返り値を代入しつつ比較ってできる?
350:デフォルトの名無しさん
08/11/05 19:58:11
できる
351:デフォルトの名無しさん
08/11/05 20:00:22
>>349
やってみてうまくいかないのか?
352:デフォルトの名無しさん
08/11/05 20:19:04
入門以前に、環境について質問なのですが、Microsoft Visual C++.net ExpressとBCC5.5では、どちらが使い易いですか?
353:デフォルトの名無しさん
08/11/05 20:26:03
どう考えても前者
354:デフォルトの名無しさん
08/11/05 20:29:21
IDEとコンパイラ単体では比較にすらならん
355:デフォルトの名無しさん
08/11/05 20:29:30
>>351
うまくいったが、その動作が保証されてるかどうかを気にしてるんじゃないの?
356:デフォルトの名無しさん
08/11/05 20:43:12
>>342
なぜ問題が?
ネットの情報の信用性云々言い出すならそもそもこんなスレの存在意義自体がない
あと正しい知識を与えろと言ってるのではない
答えたくないなら「やってみろ」ではなく「教科書読め」と返せと言ってるだけ
357:デフォルトの名無しさん
08/11/05 20:47:50
どう答えるかはその人の勝手で、お前がグダグダ言おうとかわらんけどな。
まあ、好きなだけ言っててくれw
358:デフォルトの名無しさん
08/11/05 20:52:58
>>355
推測なんざ聞きたかねえ
すっこんでろ
>>356
教科書じゃねえ、保証者(メーカなり規格なり)が発行する資料で確認することだろうが
だいたい回答者サマがそんなこともわかってないような 2ch で聞くことに問題がないとでも言うのか
359:デフォルトの名無しさん
08/11/05 21:00:47
>>358
教科書を文字通りに取られたか
そこはそういったものに読み替えてくれればいいよ
で、2chで質問することを問題視する君はなんでこのスレにいるわけ?
帰れば?むしろ帰ってくれない?邪魔だから
360:デフォルトの名無しさん
08/11/05 21:02:18
いつものageのバカじゃないか
相手しても無駄っていうかお前も邪魔だからやめろ
361:デフォルトの名無しさん
08/11/05 21:07:35
要するにこのスレを潰したいから荒らしてるんだろ?
362:デフォルトの名無しさん
08/11/05 21:12:26
>>359
いーや、おまえは教科書と言った
それからあんたには邪魔かも知れないが
俺はスレタイどおり参加しているだけで荒らしているわけでもない(スレは荒れているかも知れないがな)
難癖つけられる筋合いはないので勝手にするぜ
おまえこそ正義があるなら運営にでも訴えてはどうだ、あ?
363:デフォルトの名無しさん
08/11/05 21:16:37
printf("%d %d %d", ++i, ++i, ++i);
364:355
08/11/05 21:53:55
>>358
すっこまねえよ。
要はお前が規格に沿った回答、または引用をすることができないから、
2chで質問することに意味がないと思いこんでるだけだろ?
お前が「やってみた?どうだった?」とかアホ面ひっさげたレスをしなければ
規格に沿った回答の密度があがるんだよ。
すっこんでろ。
365:デフォルトの名無しさん
08/11/05 22:04:15
>>364
>>351 をどう読めばそうなるのかは知らんし興味もないが
推測なんざ聞きたかねえ、と言ったはずだ
だからその部分に対しては答えない
すっこまねえのは確かにあんたの勝手だが
それはこちらにも言えることだ
同じ言葉を返しさえすれば痛烈だとでも思っていて自己矛盾に気づかないなら小学生なみだぜ
366:デフォルトの名無しさん
08/11/05 22:05:21
>>365
だからすっけんどろっての
367:デフォルトの名無しさん
08/11/05 22:08:21
>>366
うっせえ ぼけ
368:デフォルトの名無しさん
08/11/05 22:18:24
まだすっこんでないよな?
Cの教科書っていったらK&Rで異論ないと思うんだが、
それで何の問題があるんだ?
369:デフォルトの名無しさん
08/11/05 22:23:38
>>368
甘いんだよ、後出し設定なんか聞いてやらん
370:デフォルトの名無しさん
08/11/05 22:40:38
>>369
お前教科書って聞いて何思い浮かべたの?
371:368
08/11/05 22:42:33
後出しも何も俺>>356じゃねえよ?
寒くなってきたんだから布団にすっこんでぽかぽかになっとけよ
372:デフォルトの名無しさん
08/11/05 22:45:49
で、別人のふりくらいしかすることなくなったわけか
373:デフォルトの名無しさん
08/11/05 22:48:16
このスレには極端にレベルの低い小学生が二人いるのかな
374:デフォルトの名無しさん
08/11/05 22:49:49
よそでやれ
375:デフォルトの名無しさん
08/11/05 22:58:36
次の方どうぞ~♪
376:デフォルトの名無しさん
08/11/05 23:53:51
>>316
それ好きな人が身近にいる。else ifだとデコボコになるからこれが好きとのこだ。
そいつは、構造対のメンバ名が長い時も、最初にそのメンバのアドレスを短くて意味のわかるポインタに移す。
最初は何でいちいちそんな事すんだよとか思ってたが、正直、そいつのソースは読みやすい。
好みだな
377:デフォルトの名無しさん
08/11/05 23:59:17
確かに、構造体ん中に構造体ある時とか、長くなるね。
378:デフォルトの名無しさん
08/11/05 23:59:33
複数ソースファイルがあるとき
ソースファイルその絡みがあるじゃないですか
例えばその値がどこから来たかを見つけたいとき
どうやればいいのですか。
1.c
から
10000000000000.c
くらいまであるとして
そのうちの23460001.cにある関数から
5986293.cに渡されたとしたら
わからないじゃ
ないですか
5986293.cのincludeには782365.cと23435.cしかない
というように、「渡りに渡って行き着いた」やつは非常に見つけにくい。
379:デフォルトの名無しさん
08/11/06 00:01:30
>>378
それは設計が悪くないか?
380:デフォルトの名無しさん
08/11/06 00:01:38
__FILE__
381:デフォルトの名無しさん
08/11/06 00:01:42
ゲームに限らず、携帯電話やATMなど
「仕事」のソースは例外なく大量のファイルに分かれているのに
「この値はどこから来たのか」
「それをはじき出すものはどこにあるのか」
っていうコメントがないことがほとんどです!!!!!!!!!!!!!!!!!!!!!!!!!!
382:デフォルトの名無しさん
08/11/06 00:04:02
>>378
Java見たら泣くよ
383:デフォルトの名無しさん
08/11/06 00:04:39
今時デバッガ使えば、その時点でどの関数がどの関数を呼び出しているかなんてすぐ分かる。
それとは別に、プログラムを実行させなくても静的に解析するツールだってちらほら存在する。
384:デフォルトの名無しさん
08/11/06 00:06:47
研修期間中に読んだものの中で最長の渡りが
30ファイル先
まず先に値を出す1.c -> それを利用する2.c -> 2.cで出た値を利用する3.c .................................................
30.cだけ見ると、「この値はどこから来たの」ってことしか分からず、
includeを見て追っていくと何十も何百も元のファイルから来てたとわかるのみです。
しかもそのincludeも、標準ライブラリ除いて20くらいincludeされていることもザラで
それら全部調べるとなるとたいへんな時間がかかります!!!!!!!!!!!
今仕事でバリバリやってる人らはどうやって調べているの
と
385:デフォルトの名無しさん
08/11/06 00:07:21
>>378
1.関数呼び出しの構造図を書く
func_a
func_b
func_c
func_d
2.データフローを書く
func_a - x ->func_b
386:デフォルトの名無しさん
08/11/06 00:08:38
関数呼ぶ→さらに中で関数呼ぶ→さらに中で関数呼ぶ→さらに中で関数呼ぶ→さらに中で関数呼ぶ・・・・
きつい時あるね
387:デフォルトの名無しさん
08/11/06 00:09:43
>>386
でも昔のDOSのころのようなミニマムな開発じゃなければ
そういうのはざらでしょ。
388:デフォルトの名無しさん
08/11/06 00:10:14
保守って点から見りゃ、およそ最悪だろ。
389:デフォルトの名無しさん
08/11/06 00:14:51
>>386
みたいなのをどうしても調べにゃならん時に、たどり着いたソースが新規1985年だったのがある。俺産まれた年(笑)
昔の人は英語好きだよね~JISに対応してなかったのかね~
390:デフォルトの名無しさん
08/11/06 00:18:22
>>389
時代的にはこんな感じだよ。
マシンによるんじゃないかな?
URLリンク(www.eonet.ne.jp)
391:デフォルトの名無しさん
08/11/06 00:22:45
とりあえずincludeで追いかけるってのはありえない
ライブラリならドキュメントがあるはずだし
ソースがあるならgrepかければ済む
392:デフォルトの名無しさん
08/11/06 00:32:05
for(;;)
{
int d = 0;
(dを用いた適当な処理)
}
と
int d;
for(;;)
{
d = 0;
(dを用いた適当な処理)
}
を比べると上のほうがオーバヘッドが大きいでしょうか?
dはfor文内でしか利用しませんのでスコープを限定したいのですが.
393:デフォルトの名無しさん
08/11/06 00:32:14
以前、関数から参照する外部変数や値の影響についてなどを関数仕様書に書いた。
すると技術の若造が「そういう事は止めてくれ。」と言われた。
「どうして?」の問いに、「そんな事を書いたら分かっちゃうだろ。」の回答。
C言語好きでNE○の系列会社に入社する奴はヲタクなお山の大将が多かった。
394:デフォルトの名無しさん
08/11/06 00:34:30
>>393
ドキュメントとソースの乖離が発生することを懸念して、じゃなくて、分かっちゃうからってところがwww
395:デフォルトの名無しさん
08/11/06 00:35:35
>>393
日本語でおk
396:デフォルトの名無しさん
08/11/06 00:38:36
>>392
{
int d;
for(;;)
{
d = 0;
(dを用いた適当な処理)
}
}
とかは?
これってgccしかできなかったっけ?
>>393-394
意味がわからねえw
397:デフォルトの名無しさん
08/11/06 00:40:28
メーカー製の場合、見えてはいけないものが多い。
特に地上デジタル放送関連は、結局はドライバで制御している以上、
「バレるとB-CASなしでも見られてコピーし放題」って芸当も出来るようになる。
398:デフォルトの名無しさん
08/11/06 00:50:07
コメントなしね~HTMLならしかたないとこあるけどね~
399:デフォルトの名無しさん
08/11/06 00:52:21
>>397
外に見せる?資料と内部では違うだろ・・
内部のものまで「書かない」が徹底されてるのか?
400:デフォルトの名無しさん
08/11/06 00:56:22
>396
VC6なんで出来るけどステートメントが深くなるからあんまりやりたくないです.
それよりfor文の中に入れたときに何度もdが宣言されるけどそのときのオーバヘッドが気になります.
401:デフォルトの名無しさん
08/11/06 00:57:17
>>393 ソフトさんですか。
402:デフォルトの名無しさん
08/11/06 00:59:12
オーバーヘッド気になるなら実測なりアセンブリ見るなりすればいいだろ。
403:デフォルトの名無しさん
08/11/06 00:59:44
for(ここにおけば?;;)
vc6だとグローバルスコープだったような気がするけど
でもそれはc++だったような期もするけど
404:デフォルトの名無しさん
08/11/06 01:03:51
>>400
宣言文は実行ステートメントではないから、
実行時のオーバヘッドにはならないだろ。
405:デフォルトの名無しさん
08/11/06 01:06:48
____
.ni 7 /ノ ヽ\ 内部にも見せないよ
l^l | | l ,/) / /゚ヽ /゚ヾ\ .n 以前、それで営業がポカやらかしたし
', U ! レ' / / ⌒ ⌒ \ l^l.| | /) 絶対に流出させられないから
/ 〈 | (____人__) | | U レ'//)
ヽ\ |lr┬-l| / ノ /
/´ ̄ ̄ノ ゙=ニ二" \rニ |
`ヽ l
406:デフォルトの名無しさん
08/11/06 01:41:40
B-CAS廃止されたんじゃなかったか?
407:デフォルトの名無しさん
08/11/06 01:48:54
まだよ
408:デフォルトの名無しさん
08/11/06 01:51:04
>>401
妙に納得した。
>>392
そのケースなら、コンパイラはどちらも同じようにコンパイルしてしまう。
スコープを限定してくれた方が読むにも判り易いからどんどん限定してくれたまえ。
# それこそ某N∈Sみたいな所の仕事だと全て関数の先頭で宣言しろとか言われかねないけど。
409:393
08/11/06 02:10:15
>>397
そういうカッコいい理由ならまだいいんだがw
NE○の通信系には変な田舎者の高専や専卒出身の奴が多いのは確かだよ。
カモフラージュ気取りのアメージングコード、騙しの#includeなどは当たり前。
例えば、ANSIの定数をコソーリとトリッキーなビットシフトで何重にも再定義してたりで
デバッガで動かすと、EOFが5に見えたりするんだが、奴らはその自分達の技術に対する
他人の反応を見て楽しんでたんだよ。(家で人知れず独りでオナニーしてろってwww)
>>401
昔はT芝相手で設計部門向けのCADなどのソフトもやってましたよ。その他にも監査に
似た評価・検証系もしてたので、よく使うコンパイラ数本のC標準ライブラリのヘッダやソースまで
ほぼ暗記してました。
410:デフォルトの名無しさん
08/11/06 09:12:19
>>352
遅レスだけど、エラーの指摘はTURBO C1.0対MS-C3.0の頃からborlandの方が出来が良い。
使いやすさじゃ勝負にならないけど、学習用途なら色々動かして、気に入った物を使うといいよ。
411:デフォルトの名無しさん
08/11/06 09:12:56
悪いがマ板でやってくれ
412:デフォルトの名無しさん
08/11/06 15:14:28
>>378
やっぱ一回実行して呼び出しスタック覗くのが一番早い気が。
gdbにもあったはずなんで、大抵の環境で可能だと思う。
413:デフォルトの名無しさん
08/11/06 17:19:50
fnameに/home/usr01/c_nara_orenikike/1th/2th/3th/4th/5th/6th/7th/8th/3.data
とかはいってたとして、次のファイル操作
printf("%s",fname);
if((fp = fopen(fname, "rb")) == NULL ) {
fprintf(stderr,"ERR;入力ファイル error;read_inputfile\n");
exit(EXIT_FAILURE);
}
これをかいて実行すると開けないってエラーがでるんですけども。なぜだと
考えられますか?ちなみに、emacsから/home/usr01/c_nara_orenikike/1th/2th/3th/4th/5th/6th/7th/8th/3.data
だと開けます。開けるからわからないんですけど。ファイルネームにラストに改行はいってるみたいで。
ただそれでエラーがくるのかと。3.dataはバイナリのデータです。
414:デフォルトの名無しさん
08/11/06 17:26:44
改行入ってたら、実際のファイルの名前にも改行入ってないと開けないぞ
415:デフォルトの名無しさん
08/11/06 18:13:23
>ただそれでエラーがくるのかと
ファイルを指す文字列をどう解決するかは当然OSに依存する
あいにく君の使っている環境は、末尾の\nを排除してファイルを探すことができなかった
それだけのことであって、そもそもCの話ではない
416:デフォルトの名無しさん
08/11/06 18:14:42
C言語を志すならばやはりK&Rは買わないとダメでしょうか?
417:デフォルトの名無しさん
08/11/06 18:17:30
別になくても困りはしないよ
418:デフォルトの名無しさん
08/11/06 18:19:39
もちろんあったほうがいいけど必須ではないよ
CFAQを読んだ上で、規格合致ギリギリのラインを攻め込んだりしない限り問題ないと俺は思う
419:デフォルトの名無しさん
08/11/06 18:20:37
>>416
K&R自体は買わなくても他に手はいくらでもあるが
たかが3千円弱の自己投資をためらうようならお先真っ暗だ
420:デフォルトの名無しさん
08/11/06 18:22:34
買ったけど内容は入門書と変わらない
正直要らないよ
421:デフォルトの名無しさん
08/11/06 18:24:44
K&Rってのは、C言語をマスターしている人間が買う入門書。
マスターしてるなら買うわけないじゃん、と思うだろうが
まさにその通り。
あの本は、読んでる人間はC言語を完全にマスターしてること前提で書いている。
辞書で言うならこんな感じだな
レバレッジ
株用語のひとつ。
リスクヘッジ
リスクをヘッジすること。
ってな
422:デフォルトの名無しさん
08/11/06 18:56:30
>>416
優れた医者は毒を薬とするという例えがあるようにその本を毒とするか薬とするかは自分次第
他人の評価を聞いて悩むより本屋でちょっと覗いてみて興味を持ったら買うのが一番
図書館で借りたって良いんだしさ
百聞は一見に如かずだよ
423:デフォルトの名無しさん
08/11/06 19:50:09
>>416
そうそう、積読の価値はあると思います。いつか、ふとしたときに手にとって、おもわず読みふけってしまう、ということがあると思います。
424:デフォルトの名無しさん
08/11/06 21:41:57
>>421
そんなことはない。
Prefaceに書いてあるとおり、他の言語は知ってるけど、C言語は
知らないって人向け
Cの文法は知ってるけど、書き方を知らないような人にも向いてると思う
425:デフォルトの名無しさん
08/11/06 21:44:04
でも本に書いてあるものは全部よい書き方だと思っちゃうようなひとには向いていない
426:デフォルトの名無しさん
08/11/06 22:04:00
「よい書き方」について論じている本ではないことくらいわかれ・・・・無理なのか?
427:デフォルトの名無しさん
08/11/06 23:00:10
趣味でプログラムを覚えようと思うのですが、最初はC言語でいいんですよね?
おすすめの入門書、サイトがありましたら教えて下さい。
428:デフォルトの名無しさん
08/11/06 23:04:30
>>427
いきなりCだなんて。えっち。
それはともかく、おすすめしない。
429:デフォルトの名無しさん
08/11/06 23:12:41
time_t tp;
time(&tp);
sprintf(buf,sizeof(buf),"%Y%m%d",localtime(&tp));
↑こんな感じのを
sprintf(buf,sizeof(buf),"%Y%m%d",localtime(time(&tp));
↑こんな感じで一行で書きたいんだけど。
もちろん、この書き方が駄目なのは分かるんだけど。
関数の戻り値のアドレスを渡したいんだよねー
430:デフォルトの名無しさん
08/11/06 23:13:07
はじめてのC
431:デフォルトの名無しさん
08/11/06 23:14:31
>>429 上のもダメですが
432:デフォルトの名無しさん
08/11/06 23:16:55
>>429
なんでこだわるの?
433:デフォルトの名無しさん
08/11/06 23:18:29
つーか、それstrftime()の間違いだろ。
434:デフォルトの名無しさん
08/11/06 23:51:25
>>427
C言語に興味があるのならC言語にすればよい。
入門書は、本屋に置いてあるのでいいと思うよ。
例えば、ポニョのとかLepton先生のとかカニハンのおっちゃんのとか。
ああ、でも『はじめての~』は買わない方がいいと思う。
厨房のとき読んでコードギアスの2ndOPになった。
あまり評価高くないけど、河西本とかもオヌヌメ。もう記述が古いけど厨房でも理解できた。
ウェブサイトは、使わない方がいいよ。コピー&ペーストで終わらせようとする衝動に負けるだろうから。
手で打って覚えるんだよ。目でコードの美しさに感動するんだよ。体でプログラミングの楽しさを感じるんだよ。
本気でC言語を使って思い通りにプログラミングできるようになりたければ、
他人の評価は気にせずに自分の直観を信じて本を読んでいった方がいいよ。
そのレビューをした人と自分の言語理解度が必ずしも同じであるわけではないのだから。
1冊読んでいい気になるなよ、そこの自称中級者。
うわっキモ。米大統領選:オバマ氏、共和党地盤・インディアナ州奪取 まで読んだ。
435:デフォルトの名無しさん
08/11/07 00:15:14
猫Cのこのページ
URLリンク(www.kumei.ne.jp)
のPGMをコーディングして実行したんだけど
結果が
「time1=1225984391 time2=0」となってしまう。
printf ("time2=%ld\n",t2)
と単独で出力すればちゃんと「time2=1225984392」になる。
何が間違ってるんでしょうか
436:デフォルトの名無しさん
08/11/07 00:16:03
実行環境はMicrosoft Visual C++ 2008 Express Editionの
Win32 コンソールアプリケーションです
437:デフォルトの名無しさん
08/11/07 01:35:33
TCP/IPのソケットを使って互いに通信するプログラムを作りたいのですが、正直さっぱりわかりません
どこか詳しい説明とサンプルプログラムがあるサイトはないでしょうか?
438:デフォルトの名無しさん
08/11/07 01:38:07
ほれ
URLリンク(x68000.q-e-d.net)
439:デフォルトの名無しさん
08/11/07 02:21:40
>>435
%ld に対応するのは long 型であって、time_t 型ではありません。
long 型と time_t 型のサイズが等しい環境では上手くいくかもしれませんが、
あらゆる環境で常にそれが成立するわけではありません。
440:デフォルトの名無しさん
08/11/07 02:57:52
ネコなんかで勉強しようなんてするから嵌まるんだ。
long(t1)とでもすれば"%ld"で出力されるだろ。
441:デフォルトの名無しさん
08/11/07 09:14:22
>>440
やってみたけどダメです。。。
じっさい、t1のほうは「%ld」でちゃんと出力されてるんですが。
ブレイクポイント設定して見てみるとちゃんと変数の中身は変わってます。
なのに「"\ntime1=%ld time2=%ld\n"」で標準出力するとtime2=0 になっちゃう
442:デフォルトの名無しさん
08/11/07 09:41:07
>>441
64bit環境?
%ld のかわりに、%I64d でやるとどうなる?
443:デフォルトの名無しさん
08/11/07 09:54:50
って環境は>>436か
time_tは
typedef __int64 __time64_t; /* 64-bit time value */
typedef __time64_t time_t; /* time value */
だから64bit整数だな。%I64dか%lldで。
444:デフォルトの名無しさん
08/11/07 09:57:58
つーか、longが64bitじゃないんだから、>>440でいいはずだな。
>>441はなにをやってみたんだ?
printf("\ntime1=%ld time2=%ld\n", long(t1), long(t2));だぞ?
445:デフォルトの名無しさん
08/11/07 10:07:02
>>444
その通りやってみたんですがダメですね・・・
printf ("time2=%ld\n",t2)
だと正常に出力されるので%ldの型指定に問題があるとは思えないのです。
なんで0が出力されるのか、全く見当が付きません・・・