【ISO/ANSI/JIS】 C言語なら俺に聞け! Part 132at TECH
【ISO/ANSI/JIS】 C言語なら俺に聞け! Part 132 - 暇つぶし2ch2:デフォルトの名無しさん
07/09/20 13:23:05
【質問者の絶対心得】
このスレは初心者スレではありません。Cの手練れが悩んで悩んでわからない事を
質問するスレです。スレのレベルに合わない低レベル質問は禁止です。
質問する前に先ず自分で最低1週間はいろいろ調べましょう。
K&Rに書かれているような事は質問しないこと

3:デフォルトの名無しさん
07/09/20 15:13:48
>ビットシフトはなんの役に立つのでしょうか でググれ
もうこのスレが出て来る
ぐーぐるさんはえーマジはえー

4:デフォルトの名無しさん
07/09/20 22:42:27
CHAR_BIT が 16 の処理系で fputc( 1000, fp ) で書き込んだファイルを
CHAR_BIT が 8 の処理系で fgetc( fp ) を読んだら何が返ってきますか?


5:デフォルトの名無しさん
07/09/20 22:51:13
整数の加算や積算の結果オーバーフローしたか(あるいはするか)
判定するにはどういう方法があるんでしょうか

インラインアセンブラ使うならオーバフローフラグ調べて終了なんですが、
C言語レベルでの検知方法を知りたいです

6:デフォルトの名無しさん
07/09/20 22:57:16
標準ではありません。
でもDSP系のコンパイラなら書けます。
もっとも専用に拡張されているのかも知れませんが。


7:デフォルトの名無しさん
07/09/20 22:57:34
演算結果が演算前より小さくなっていたら、オーバーフローとか。

8:デフォルトの名無しさん
07/09/20 23:31:24
同一機種用の処理系で、それぞれCHAR_BITが異なるという例はないと思う。
だから、わからない。

ケースバイケースともいえる。

9:デフォルトの名無しさん
07/09/20 23:42:32
int a, b;
if ((long long)a + b > INT_MAX) printf("overflow");

10:デフォルトの名無しさん
07/09/21 00:44:06
>>9
a, b が負数のときはどうなんです?

11:デフォルトの名無しさん
07/09/21 00:46:26
(long long)a + b < INT_MIN

12:デフォルトの名無しさん
07/09/21 05:37:53
>>5
符号なしではオーバーフローは決して起きないので
(ラップアラウンドするのは仕様)検出できません。
符号ありでオーバーフローが起きた場合の動作は未定義なので、
処理系依存の検出方法が存在するかもしれませんが
一般にはやはり不可能です。

13:デフォルトの名無しさん
07/09/21 09:37:08
void MergeSort(int x[ ], int left, int right);
void main(void);

void MergeSort(int x[ ], int left, int right)
{
int mid, i, j, k;
if (left >= right) /* 配列の要素がひとつなら */
return; /* 何もしないで戻る */
mid = (left + right) / 2; /* 中央の値より */
MergeSort(x, left, mid); /* 左を再帰呼び出し */
MergeSort(x, mid + 1, right); /* 右を再帰呼び出し */

for (i = left; i <= mid; i++)
temp[i] = x[i];

for (i = mid + 1, j = right; i <= right; i++, j--)
temp[i] = x[j];

i = left; /* i とj は作業領域のデーターを */
j = right; /* k は配列の要素を指している */

for (k = left; k <= right; k++) /* 小さい方から配列に戻す */
if (temp[i] <= temp[j]) /* ここでソートされる */
x[k] = temp[i++];
else
x[k] = temp[j--];
}

こういうマージソートって後ろからマージしていく感じでしょうか?
あと、グローバル変数を使わずにポインタで領域確保していったほうが
いいでしょうか?

14:デフォルトの名無しさん
07/09/21 11:46:20
UINT_MAX が 2 の累乗 - 1 以外の処理系は ISO/IEC 9899:1990 に適合しているといえるでしょうか?
たとえば UINT_MAX が 99999 の処理系があっても問題ないでしょうか?
最低値が 65535 という記述は見つけたのですが。

15:デフォルトの名無しさん
07/09/21 13:15:28
>13
「後ろからマージしていく感じ」ってなんだ、もっと厳密に話せ
でないと「お前がそう感じるならそうなんだろう」としか言えん

ソートできる配列の大きさに制限をかけたくないなら
必要に応じてallocするしかない

16:デフォルトの名無しさん
07/09/21 13:20:03
前と後ろの両端からマージしてく
左右どちらかの配列が終わったときの処理を別に書かなくていい分、短くかけることが利点

17:13
07/09/21 14:20:02
>>15
まだわかってないのでイメージでしか言えなかったです。すいません
>>16
なるほど。ありがとうございます

18:デフォルトの名無しさん
07/09/21 14:22:58
#include <stdio.h>
int main(void)
{
int no1,no2,max;

puts("整数二つを入力してください。");
printf("整数1:"); scanf("%d",&no1);
printf("整数2:"); scanf("%d",&no2);

if (no1==no2)
puts("二つは同じです。");
else if (no1>no2)
max=no1;
else
max=no2;
printf("大きい値は、%dです。",max);

return (0);
}

で0と0を入れると、
「二つは同じです。
大きい値は、1です。」と出ます。
なぜですか?

19:デフォルトの名無しさん
07/09/21 14:26:09
no1==no2のとき、maxに値を代入してないからたまたま最初から入ってた数字が表示されてる

20:デフォルトの名無しさん
07/09/21 14:31:41
数値が同じときに「大きい値は~」を表示させたくないのなら、
最初のelseの後ろのifからreturnの手前までを{}で囲む

21:デフォルトの名無しさん
07/09/21 14:34:43
#include <stdio.h>
int main(void)
{
int no1,no2,max;

puts("整数二つを入力してください。");
printf("整数1:"); scanf("%d",&no1);
printf("整数2:"); scanf("%d",&no2);

if (no1==no2)
puts("二つは同じです。");
else if {
(no1>no2)
max=no1;
else
max=no2;
printf("大きい値は、%dです。",max);
}

return (0);
}
したら、
If文に ( がない(関数 main )
とエラーがでます。

22:デフォルトの名無しさん
07/09/21 14:37:14
else { if

23:デフォルトの名無しさん
07/09/21 14:39:07
>>22
thx!

24:デフォルトの名無しさん
07/09/21 19:04:29
const char** と char* const * と const char* const * の違いがよくわかる
説明サイト、参考書があったら教えていただけませんか? JISX 3010の当該章の提示
でも結構です。

よろしくおねがいします。

25:デフォルトの名無しさん
07/09/21 19:36:51
if (n1>n2)
max=n1;
else
max=n2;

max=(n1>n2) ? n1:n2;
とはどう違いますか?

26:デフォルトの名無しさん
07/09/21 19:42:21
>>25
結果は同じだが、後者の方が速い

27:デフォルトの名無しさん
07/09/21 19:45:19
いや同じでしょう

28:デフォルトの名無しさん
07/09/21 19:45:31
また適当な事言ってスレを盛り上げようとして~

29:デフォルトの名無しさん
07/09/21 19:48:43
アセンブリ見てみなよ

30:デフォルトの名無しさん
07/09/21 19:51:33
結局どっちなの?

31:デフォルトの名無しさん
07/09/21 19:55:48
>max=(n1>n2) ? n1:n2;
これって()要らないんじゃない?
max=n1>n2 ? n1:n2;
でいいんじゃない?

32:デフォルトの名無しさん
07/09/21 20:07:42
>>30
同じ
>>31
いい

33:デフォルトの名無しさん
07/09/21 20:39:35
>>24もおながいします..

34:デフォルトの名無しさん
07/09/21 21:13:07
constは直後のトークンを修飾する。

const char** p1; //charを修飾
char* const * p2; // char *を修飾
const char* const * p3; //charと char *を修飾
ならば
**p1がconst
*p2がconst
*p3と**p3がconst
だと想う。

35:デフォルトの名無しさん
07/09/21 21:15:48
>>24
URLリンク(kmaebashi.com)

36:デフォルトの名無しさん
07/09/21 22:17:52
num?printf("その数は0ではない。"):printf("その数は0。");

(num)?printf("その数は0ではない。"):printf("その数は0。");
のほうがいいですか?

37:デフォルトの名無しさん
07/09/21 22:27:47
if-elseのほうがいい。常考。

38:デフォルトの名無しさん
07/09/21 22:30:56
C言語ってなんですか、

39:デフォルトの名無しさん
07/09/21 22:32:01
>>36
どうでもいい。


40:デフォルトの名無しさん
07/09/21 22:33:48
Cライブラリのワイド文字(wchar_tとかwint_t)について質問です。
ユニコード(UTF16)では0x0000~0xffffまでの値が文字の領域として
定義されているらしいですが、WEOFは0xffffと定義されています。
これだと文字とWEOFを区別できない様な気がするのですが、
0xffffの文字は存在しないと考えてよいのでしょうか?

ここを見ると一応未使用となっていますが、気持ち悪いです。
URLリンク(ja.wikipedia.org)

なんでEOFじゃなくWEOFになったんでしょうね。


41:デフォルトの名無しさん
07/09/21 22:33:49
三項演算子はその演算結果を使用しないのであればif-elseを使うべき。
printfの戻り値を利用するのなら丸っきり否定はしないが。

42:デフォルトの名無しさん
07/09/21 22:37:22
>>31は正しいのですか?
()はつける必要ないのですか?

43:デフォルトの名無しさん
07/09/21 22:39:01
max=(n1>n2) ? n1:n2;
でOKなら、
(num)?printf("その数は0ではない。"):printf("その数は0。");
もOKですよね?

max=n1>n2 ? n1:n2;
がOKなら、
num?printf("その数は0ではない。"):printf("その数は0。");
はOKですよね?

どっちが適切ですか?

44:デフォルトの名無しさん
07/09/21 22:41:09
>>43
どうでもいいよ。

45:デフォルトの名無しさん
07/09/21 22:41:17
>>41
そうなんですか。それなら、基本的にif-elseを使えばいいんですね。


46:デフォルトの名無しさん
07/09/21 22:41:54
4つともおk


47:デフォルトの名無しさん
07/09/21 22:42:32
>>41
ほっといてやれ
知ったばかりで使いたい年頃なんだ

48:デフォルトの名無しさん
07/09/21 22:43:29
>>47
教科書に載っていたので、条件演算子を使ったんです。
でも、あまり使われていないんですね。
if-elseのほうがいいんですよね?

49:デフォルトの名無しさん
07/09/21 22:45:41
>>43
演算子の優先順位について調べろ。
?:と=と>でどれがより優先されるか。

50:デフォルトの名無しさん
07/09/21 22:49:56
>>48
異論もあるだろうけど、if文を使った方が読みやすい場合が多いと思う。
?:を使ってコンパクトに書いた方がいいという積極的な理由がなければif文を選択した方が無難だと思う。

51:デフォルトの名無しさん
07/09/21 22:49:56
>max=n1>n2 ? n1:n2;
はNG
maxにn1が入る

52:デフォルトの名無しさん
07/09/21 22:55:27
>>51
それはどんな処理系?

53:デフォルトの名無しさん
07/09/21 22:56:16
>>52
C/C++処理系ではないことは確か

54:デフォルトの名無しさん
07/09/21 22:57:28
>>51
>>49

55:40
07/09/21 22:57:35
おい、さっさと教えろよ

56:デフォルトの名無しさん
07/09/21 22:59:24
>>40
知るかヴォけ

57:デフォルトの名無しさん
07/09/21 23:01:16
>>55
>>40 のリンク先をもう一度よく見なおしてみれば満足できるかも

58:デフォルトの名無しさん
07/09/21 23:01:42
>>51
だから、
max=(n1>n2)?n1:n2;
がいいよ。()をつけるべき。

59:デフォルトの名無しさん
07/09/21 23:01:49
>>40
異論もあるだろうけど、ここは条件演算子の是非を今更議論するような
幼稚なスレなので、他を当たって下さい。ちなみに自分もわかりませんので。

60:デフォルトの名無しさん
07/09/21 23:06:03
>>59
芸風真似すんなww

61:デフォルトの名無しさん
07/09/21 23:08:03
>>51>>58
ホレ。ググってきてやったぞ。
コレ見て落ち着いて来い。な?

URLリンク(www.bohyoh.com)

62:デフォルトの名無しさん
07/09/21 23:09:57
>>40
頭悪いな。
16bit処理系だとEOFも0xffffなんだよ。
判る?
たとえると実際のハードウェアやOSでNULLの0を示す
アドレス付近を読み出し専用にして不正なアドレスをトラップする仕組みと同じ。


63:デフォルトの名無しさん
07/09/21 23:12:17
>>62
分かってないのはお前じゃないのか?

64:40
07/09/21 23:15:06
あー未使用じゃなくて「不使用」なのね。
よくわかった。
けど、wikipediaなんて信用すんなこのアホが!
って人もいるけど、その辺どうよ?
俺は信用したが。

65:デフォルトの名無しさん
07/09/21 23:15:17
>>40
0xfffe, 0xffffはアプリケーション定義

66:デフォルトの名無しさん
07/09/21 23:18:34
え、おれ今までwint_tってintなのかと思ってた
wchar_tなのかよ
やべえwwww

67:デフォルトの名無しさん
07/09/21 23:28:56
>>40
wchar_tはunsigned shortになってるから、WEOFの時だけ
short→intとキャストすればEOFと共有できるよ。

68:デフォルトの名無しさん
07/09/21 23:37:13
BOM

69:デフォルトの名無しさん
07/09/21 23:41:13
>>67
WEOFの時だけ、って条件だと、
int my_fputwc(wint_t c, FILE *fp)
{ wint_t r = fputwc(c, fp);
return (r == WEOF) ? EOF : r;
}
みたいな書き方しかないと思うけど、
これを条件分岐させずに書く方法ってある?

70:デフォルトの名無しさん
07/09/21 23:46:38
#include <stdio.h>

void wprt(char (*sp)[7], int n);

int main(void)
{
char str[3][7] = {"JAPAN", "USA", "FRANCE"};

wprt(str, 3);

return 0;
}

void wprt(char (*sp)[7], int n)
{
int i, j;

for(i = j = 0; i < n; i++, sp++, j = 0)
{
printf("string: %d line = ", i);
while(*((*sp) + j) != '\0')
{
printf("%c", *((*sp) + j ));
j++;
}
printf("\n");
}
}


71:デフォルトの名無しさん
07/09/21 23:47:23
>>70のプログラムで、出力結果は
string: 0 line = JAPAN
string: 1 line = USA
string: 2 line = FRANCE


となるのですが、どうしても
*((*sp) + j)
の部分できちんと処理されてるのかわかりません

この書き方だと配列strの最初の「J」にjの値を足すことになるのでは?
なぜきちんとアドレスに1足したように処理されているのでしょうか?

72:デフォルトの名無しさん
07/09/21 23:51:36
jは文字列のインデクス
増えるたびに
J A P A N
と順に指してる

73:デフォルトの名無しさん
07/09/21 23:59:02
>>69
int wtbl[0x10000];
void dokkade_jikkou(void ) {
int i;
for (i = 0; i < 0x10000; i++)
wtbl[i] = i;
wtbl[0xffff] = EOF;
}
int my_fputwc(wint_t c, FILE *fp) return wtbl[fputwc(c, fp);]; }

256KB我慢できれば。

74:デフォルトの名無しさん
07/09/22 00:06:00
>>71
ポインタの型スケーリング

75:デフォルトの名無しさん
07/09/22 00:32:37
>>72 >>74

返答ども!
やってることは確かにそうなんですよねぇ

なんで*(sp + j)でやると異常終了するんでしょう?
アドレスを1づつ増やして、*でその1増えたアドレスを差せば
順番に出力されてもいいはずなのになぁ

76:デフォルトの名無しさん
07/09/22 00:40:34
>>71
どこから引っ張ってきたソースだかしらんけど
spは要素7のcharの配列へのポインタだから*spは要素7のcharの配列そのものを意味するけど
これは直ちに要素7のcharの配列の先頭要素へのポインタつまりcharへのポインタに成り下がるので、
これにjを足せばそれは要素7のcharの配列の先頭要素から数えてj個目の要素を指すポインタになるから
*(*sp+j)は要素7のcharの配列の先頭要素から数えてj個目の要素を意味する

77:デフォルトの名無しさん
07/09/22 00:44:06
>>75
spは要素7のcharの配列へのポインタだから、
これに1を足すと要素7のcharの配列のサイズぶん後を指す
charのサイズぶん後を指させたいならcharへのポインタにしなければならない

78:デフォルトの名無しさん
07/09/22 00:44:21
spは「要素7の配列」へのポインタだから
有効なのはsp+0~sp+2 の間だけ
spに1足すと
[JAPAN\0\0]
→[USA\0\0\0\0]
[FRANCE\0]
に移動する
JAPANの'A'に移動するわけじゃない

79:デフォルトの名無しさん
07/09/22 00:49:13
こういう場合普通は char sp[][7] って書いて
sp[i][j] みたいに参照するんだけどな
なんだこのソース

それとも訓練用にわざとわかりにくい書き方をしてるのか

80:75
07/09/22 01:11:26
みなさんありがとうございます!非常にすっきりしました。どんだけ悩んだことか・・・

spは配列strの先頭アドレスが入ってて、1足せば次の文字が出るもんだと思ってた
今の場合は2次元配列で要素数が7だからsp+1だと7つ分一気にずれるのか

で、*spにすることでcharへのポインタになり、1足せば次の要素に行く。と・・・

こんな感じであってるんでしょうか?

81:デフォルトの名無しさん
07/09/22 03:19:35
> ユニコード(UTF16)では0x0000~0xffffまでの値が文字の領域として
> 定義されているらしいですが、WEOFは0xffffと定義されています。
このそもそも間違いだらけの文章に誰も突っ込まないってどうよ

82:デフォルトの名無しさん
07/09/22 04:28:28
どこが間違ってるか説明お願いしますよ

83:デフォルトの名無しさん
07/09/22 04:30:29
1行目はC言語のワイド文字(Unicodeとは限らない)の話なのに
なぜか唐突にUnicodeが出てくる
WEOFは0xffffとは限らない

84:デフォルトの名無しさん
07/09/22 10:19:03
たまたま40の処理系ではそうだったけど、ということで勘弁してやろうぜ。

85:デフォルトの名無しさん
07/09/22 10:42:54
>80
あってる

86:デフォルトの名無しさん
07/09/22 10:56:34
objと lib は同じようなものですか?

objを標準のlibフォルダに入れておけばコンパイル速いですか?

87:デフォルトの名無しさん
07/09/22 11:09:52
複数の関数が入っているlibファイルを作って、<***.h>と書いたとき自動的に必要なlibファイルを読み込むように出来ますか?
printfとかは必要なlibファイルを勝手に読み込みますよね?

88:デフォルトの名無しさん
07/09/22 11:14:15
環境とコンパイラによる
C言語そのものとは関係ない

89:デフォルトの名無しさん
07/09/22 11:21:32
>>86
>objと lib は同じようなものですか?
Windowsのlibの話ならlibはobjのアーカイブ

>objを標準のlibフォルダに入れておけばコンパイル速いですか?
関係ない

>>87
ムリ
>printfとかは必要なlibファイルを勝手に読み込みますよね?
gccならlibc、VCならCRTが自動的にリンクされるだけで、ヘッダファイルとは関係ない

90:デフォルトの名無しさん
07/09/22 12:09:33
↑リンカーを自分で作ったら可能

91:デフォルトの名無しさん
07/09/22 12:12:15
JavaScriptに近いC++ありませんか?

92:デフォルトの名無しさん
07/09/22 12:14:34
>>91
C#

93:デフォルトの名無しさん
07/09/22 13:46:57
3つの数字が同じかどうかを
A==B==C
で比較できますか?


94:デフォルトの名無しさん
07/09/22 13:50:05
できませんよ

95:デフォルトの名無しさん
07/09/22 13:50:52
できますよ

96:デフォルトの名無しさん
07/09/22 13:52:20
AもBもCも1である、という限られた条件なら可能w。

97:デフォルトの名無しさん
07/09/22 13:52:43
そう思うならやってごらんよ

98:デフォルトの名無しさん
07/09/22 13:59:01
>>95
お前バカだなぁ
わかってないんだから出てくるなよ

99:デフォルトの名無しさん
07/09/22 16:13:40
できますよ

100:デフォルトの名無しさん
07/09/22 16:15:38
できますん

101:デフォルトの名無しさん
07/09/22 16:23:29
自演乙

102:デフォルトの名無しさん
07/09/22 16:54:14
どうでもいいが、馬鹿は初心者スレで言ってくれ。

103:デフォルトの名無しさん
07/09/22 17:21:48
>>87
>複数の関数が入っているlibファイルを作って、<***.h>と書いたとき自動的に必要なlibファイルを読み込むように出来ますか?
Visual C++ なら、ヘッダファイルに次のように書いておけば、mylib.libがリンクされる。
#pragma comment(lib, "mylib.lib")

104:デフォルトの名無しさん
07/09/22 17:35:38
>>103
スレ違いは誘導しましょう。

105:デフォルトの名無しさん
07/09/22 18:28:21
JIS X 3010-1993 6.2.1.2 から
負の整数 A を A の型と同じサイズか大きいサイズの符号無し整数 B に変換するとき
処理系の負の整数の表現がどうであれ B は A の 2 の補数表現と同じビットパターン
になると考えてもいいですか?


106:デフォルトの名無しさん
07/09/22 18:36:22
規格は、処理系が採用している数値の内部表現(2's complementとか)には言及してないだろ。
だから、符号拡張が起きるかどうか(が聞きたいのだろうがそれ)も処理系による。


107:デフォルトの名無しさん
07/09/22 18:38:41
とはいえ、まーそのへんの2's complementな処理系だと、

32bit signed int が INT_MIN
10000000000000000000000000000000
だったとして、それを64bit unsigned long longに代入したら
1111111111111111111111111111111110000000000000000000000000000000
だわな。

| B は A の 2 の補数表現と同じビットパターン
| になると考えてもいいですか?

だから、この答えはNoかな。



108:デフォルトの名無しさん
07/09/22 18:58:19
規格では B の型の最大値 + 1 + A だから型のサイズが同じ処理系なら
負数の表現方法にかかわらず同じ結果になるんじゃないですか?


109:デフォルトの名無しさん
07/09/22 19:00:18
>>108
規格の文言を一字一句たがわず書いてみて

110:デフォルトの名無しさん
07/09/22 19:06:05
> 型のサイズが同じ処理系なら
> 型のサイズが同じ処理系なら
> 型のサイズが同じ処理系なら
> 型のサイズが同じ処理系なら
> 型のサイズが同じ処理系なら
> 型のサイズが同じ処理系なら

>>105と前提が変化した件について。相手にするの止めようかな。



111:デフォルトの名無しさん
07/09/22 19:18:17
ビットの話がしたいなら、規格持ち出すの止めて処理系書けよ。



112:デフォルトの名無しさん
07/09/22 19:22:00
NicoVideo動画リンクが付いて超便利になった
URLリンク(www.freewebs.com)


113:デフォルトの名無しさん
07/09/22 19:27:03
if (sa > 10 || sa < -10)

if (sa>=11 || sa<=-11)
は同じですか?

114:デフォルトの名無しさん
07/09/22 19:29:12
>>113
sa が整数型なら

115:デフォルトの名無しさん
07/09/22 19:33:15
>> 109
JIS X 3010-1993 は会社にしかないし紙しかなく文が長いので
ここに書くには手間がかかりすぎます。


116:デフォルトの名無しさん
07/09/22 19:42:48
>>113
お前宿題スレでしつこく書いてるバカだろ
お前だけだぞ、わかってないの

117:デフォルトの名無しさん
07/09/22 19:45:33
>>115
身勝手な奴だな

118:デフォルトの名無しさん
07/09/22 20:08:10
printfなどの関数でefgなど浮動小数点数の変換を行うとき、
私は四捨五入が行われるものと思っていましたが、
X3014 : 2003 7.19.6.1には「この変換は適切な桁数への値の丸めも行う」と書かれているのみです。

この丸めもFLT_ROUNDSに従うものなのでしょうか。
あるいは、私が見落としただけで、ほかの箇所で規定されているのでしょうか。

119:デフォルトの名無しさん
07/09/22 20:13:55
>>113
こんなとこまで来ててフイタ

120:デフォルトの名無しさん
07/09/22 20:24:25
模倣犯では。
ネット社会が生み出した
これも一つの Stand Alone Comlex か(笑)


121:デフォルトの名無しさん
07/09/22 20:25:21
模倣犯では。
ネット社会が生み出した
これも一つの Stand Alone Comlex か(笑)

122:デフォルトの名無しさん
07/09/22 20:25:47
模倣犯では。
ネット社会が生み出した
これも一つの Stand Alone Comlex か(笑)


123:デフォルトの名無しさん
07/09/22 20:35:32
模倣犯では。
ネット社会が生み出した
これも一つの Stand Alone Comlex か(笑

124:デフォルトの名無しさん
07/09/22 20:38:03
模倣犯では。
ネット社会が生み出した
これも一つの Stand Alone Comlex か(笑)

125:デフォルトの名無しさん
07/09/22 20:44:23
>>120-124
間違い探しか?

126:デフォルトの名無しさん
07/09/22 21:01:22
Stand Alone Comlex(笑)

127:デフォルトの名無しさん
07/09/22 21:02:33
>>109
C90 ではなく C99 であるが URLリンク(www.jisc.go.jp)
6.3.1.3 に同じような内容がある。
UINT_MAX が 65535 のとき (unsigned int)(-1) は 65535 ということに
ならないでしょうか?


128:デフォルトの名無しさん
07/09/22 22:13:22
intで2バイトってまだあるの?

129:デフォルトの名無しさん
07/09/22 22:13:34
うん

130:デフォルトの名無しさん
07/09/22 22:36:41
ifとswitchはどのように使い分ければいいですか?

131:デフォルトの名無しさん
07/09/22 22:52:49
switchは複数個の定数値を取るかもしれない1個の変数を判断するとき
それ以外はif
というか全部if、else ifでも別に

132:デフォルトの名無しさん
07/09/22 22:58:04
>>131
具体的に教えてください。

133:デフォルトの名無しさん
07/09/22 22:59:41
>>132
具体的に聞いてください。

134:デフォルトの名無しさん
07/09/22 23:00:20
>複数個の定数値を取るかもしれない1個の変数を判断するとき
というのが良く分かりません。

135:デフォルトの名無しさん
07/09/22 23:05:31
知らなくておk

136:デフォルトの名無しさん
07/09/22 23:07:42
分かったときに分かればいいだけの話

137:デフォルトの名無しさん
07/09/22 23:09:55
>>134
if(xxx==0){
.....
}else if(xxx==1){
.....
}else{
.....
}
↑こういうのならswitchで↓この様に書けるけど
switch(xxx){
case 0:.....break;
case 1:.....break;
default:.....
}
↓こういうのはswitchを使って書けない
if(xxx==0){
.....
}else if(yyy==1){
.....
}else if(yyy==zzz){
.....
}else{
.....
}

138:デフォルトの名無しさん
07/09/22 23:16:34
馬鹿な質問に対して列挙型を~って素直に教えないところがこのスレの優しさだな。

139:デフォルトの名無しさん
07/09/22 23:17:04
と言ってしまったけどswitchを複数使えば書けないことも無いか
でもやっぱりそこまでして使うくらいならifを使ったほうがいい

140:デフォルトの名無しさん
07/09/22 23:19:48
>>138
皮肉なんか言ってないで教えたらどうなの。

141:デフォルトの名無しさん
07/09/22 23:43:39
初心者スレじゃないんだから、わざわざ教えることもない。

142:デフォルトの名無しさん
07/09/23 00:01:27
符号付き整数 x を2のn乗 (n は 0 から 8 の整数) で割って-∞方向の
整数に丸める整数演算はどのようにすればいいでしょうか?
Windows なら右シフトで x >> n のようにできますが処理系定義なので
一般的には右シフトではできないようですが。


143:デフォルトの名無しさん
07/09/23 01:23:10
>>142
x / (1 << n)

144:デフォルトの名無しさん
07/09/23 01:28:14
>>143
それだと負の数が0方向に丸められないか?

145:デフォルトの名無しさん
07/09/23 01:43:54
>>144
んじゃ、負の数ん時は条件分岐して適当にやっておいて。

146:デフォルトの名無しさん
07/09/23 02:38:31
>>127
ファイルが見つかりません。
ならない。

147:デフォルトの名無しさん
07/09/23 02:39:26
ちなみに-(unsigned int)1なら65535になる。

148:デフォルトの名無しさん
07/09/23 02:43:26
へ? (unsigned int)(-1) は UINT_MAX と同じだろ。

149:デフォルトの名無しさん
07/09/23 02:46:46
>>146-147
何でそう思うか、きみが前提としている諸条件と共に述べよ。

150:デフォルトの名無しさん
07/09/23 03:22:22
どーでもいい話してんなお前ら

151:デフォルトの名無しさん
07/09/23 04:45:40
>>149
それはむしろ俺が>>127に言いたいんだが

152:デフォルトの名無しさん
07/09/23 09:48:24
/*奇数か偶数か*/
#include <stdio.h>
int main(void)
{
int no;

printf("整数:"); scanf("%d",&no);

switch (no%2) {
case 0:puts("偶数");break;
case 1:puts("奇数");break;
}
return (0);
}


153:デフォルトの名無しさん
07/09/23 10:14:31
switch (no%2) {
case 0:puts("偶数");break;
case 1:puts("奇数");break;
}



puts((no%2)?"奇数":"偶数");

154:デフォルトの名無しさん
07/09/23 10:15:26
/*月の季節を表示 switchで*/
#include <stdio.h>
int main(void)
{
int no;

printf("月:"); scanf("%d",&no);

switch(no) {
case 3:
case 4:
case 5:puts("春です。");break;
case 6:
case 7:
case 8:puts("夏です。");break;
case 9:
case 10:
case 11:puts("秋です。");break;
default:puts("冬です。");break;
}

return (0);
}




155:デフォルトの名無しさん
07/09/23 10:16:26
>>153
条件演算子は、見にくくなるから使わないほうがいいって言われたんですが、どうなんでしょうか?

156:デフォルトの名無しさん
07/09/23 10:21:29
>>154
そらぁさすがに、defaultはエラー処理に使うべきじゃね?

157:デフォルトの名無しさん
07/09/23 10:22:56
>>155
>>153が見にくい?

158:デフォルトの名無しさん
07/09/23 10:27:14
>>153は十分に可読性を残してるだろ

159:デフォルトの名無しさん
07/09/23 10:39:46
>>50参照。

160:デフォルトの名無しさん
07/09/23 10:40:00
>>41
参照。

161:デフォルトの名無しさん
07/09/23 10:41:06
>>154
/*月の季節を表示 switchで*/
#include <stdio.h>
int main(void)
{
int no;

printf("月:"); scanf("%d",&no);

switch(no) {
case 3:
case 4:
case 5:puts("春です。");break;
case 6:
case 7:
case 8:puts("夏です。");break;
case 9:
case 10:
case 11:puts("秋です。");break;
case 12:
case 1:
case 1:puts("冬です。");break;
default:puts("そんな月ありません。");
}

return (0);
}




162:デフォルトの名無しさん
07/09/23 10:56:22
>>161
バグがある

163:デフォルトの名無しさん
07/09/23 11:08:22
>>154,>>161
何故これを書いたの?この後に質問が続くのか?
先に意図を書いて欲しい...

164:デフォルトの名無しさん
07/09/23 11:15:23
return (0); //(笑)

case 1:
case 2:puts("冬です。");break;
の間違い?

165:デフォルトの名無しさん
07/09/23 11:31:54
>>163
多分>>134の例だろ

166:デフォルトの名無しさん
07/09/23 12:42:42
>>147
6.5.3.3 単項演算子-の結果は,その(拡張された)オペランドの符合を反転した値とする。
オペランドに対して整数拡張を行い,その結果は,拡張された型を持つ。

拡張された型で負数を表現できない場合にどうなるかの記述を見つけることができ
なかったが,拡張された型に変換されると考えれば
(unsigned int)(-1) と -(unsigned int)1 は同じ結果になるんじゃないか?


167:デフォルトの名無しさん
07/09/23 13:36:46
puts("\a負の数を入力しないでください。");
の\aはどんな意味がありますか?

168:デフォルトの名無しさん
07/09/23 13:41:27
>>167
ビープ音を1回鳴らす。

169:デフォルトの名無しさん
07/09/23 13:53:52
\a = alert
実際の動作は処理系依存。
ビープ音もあれば画面をフラッシュさせることもあるらしい。

170:デフォルトの名無しさん
07/09/23 14:11:57
前者はaudible alarm、後者はvisible alarmと言うこともあるね。

171:デフォルトの名無しさん
07/09/23 16:08:05
int no;
int sum;
no=1;
sum=2;

int no=1;
int sum=2;
は同じですか? どちらを使うべきですか?

172:デフォルトの名無しさん
07/09/23 16:09:39
後者は古い規格だと使えない事がある

173:デフォルトの名無しさん
07/09/23 16:23:02
>>172
それはないやろ。

174:デフォルトの名無しさん
07/09/23 16:23:55
いいえ。このスレ的には全く問題ありません。

175:デフォルトの名無しさん
07/09/23 16:25:57
>>172
そうなんですか。前者を使うほうがいいんですね。

176:デフォルトの名無しさん
07/09/23 16:33:04
>>175
いいえ。後者を使うべきです。

177:デフォルトの名無しさん
07/09/23 16:33:33
なんで?

178:デフォルトの名無しさん
07/09/23 16:38:37
前者を使うべき理由がないからです。

179:デフォルトの名無しさん
07/09/23 16:38:43
どっちでもいいだろ

180:デフォルトの名無しさん
07/09/23 16:39:56
それだと 後者を使うべき理由が無いから前者を使うべきです とも言える

181:デフォルトの名無しさん
07/09/23 17:05:35
>>172さんへ
質問者です。それは本当ですか?
ということは、前者を使ったほうがいいってことですか?
どうなんでしょうか?


182:デフォルトの名無しさん
07/09/23 17:09:43
>>181
C89とC99あたりの違いで言ってるんだろうけど本当だよ

183:デフォルトの名無しさん
07/09/23 17:11:06
ボーランドのbccを使っているんですが、
その場合も前者を使ったほうがいいですか?

184:デフォルトの名無しさん
07/09/23 17:12:06
バージョンくらい書けよ

185:デフォルトの名無しさん
07/09/23 17:13:22
MAKE Version 5.2 Copyright (c) 1987, 2000 Borland
ってなってます

186:デフォルトの名無しさん
07/09/23 17:14:37
Borland C++Compiler 5.5.1
です。

187:デフォルトの名無しさん
07/09/23 17:43:05
C++だと、初期化と代入が区別されるから、Cでも意識して使いわけてもいいんじゃないか?


188:デフォルトの名無しさん
07/09/23 17:45:33
どういうこと?

189:デフォルトの名無しさん
07/09/23 17:55:52
>>127,146-147,166
(unsigned int)(-1) は 6.3.1.3 p2 により UINT_MAX と同じになる。

"if the new type is unsigned, the value is converted by repeatedly adding or
subtracting one more than the maximum value that can be represented in the new type
until the value is in the range of the new type."

-(unsigned int)1 は 6.2.5 p9 により UINT_MAX と同じになる。

"A computation involving unsigned operands can never overflow,
because a result that cannot be represented by the resulting unsigned integer type is
reduced modulo the number that is one greater than the largest value that can be
represented by the resulting type."

引用は ISO のドラフト (n1124) からね。

190:デフォルトの名無しさん
07/09/23 18:11:50
>>180
いいえ、後者を使うべき理由ならあります。
宣言以降代入までの不定値が存在する期間を排除することができるというのがそれです。

191:デフォルトの名無しさん
07/09/23 18:21:32
互換性のために前者で書いたほうがいい

192:デフォルトの名無しさん
07/09/23 18:26:22
Cで前者にしか対応してないコンパイラがまだまだ普及してる
互換性を切り捨てるには時期尚早

193:デフォルトの名無しさん
07/09/23 18:29:23
っていうか、俺涙目みたいな・・・

194:デフォルトの名無しさん
07/09/23 18:46:58
代入と初期化は違うんだよ!
初期化を怠ると、後でひでーめに遭うんだよ!
むしろ初期化は強制すべきなんだよ!

195:デフォルトの名無しさん
07/09/23 18:51:24
そんな事言ってる君らはどのコンパイラ使ってるの?

196:デフォルトの名無しさん
07/09/23 18:54:37
Kylix

197:デフォルトの名無しさん
07/09/23 18:59:33
>>189
ありがとうございます。勉強になりました。

198:デフォルトの名無しさん
07/09/23 20:01:38
>>194
私をお呼びですか?フフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフフ

199:デフォルトの名無しさん
07/09/23 20:02:50
>194
代入を禁止したらいい。


200:デフォルトの名無しさん
07/09/23 20:09:43
・変数の初期値は必ず決める
・変数への代入は可能な限り行わない(変数を使いまわさない)

でもコンテナとかポインタ先への間接代入はしょうがないよね。


201:デフォルトの名無しさん
07/09/23 20:24:46
関数型言語でおk

202:デフォルトの名無しさん
07/09/23 20:41:26
C++でもSICPの問題がとけるんだからきっとCでも解けるさ

203:デフォルトの名無しさん
07/09/23 21:14:28
>>191
>>192
どこに初期化ができないCコンパイラがあるというんだ?
だれもブロックの途中だなんて一言も言ってないわけで、宣言できる場所でなら初期化代入は必ずできるわけだが。

204:デフォルトの名無しさん
07/09/23 21:29:25
構造体変数のコピー初期化ができないコンパイラには遭ったことがある。
struct s a = {...}; /* これはいける */
struct s b = a; /* こっちはエラー */

205:デフォルトの名無しさん
07/09/23 21:31:01
>>204
スレタイに注目。

206:デフォルトの名無しさん
07/09/23 21:46:28
>>204
こいつ最高にアホ。

207:204
07/09/23 21:47:18
>>205 何か問題でも?

208:デフォルトの名無しさん
07/09/23 22:03:51
K&Rならいざしらず、ISOその他では204ができないといけないことになっている。

209:デフォルトの名無しさん
07/09/23 22:08:32
ビットフィールドは、ビット演算を使わないように気を付ければ移植性は問題無しですか?

210:デフォルトの名無しさん
07/09/23 22:15:17
>>209
メモリ上のレイアウトを意図したビットフィールドの使い方には移植性に問題があります。
ビット演算を使うかどうかは、あんまり関係ないでしょう。

211:209
07/09/23 22:47:20
>>210
どうもありがとう。

ちなみに、処理速度的にはやっぱりビットフィールド使うとたいていの場合遅くなるもんですか?
どっちみち今やってるプログラムはメモリの制約があるので使わざるを得ないんですが…

212:デフォルトの名無しさん
07/09/23 22:55:49
>>211
遅くなることのほうが多いだろうけど、使い方とコンパイラの実装の相性による。
速度は実測が基本。

213:デフォルトの名無しさん
07/09/24 17:19:46
プログラミングが上達するコツ
スレリンク(tech板)

214:デフォルトの名無しさん
07/09/24 21:50:47
clock()が本来返すべき値がclock_tの範囲を超えた場合ってどうなるんですか?

215:デフォルトの名無しさん
07/09/24 21:55:11
If the processor time  used is  not  available  or  its  value cannot be represented, the function shall return the value (clock_t)-1.





216:デフォルトの名無しさん
07/09/24 21:59:26
>>215
ありがとう。

217:デフォルトの名無しさん
07/09/25 15:39:42
int sum;
int dig;
とint sum,dig;
とはどう違いますか?

218:デフォルトの名無しさん
07/09/25 15:59:30
違わない

219:デフォルトの名無しさん
07/09/25 16:17:39
C99の標準機能だけで、UNIXのsleepコマンドみたいな機能は実現可能ですか?

220:デフォルトの名無しさん
07/09/25 16:19:40
whileとforはどう使い分けるべきですか?

221:デフォルトの名無しさん
07/09/25 17:04:51
>>219
不可能

>>220
whileとforの仕様を本当に理解していたらそんな出るはずない
教科書読み直せ

222:デフォルトの名無しさん
07/09/25 17:05:22
×そんな
○そんな質問

223:デフォルトの名無しさん
07/09/25 18:10:20
そんなあー

224:デフォルトの名無しさん
07/09/25 18:20:56
>>223
>>223
>>223
>>223
>>223

225:デフォルトの名無しさん
07/09/25 21:46:08
>>219
system("sleep

226:デフォルトの名無しさん
07/09/25 21:57:02
");

227:デフォルトの名無しさん
07/09/26 00:47:34
JIS X3010 の 6.2.6.2 を読んだだけでは分からなかったのですが
int の負数の表現が 2 の補数で short の負数の表現が 1 の補数
という処理系はありえますか?


228:デフォルトの名無しさん
07/09/26 01:08:58
灯油を燃やした熱で水蒸気を発生させてタービンを回して発電した電力で水を電気分解して得られた水素と酸素を爆発させてシリンダーを動かしてプロペラに伝えて走るホバークラフトくらいにはありえる

229:デフォルトの名無しさん
07/09/26 01:39:47
面白くない

230:デフォルトの名無しさん
07/09/26 01:46:44
>>228
ロジン貸そうか

231:デフォルトの名無しさん
07/09/26 15:21:00
int goto;
int while;
int for;
とかintに関数を使ってもいいですか?

232:デフォルトの名無しさん
07/09/26 15:23:13
>>231
gotoもwhileもforも関数じゃないが、予約語は変数名に使えない。


233:デフォルトの名無しさん
07/09/26 15:43:22
#include <stdio.h>
int main(void)
{
int kara;
int made;
int kankaku;
int cnt;

printf("何cmから:"); scanf("%d",&kara);
printf("何cmまで:"); scanf("%d",&made);
printf("何cmごと:"); scanf("%d",&kankaku);

for (cnt=0; (kara+cnt)<=made; cnt=+kankaku) {
printf("%dcm ",kara+cnt);
printf("%.2fkg\n",(double)(kara+cnt-100)*0.9);
}

return (0);
}

これどこがミスってますか?

234:デフォルトの名無しさん
07/09/26 15:43:33
>>232
thx!

235:デフォルトの名無しさん
07/09/26 15:44:21
>cnt=+kankaku
ですね。thx!

236:デフォルトの名無しさん
07/09/26 19:11:09
while (!cont)
ってどういう意味?


237:デフォルトの名無しさん
07/09/26 19:16:18
!は以外ってこと
contだけのときは、0
!contは!0ってこと。
だから、0以外

238:デフォルトの名無しさん
07/09/26 19:55:47
>>236はどういう意味ですか?
!contっていう部分です

239:デフォルトの名無しさん
07/09/26 19:58:11
否定ってこと。0のこと。

240:デフォルトの名無しさん
07/09/26 20:00:13
>>239
???

>>238
cont=0;
printf("cont=%d !cont=%d\n", cont, !cont);
cont=1;
printf("cont=%d !cont=%d\n", cont, !cont);
cont=2;
printf("cont=%d !cont=%d\n", cont, !cont);
cont=-1;
printf("cont=%d !cont=%d\n", cont, !cont);

241:デフォルトの名無しさん
07/09/26 20:03:21
contの反対ですよ。

242:デフォルトの名無しさん
07/09/26 20:08:26
アホばっか

243:デフォルトの名無しさん
07/09/26 20:08:32
while文は0以外の時に真となりループする。
while(cont)は、contが0以外だったらループする。
while(!cont)は、「contが0以外」以外だったら、つまり0だったらループする。

244:デフォルトの名無しさん
07/09/26 20:12:15
>while(!cont)は、「contが0以外」以外だったら、つまり0だったらループする。
どういう意味?

245:デフォルトの名無しさん
07/09/26 20:28:37
どういう意味もなにも、それ以外の意味は無いんだが…

while ( ! (cont) )

こう書けば分かるかね?論理否定演算子あたりでググってくれ。

246:デフォルトの名無しさん
07/09/26 21:15:22
釣られすぎ

247:デフォルトの名無しさん
07/09/26 21:20:06
コントです

248:デフォルトの名無しさん
07/09/26 23:02:38
誰がうまい事言えと・・・

249:デフォルトの名無しさん
07/09/27 00:37:50
釣りだったのかよ。付き合って損した。こんなことしてもスレ住人が減るだけなのに。

250:デフォルトの名無しさん
07/09/27 14:54:01
型 X と型 Y が signed 付きか unsigned 付きかの違いしかない整数型のとき
X x = A;
Y* y = (Y*)&x;
のあと
(Y)x と *y は同じ結果になりますか?
または ISO/IEC 9899:1990 のどのあたりで分かりますか?


251:デフォルトの名無しさん
07/09/27 15:18:35
>signed 付き
>unsigned 付き

252:デフォルトの名無しさん
07/09/27 16:13:37
#include <stdio.h>
int main(void)
{
int width,height,i,j;

puts("長方形");
printf("幅はいくつ?:"); scanf("%d",&width);
printf("高さはいくつ?:"); scanf("%d",&height);

for (i=1; i<=height; i++) {
for (j=1; j<=width; j++)
putchar('*');
putchar('\n');
}

return (0);
}
を採点してください。こうしたほうが、スマートだよとか、
速いよ、とかあれば教えてください。

253:デフォルトの名無しさん
07/09/27 16:57:42
・scanf()は使わない方がいい。
・個数を回すループは 0 から n 未満とするのが一般的。
・forの中味の行が変わるなら括っておくのが無難。
・一文字変数は避けた方がいい。
・(0)は意味がないので 0 で充分。

254:デフォルトの名無しさん
07/09/27 17:04:09
>>252
>>1
> GUIなどの標準Cではできない事の質問、ソース丸投げ、宿題、書籍 は
> 専門の別スレッド↓があるのでそこへさようなら。

255:デフォルトの名無しさん
07/09/27 18:35:24
>>253
このようなtoy programなら、scanfを使っていけない理由はない。
ループ制御変数はi,jのように1文字にするのが原則。無駄にcounterのようにすると返って読みにくい。

256:デフォルトの名無しさん
07/09/27 18:50:05
>>253の他はどうですか?

257:デフォルトの名無しさん
07/09/27 19:15:16
csvファイルを読み込んで構造体に格納するとき、
strtok()とsscanf()では、どちらを使う方がいいですか?
あるいはもっといい方法ありますか?

258:デフォルトの名無しさん
07/09/27 20:02:16
>>257
基本的にscanfファミリーはガッチリフォーマットの決まったレコードや
データが空白で区切られたレコードを読むのに最適に出来ている
カンマ区切りの可変長データは、それが全部数値ならいいが、
文字列が混ざってると厄介なことになりやすいので、
そういう場合にはstrtokを使ったほうが楽な場合も多い

あとは具体的なデータの内容によるとしか言えないが、
"str,ing",255, …みたいなものまで読める完全に汎用なものを作りたいなら
strtokでもsscanfでもなく頭っから一文字ずつ読んで解釈するしかない

259:デフォルトの名無しさん
07/09/27 20:02:30
#include <stdio.h>
int main(void)
{
int width,height;

puts("長方形");
printf("幅はいくつ?:"); scanf("%d",&width);
printf("高さはいくつ?:"); scanf("%d",&height);

for (int i=0; i<height; i++) {
for (int j=0; j<width; j++) {
putchar('*');
}
putchar('\n');
}

return 0;
}

260:デフォルトの名無しさん
07/09/27 20:40:43
>>259
C99だね

261:デフォルトの名無しさん
07/09/27 22:23:26
ピラミッドの作り方は、法則があるのですか?
scanf("%d",&n);

for (i=1; i<=n; i++) {
for (j=1; j<n-i+1; j++)
putchar(' ');
for (j=1; j<=(i-1)*2+1; j++)
putchar('*');
putchar('\n');

for (j=1; j<n-i+1; j++)

for (j=1; j<=(i-1)*2+1; j++)
の解説をお願いします。

262:デフォルトの名無しさん
07/09/27 22:24:24
>>261
ピラミッドにもいろいろあるので、一概には答えられません。

なんて冗談は兎も角、>1を読んで初心者スレへどうぞ。

263:デフォルトの名無しさん
07/09/27 22:26:22
>>262
thx! 移動します

264:デフォルトの名無しさん
07/09/28 00:18:10
>>252
そもそも長方形であるためには width>0 && height>0 でないといけないんだから
それをチェックすべきじゃないのか?

265:デフォルトの名無しさん
07/09/28 01:35:27
>>250
同じ結果になるとは言えない。
と 6.2.6.2 を読んで思った。

266:デフォルトの名無しさん
07/09/28 22:25:05
相互参照するヘッダってどう書けばよいですか。
文字列ライブラリと、エラーラーブラリのヘッダで、
文字列ライブラリでエラーがあったらエラーライブラリの関数、
エラーライブラリ内では文字列ライブラリを使ってます。
頭が再帰でどうにかなりそおです。

267:デフォルトの名無しさん
07/09/28 22:26:38
ちなみに
どっちかに自分のプロトタイプを置く方法は使いたくありません。
メンテが面倒なのでね。

268:デフォルトの名無しさん
07/09/28 23:10:53
よく使われるこのイディオムじゃ駄目?

--foo.h
#if !defined FOO_H
#define FOO_H
#include "bar.h"
...(本体)
#endif
--

--bar.h
#if !defined BAR_H
#define BAR_H
#include "foo.h"
...(本体)
#endif
--

269:デフォルトの名無しさん
07/09/28 23:18:55
>>266,267
文面からすると、関数の呼び出しをヘッダ内で行っている(つまり「定義」を書いている)???

通常は、ヘッダには、関数の[宣言のみ]書き、定義は別にするから、
互いに参照し合う必要はないはず。

270:デフォルトの名無しさん
07/09/28 23:41:32
うるさいなー
もー
C++だってインラインで定義してんじゃん
分けるの面倒なの!

271:デフォルトの名無しさん
07/09/28 23:44:20
>>268
それじゃダメだっつってんだろ

272:デフォルトの名無しさん
07/09/29 00:10:39
関数定義がヘッダで行われてるなら、
2つのソースファイルで同じヘッダを読み込んだ時点で
関数の2重定義でリンク通らなくなるだろ。

相互参照云々以前に根本的にバグってる。

273:デフォルトの名無しさん
07/09/29 00:18:55
>>272
ライブラリ使う側からなら何の問題もなし。
バグってるのはお前の頭。

274:デフォルトの名無しさん
07/09/29 00:25:01
>>273
コンパイル出来ない両ライブラリとライブラリを使ってる部分のソース一式どっかにアップするか
日本語勉強し直すか、どっちかにしてくれ。

275:デフォルトの名無しさん
07/09/29 00:26:01
わかんないなら引っ込んでろよ
うぜー


276:デフォルトの名無しさん
07/09/29 00:28:43
自分だってわからないことがあるから質問に来てるんじゃないのか?
そう邪険にするなよ

277:デフォルトの名無しさん
07/09/29 00:29:25
いや、これが正解なんだけど

278:デフォルトの名無しさん
07/09/29 00:29:30
ヘッダに関数定義書くとかクソすぎだろマジで

279:デフォルトの名無しさん
07/09/29 00:29:39
事故解決しました

280:デフォルトの名無しさん
07/09/29 00:37:26
ヘッダ2つの中身を一緒にしちゃえば?
んで、片方は#include1行の適当なヘッダ名でっち上げる。
ソース管理楽だよ。

281:デフォルトの名無しさん
07/09/29 00:42:48
>>280
今まさにそうしてるんだよね
気持ち悪いから変えたかったんだけど
いまのとこそれしか思いつかない
ほんとアホばっかだなここ・・・

282:デフォルトの名無しさん
07/09/29 02:26:20
アホが多いのは否定しない。

283:デフォルトの名無しさん
07/09/29 02:30:16
どんだけバカなんだよ
メンテが面倒だからプロトタイプ書かないとか
気持ち悪いなら他の言語使えば?

284:デフォルトの名無しさん
07/09/29 02:36:14
どう考えても釣りだろう

285:デフォルトの名無しさん
07/09/29 02:54:46
心の底から言ってるんじゃね?
そう考えると哀れみだけしか浮かんでこないので笑ってスルーできるよ。

286:デフォルトの名無しさん
07/09/29 05:58:54
そもそもこのスレで扱う内容なのか?
プロトタイプ宣言と定義が一致しないとエラーになるISO/ANSI/JIS Cはおかしい
K&R時代の仕様に戻すべきだとか?

287:デフォルトの名無しさん
07/09/29 06:37:27
むしろプロトタイプ宣言があれば凡ミスによるバグが減らせて保守が滅茶苦茶楽になるのにね。
機械にやらせられるところは極力機械にやらせるという発想がないやつはプログラマには向いてないな。

288:デフォルトの名無しさん
07/09/29 21:53:36
ファイルをアップロードするCGIをCで作ってます。
バウンダリ文字列で区切られたデータを切り出す際の定跡的な物はありますか??

いまは、
・CRLFCRLFとなった時点をデータの始まり
・すべて書き込んだ後、CRLFまで戻ってそこをデータの終わりとする
って感じでやってます。

289:デフォルトの名無しさん
07/09/29 22:04:13
>>288
Cの言語規約には含まれてはいないので、ご自由にどうぞ。

290:デフォルトの名無しさん
07/09/29 22:51:49
>>289
いや、規約というかテクニックを教えていただけたらと思いまして。。。


291:デフォルトの名無しさん
07/09/29 22:56:33
>>290
スレ違い。

292:デフォルトの名無しさん
07/09/30 00:16:29
議題:このスレの存在意義について

293:デフォルトの名無しさん
07/09/30 00:17:49
もちろん規格の範囲内についてを扱う。
それがなんのことやら理解できないやつが>>292みたいな疑問を持つ。

294:デフォルトの名無しさん
07/09/30 00:20:45
低席(なぜか変換できない)
定石(じょうせき)

295:デフォルトの名無しさん
07/09/30 00:31:52
定石は囲碁用語、定跡は将棋用語。
どちらもよみはじょうせき。

馬鹿の癖に無理に揚げ足とろうとするな

296:デフォルトの名無しさん
07/09/30 01:19:03
将棋なんて知らないもん!

297:デフォルトの名無しさん
07/09/30 08:03:43
288はネットワークプログラミングスレに誘導すればいいのか?

298:デフォルトの名無しさん
07/09/30 12:20:31
>>289>>291

>>288の質問って結局

---------------------hoge

(ここがバイナリデータ部)
---------------------hoge--

ってフォーマットからデータ部を切り出すテクニック、ってことだよ。
これ追い返してたら何も質問できないだろw
ネットワークプログラミングに誘導しても、向こうの住人も困るんじゃないか。
通信関係なら兎も角、タダの文字列処理だもんな。。。

299:デフォルトの名無しさん
07/09/30 12:25:29
>>298
ここは言語テクニックを語るスレでも初心者教習のスレでもありません。
標準Cでの仕様や実装を云々するスレです。
まして「データを切り出す際の定跡」と言った、言語に依存しない抽象概念を扱うスレではありません。

300:デフォルトの名無しさん
07/09/30 12:33:23
>>298
標準Cにおける文字列処理の質問じゃないでしょ。
少なくともhtmlについて殆ど何も知らない私にとって、>288に書かれた以外に
データを切り出す手段があるかどうかなんて見当もつかない。
「こうこうこういうプロトコルで来るデータがある、どう切り出すべきか」というなら
話は別だが、>288を読む限り単なる初心者質問だからこの辺りで充分だろ。
--
C言語なら俺に聞け(入門篇) Part 19
スレリンク(tech板)
スレを勃てるまでもないC/C++の質問はここで 3
スレリンク(tech板)
【初心者歓迎】C/C++室 Ver.43【環境依存OK】
スレリンク(tech板)

301:デフォルトの名無しさん
07/09/30 14:47:35
スレタイトルをそろそろ変えたほうがいいかもしれんね
C規格なら俺に聞け!
とか

302:デフォルトの名無しさん
07/09/30 14:55:20
C規格なら規格書嫁!とか
まあ、「規格」とか「標準」とかって言葉をいれておいた方がいいかもね。

303:デフォルトの名無しさん
07/09/30 14:59:12
ISO/ANSI/JISがそういう意図を含んでいるはずだがね

304:デフォルトの名無しさん
07/09/30 15:00:57
入門者がその意図をくめるはずもなく

305:デフォルトの名無しさん
07/09/30 15:13:30
【ISO/ANSI/JIS以外の】 C言語なら俺に聞け! 【質問お断り!】Part 133

そもそも【】内を真面目に読む人少ないでしょ
>>1も読まれない、合致する質問もほとんど来ない
終了でいいんじゃね

306:デフォルトの名無しさん
07/09/30 15:14:16
>>305
どう考えても字数制限引っかかるだろうが。あほか

307:デフォルトの名無しさん
07/09/30 15:18:49
C言語なら俺に聞け(入門篇) Part 19
【ISO/ANSI/JIS】 C言語なら俺に聞け! Part 132

上はコード質問可で、下は規約の解釈限定か。なかなか難しいなwww

308:デフォルトの名無しさん
07/09/30 15:20:03
そんなのにマジレスされてもなあ
頭大丈夫?

309:デフォルトの名無しさん
07/09/30 15:20:51
ごめんごめん
>>306の頭のことね

310:デフォルトの名無しさん
07/09/30 15:22:39
C言語規格議論厨隔離スレ
でいいじゃん

311:デフォルトの名無しさん
07/09/30 15:29:56
つーかどう考えても
ISO/ANSI/JIS
これいらないだろ。
取っちゃえよ。

標準Cなら俺に聞け!

テンプレ:
Q標準Cって何?

312:デフォルトの名無しさん
07/09/30 15:32:31
切れちゃった。まあいいや。
>>2の心得とかも必要ない。誤解されるだけ。

313:デフォルトの名無しさん
07/09/30 15:43:43
そりゃそうだな。
そもそも定義にうるさいはずの連中がなんで「C言語」とか「標準C」とか「C」とか
いちいち呼び方変えてるんだよ。
アホか。

314:デフォルトの名無しさん
07/09/30 16:00:31
>>305
>俺に聞け!

>質問お断り!
はねえだろw

315:デフォルトの名無しさん
07/09/30 16:05:12
【A】 B 【C】
とあったら、普通はBが正タイトルでACはサブタイ。ACは繋げて読む事が多い。
AやCに重みがあるスレはネタスレと決まっています。

316:デフォルトの名無しさん
07/09/30 16:10:12
「標準C限定」ってのは、コーディングの際に標準Cを逸脱しないって
意味だと思ってたんだけど、違ってたんだな。
「標準Cそのものに関する質問限定」ってことだったんだねw


317:デフォルトの名無しさん
07/09/30 16:13:35
>>315
ここってネタスレだったんだ
納得ww

318:デフォルトの名無しさん
07/09/30 16:18:29
>>316
フツーに考えて、規約の質問だけでpart132まで行くはずもなく……

いつの間に乗っ取られたんでしょうね。

319:デフォルトの名無しさん
07/09/30 16:19:28
>>316
規約に全く関係ない質問なら、他に質問スレたくさんあるからそっちへ行ってくれればいい

320:デフォルトの名無しさん
07/09/30 16:20:44
>>319

321:デフォルトの名無しさん
07/09/30 16:28:23
初めて家族でF1観戦をしてきたのですが、子供がバスの中でお漏らししてしまい
回りの皆様に迷惑をおかけしました、同乗していた方申し訳ありませんでした

322:デフォルトの名無しさん
07/09/30 16:30:36
>>321
最後のマッサやばかったなw
あれは伝説に残る

323:デフォルトの名無しさん
07/09/30 16:40:04
この流れは>>294を流そうとして必死なのか?

324:デフォルトの名無しさん
07/09/30 16:53:01
ビール 5000ペリカ
カキピー 3000ペリカ
オムツ 20000ペリカ


325:デフォルトの名無しさん
07/10/01 02:13:22
F1弁当 100000ペリカ

326:デフォルトの名無しさん
07/10/01 13:47:11
なぜここでゆでが

327:デフォルトの名無しさん
07/10/01 14:20:03
妙な流れで忘れ去られている >>250 だけど、
非負の値だけの場合
「二つの型において同じ値の表現は同じとする」(6.2.5 型)
負の値も含まれる場合
6.2.6 型の表現 の 6.2.6.2 整数型、により、負の値の表現は
処理系定義となっているので、結果は処理系定義

だと思う

328:デフォルトの名無しさん
07/10/01 21:28:59
6.5.3.2 アドレスおよび間接演算子
正しくない値がポインタに代入されている場合,単項*演算子の動作は,未定義とする。

適合しない型のオブジェクトへのポインタが正しくない値と考えるなら未定義という
こともできないかな?
(83)の注釈にいくつか正しくない値の例があるがこれがすべてだとは言っていないようだ。

329:デフォルトの名無しさん
07/10/09 18:51:48
内容:
作業時間48時間くらいで出来るC言語使った初歩レベルで作れるプログラムない?

都合よすぎかもしれないんだが、1年の節目としてなんか作れと先生に言われてるんだが
いい案がまったく出てこない、そういう例をまとめたサイトとかあれば最高なんだが。

330:デフォルトの名無しさん
07/10/09 18:53:34
ちとコピペミスった申し訳ないorz

内容は時間内に作れれば何でもいいです。

331:デフォルトの名無しさん
07/10/09 18:55:47
echod

332:デフォルトの名無しさん
07/10/09 18:57:58
>>329
学生の1年目なら hit&blow
社会人の1年目なら 住所録(最大件数はメモリの許す限り無制限、10万件程度のデータに対して検索1秒以内)
くらいかな?

333:デフォルトの名無しさん
07/10/09 19:39:45
>>330 >>1 を読め
>>331>>332 スレ違いに反応しない

334:デフォルトの名無しさん
07/10/09 20:52:49
指定されたディレクトリとその下層にあるファイルの中から
指定された名前の関数定義を探し当てるプログラムというのはどうかなッ

335:デフォルトの名無しさん
07/10/09 20:59:58
>>333
申し訳ない。
>>331>>332
ありがとうございます。

336:デフォルトの名無しさん
07/10/09 22:54:24
宿題スレに行って他人の宿題盗ってくれば?

337:デフォルトの名無しさん
07/10/10 00:13:55
後で苦労するのは俺だし授業で時間取ってくれてるからその時間暇になるわ。

338:デフォルトの名無しさん
07/10/11 14:26:34
main()
{
int i;
int a[2][10];

for( i = 0; i < 10; i++ )
{
a[1][i] = i;
a[2][i] = i;
printf("i=%d j=%d\n",a[1][i],a[2][i]);
}
printf("\n");
printf("i=%d j=%d\n",a[1][1],a[2][2]);
}

Visual C++ 2005 Express Edition です。
これをコマンドプロンプトを使ってコンパイルすると、
結果表示後「問題が発生したため・・・」のエラーがでます。
どこかおかしいところはあるでしょうか?

下のprintf文2つは実行確認用です。

339:デフォルトの名無しさん
07/10/11 14:33:04
>>338
>a[2][i] = i;
範囲外


340:デフォルトの名無しさん
07/10/11 14:40:34
「Visual C++ 2005 Express Edition です。」と断らなければいけない
レベルの質問は基本的にはこのスレの対象範囲外

341:デフォルトの名無しさん
07/10/11 20:52:46
まあ内容自体は処理系関係ないがな。

342:デフォルトの名無しさん
07/10/11 20:53:42
だからこそ環境を書く時点でわかってない事の証左

343:デフォルトの名無しさん
07/10/13 13:27:48
fopenで開いているファイルの大きさを切り詰める方法を教えてください。
一時ファイルとして使ってるんですが、自前のデフラグで前に積めた時、
後ろのゴミを消したいので。


344:デフォルトの名無しさん
07/10/13 13:40:08
「C言語」で引っかかるスレで質問できそうなのがここしか見つからないのが問題
限定的な話題扱うならスレタイ自重しろよボケが

345:デフォルトの名無しさん
07/10/13 13:54:09
なら、次スレからJISに合わせて「プログラム言語C」にするか

346:デフォルトの名無しさん
07/10/13 13:55:40
~なら俺に聞け がよくない。

347:デフォルトの名無しさん
07/10/13 14:19:14
初心者お断りってスレタイで明言すればいいじゃん。きっと過疎って誰も来なくなるよ。

348:デフォルトの名無しさん
07/10/13 14:24:04
C言語なら俺に聞け(入門編)があるのになぜそっちに行かないんだろう

349:デフォルトの名無しさん
07/10/13 14:26:15
>>343
マルチすんな。あっちで回答しておいた。

350:デフォルトの名無しさん
07/10/13 14:26:48
>>347
願ったり叶ったり。

351:デフォルトの名無しさん
07/10/13 14:54:40
>>348
全角厨しか引っかからないな
愛用のかちゅ~しゃで確認

352:デフォルトの名無しさん
07/10/13 15:10:16
>>351
JaneDoeViewだと引っかかるから気がつかなかったよ
じゃぁこのスレも全角にすれば問題解決だな

353:デフォルトの名無しさん
07/10/13 17:14:58
入門者のくせに「入門」で検索しないのか

354:デフォルトの名無しさん
07/10/13 19:43:13
「入門」で検索って、しないでしょw
言葉使う側のオナニー

355:デフォルトの名無しさん
07/10/13 19:49:16
ほんとスレ立て下手糞だね。
毎回こんな事で揉めるのは双方不愉快になるし時間の無駄。
このスレの存在自体迷惑だし削除した方がマシだよ。


356:デフォルトの名無しさん
07/10/13 21:09:55
お前が立てればいいんじゃね?

357:デフォルトの名無しさん
07/10/13 21:10:16
じゃ、[標準C限定、C++不可、初心者お断り]ってスレタイに明記しとけ。

358:デフォルトの名無しさん
07/10/13 21:13:36
テンプレも読まない連中だから無駄な気もするな

359:デフォルトの名無しさん
07/10/14 22:17:28
>>355
>このスレの存在自体迷惑だし
どんな迷惑を被ったのかkwsk

360:デフォルトの名無しさん
07/10/15 00:44:03
調子こいて答えたら、規格に基づいて袋叩きにされた

361:デフォルトの名無しさん
07/10/15 23:21:44
volatile int v1, v2;
int x = v1 + v2;

これは推奨できないらしいですが、
どういう理由なんでしょうか

どうやらvolatile変数の参照は副作用を持つかららしいのですが、
具体的にどのようなケースがあるのでしょうか


362:デフォルトの名無しさん
07/10/15 23:25:55
>>361
式 v1 + v2 の v1 と v2 のどちらが先に評価されるか不定だから。

363:デフォルトの名無しさん
07/10/15 23:37:50
言葉足らずでした
おっしゃる通り、評価順が不定なのはわかったのですが、

v = f() + g(); みたいなケースは
f()やg()内で副作用のある処理が行われたんだろうな~
(グローバル変数をいじってるとか)
と想像はつくのですが

volatile変数の場合,
v1とv2が評価順に依存しているケースがあるって事なんでしょうか
その具体例が思い浮かばないです



364:デフォルトの名無しさん
07/10/15 23:40:03
>361

ググりましたが、volatile修飾子はコンパイル時の最適化を抑制する修飾子とのこと
たぶん、排他制御の二重ロックなどの冗長に見える部分の最適化を止めたいのでは?
DOSのシングルスレッドなプログラムしか組んだことないからよくわからないが…

URLリンク(itref.fc2web.com)


365:364
07/10/15 23:41:50
質問の勘違いしてました。御免なさい
 m(_ _)m

366:デフォルトの名無しさん
07/10/15 23:46:52
#include <stdio.h>
#define N 5
int main(void){
int data1[]={1,3,5,7,10};
int data2[]={2,4,6,8,9};
int data3[]=0;
int i = 0;
int j = 0;
if (data1[i] >= data2[j]){
data3[i + j] = data[i];
i++;
}
if (data2[j] > data1[i]){
data3[i + j] = data2[j];
j++;
}
else return 0;
for (i=0;i<N;i++)
printf("%d",data3[i]);
return 0;
}

何がおかしいですか?

367:デフォルトの名無しさん
07/10/15 23:47:42
>>366
int data3[]=0;

368:デフォルトの名無しさん
07/10/16 00:13:38
>>367
どうすればいいですか?

369:デフォルトの名無しさん
07/10/16 00:19:25
>>363
未初期化の変数のロケーションを、必ず、読む、というコードが生成される、はず
規格では未初期化の自動変数を読んだ場合のふるまいはどうだっけ?

実際、どういう場合にまずいかというと
処理系(ここで言う処理系にはOS以下メモリやプロセッサまで含む)によっては
プロセスが、まだ書いたことのないロケーションを読もうとすると、メモリの
ゴミあさり(他のプロセスがパスワードとかを残してたりするの探す)と判断されて
例外で落とされるかもしれない、とか

370:361=363
07/10/16 00:22:31
あぁぁぁすいません
変数は初期済みという前提でおながいします

371:デフォルトの名無しさん
07/10/16 00:23:05
>>368
int data3[N]={0};
他にもおかしいところがあるかもしれないけど見てない

372:デフォルトの名無しさん
07/10/16 00:26:17
>>363
volatileオブジェクトは例えばプロセッサの内蔵タイマのようなリアルタイムに値の変化するものを指しているかもしれない。

373:デフォルトの名無しさん
07/10/16 00:27:16
ありがとうございます。
そこを直してもまだ1つエラーがありました。
data3[i + j] = data[i];
ここらしいです

374:デフォルトの名無しさん
07/10/16 00:27:36
>>363
メモリマップド I/O だな。読んだだけでチップの信号が変わるとか。

375:デフォルトの名無しさん
07/10/16 00:28:33
>>373
エラーメッセージ嫁。
読んで分からなかったらエラーメッセージ添えて聞け。
ここはエスパーごっこするスレじゃない。

376:363
07/10/16 00:29:41
>>372
>>374
なるほど。ハードウェア絡みですね

確かに読むだけでデバイスの状態が変化する可能性がありますね

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

377:デフォルトの名無しさん
07/10/16 00:31:43
>>375
すみません。
エラー E2451 babble.cpp 10: 未定義のシンボル data(関数 main() )
だそうです。

378:デフォルトの名無しさん
07/10/16 00:34:28
>>377
dataは1~3だろ、無印は無い
たぶんdata3[i + j] = data1[i];

379:デフォルトの名無しさん
07/10/16 00:38:27
>>377
なんでそこまで言われて気づかないんだ?

380:デフォルトの名無しさん
07/10/16 00:40:35
BCC はこれがコンパイルエラーじゃなくてリンクエラーになるのか。恐ろしいな。
っていうか悪いことは言わないから VC++ 2005 EE か Cygwin GCC にしとけ。

381:デフォルトの名無しさん
07/10/16 00:42:08
いくらBCCでもコンパイル通らないだろ

382:デフォルトの名無しさん
07/10/16 00:43:00
完全な見落としですね…
すみません。ありがとうございました

383:デフォルトの名無しさん
07/10/16 00:58:14
>>371

Cの配列は自動で領域拡張してくれないからdata3のメモリ領域は必ず確保することが必要だと。
data3[] = {0};
だとdata3の配列の長さは1です。今のままだと条件によってはバッファーオーバーランします。


384:デフォルトの名無しさん
07/10/16 01:10:34
たまたま質問が標準C以内のものだったら回答してるって感じだな
>>366なんか標準Cと何の関係もない、ただのデバッグ依頼だろ
ちゃんと切り分けろよ

385:デフォルトの名無しさん
07/10/16 01:10:34
>>383
Nがわざわざ定義してあるだろ

386:デフォルトの名無しさん
07/10/16 01:20:08
>>371
現状の結果は data3[] = {3,*,*,*,*};
となる。*部は未定義かつ異常アクセス。
このデータの場合読み込みしかしていないが
二つのif条件が共に満たされている場合始めの*に書き込み
Windouwsなら共有違反のエラーダイアログが出て強制終了されると思います。



387:デフォルトの名無しさん
07/10/16 01:24:34
突っ込むの面倒だし放置でいいかな?

388:デフォルトの名無しさん
07/10/16 01:27:28
なんでいきなりBCC

389:384=386
07/10/16 21:29:10
一つ見落としてました御免なさい…

390:デフォルトの名無しさん
07/10/23 23:39:29
ぬるぽ

391:デフォルトの名無しさん
07/10/23 23:56:21
ガッ

392:デフォルトの名無しさん
07/10/25 02:01:37
int a = -1;
unsigned int b = a;
こうするとbは標準Cならどんな環境でもUINT_MAXになるんですが

unsigned int b = (unsigned int)a;
こうした場合って、このキャストは
(1)aのビットパターンを無理やり unsigned int として解釈するのか (C++のreinterpret_cast)
→負数の表現が2の補数なら UINT_MAX
 1の補数なら UINT_MAX-1
 絶対値と符号フラグなら…いくつだ?

(2)aをunsigned int に変換するのか (C++のstatic_cast)
→環境によらず UINT_MAX

どっちでしょうか?
あいにく手元には負数の表現方法が2の補数の環境しかないので、確かめられません

393:デフォルトの名無しさん
07/10/25 02:06:39
って、>>189に書いてある説明文に思いっきり
(unsigned int)-1 って書いてあるな…

394:デフォルトの名無しさん
07/10/25 02:16:57
>>392
C の話は解決したとして、 C++ の reinterpret_cast の理解が間違ってる。
reinterpret_cast で int → unsigned int の変換はできない。
reinterpret_cast による変換結果はすべて実装依存。ビットパターン云々とは言えない。

395:デフォルトの名無しさん
07/10/26 12:00:55
>>364 volatile修飾子は、組み込み用プログラムでは多用するな。

    最適化では、値を読むことしかしてない変数は無駄なコードとして
   削除されてしまう。
   
    しかし、メモリマップドI/Oでは、I/Oのレジスタ類は変数として
   定義され、その内容の変化のみをチェックする処理は多い。 その様な
   変数には、volatile修飾子をつけないと最適化で消されてしまって
   処理が実行されない。 Cソース上では存在するが、機械語コードでは
   存在しなくなっている。 これを防止するのが主な使い方だな。


396:デフォルトの名無しさん
07/10/26 14:43:41
>>395
それで思い出したがCPU自体にアトミックな操作ができない物があり、
そういうCPUではvolatileを完全に実現出来ないと聞いた。

具体的には16ビットCPUで32ビット変数を扱うと完全なvolatileには
ならない。16 + 16に分けて2回読み書きするためで、その間に割り込み
が入って内容を変更されてもCPUはそれに気づけない。

397:デフォルトの名無しさん
07/10/26 16:52:48
>>396
>volatileを完全に実現出来ない
それは適当な表現じゃないなぁ。
単にvolatileではアトミックかどうかを意識できないだけの話だと思うんだ。
volatileがそれを保証する修飾子じゃないんだから実現できないってのとは違うでしょ。

398:デフォルトの名無しさん
07/10/26 17:12:01
>>397
§6.7.3.6
An object that has volatile-qualified type may be modified in ways unknown to the
implementation or have other unknown side effects. Therefore any expression referring
to such an object shall be evaluated strictly according to the rules of the abstract machine,
as described in 5.1.2.3. Furthermore, at every sequence point the value last stored in the
object shall agree with that prescribed by the abstract machine, except as modified by
theunknown factors mentioned previously.114) What constitutes an access to an object that
has volatile-qualified type is implementation-defined.

確かに実装依存と書いてあるね。しかしアトミックである事を保証できないのならvolatile修飾子の意味は
無い事になってしまう。規格には保証されてなくても実際volatileをそのような目的に使うなら、CPU固有の
振る舞いを知っておく事は非常に重要なはずだ。

399:デフォルトの名無しさん
07/10/26 17:30:16
主旨には同意するが

> アトミックである事を保証できないのならvolatile修飾子の意味は
> 無い事になってしまう。

これは言い過ぎ。例えば
volatile x;
x = 2;
x = 3;
の x = 2; が実行されることが保証されること等、
アトミシティ以外にも存在する意味はある。

400:デフォルトの名無しさん
07/10/26 17:57:20
ベンチでCPU側にとって無意味なループを省略させないとかかね

401:デフォルトの名無しさん
07/10/26 18:43:50
>>400
保証されない。
xが32bitだとして16bitのCPUなら、上位16ビットを代入した直後に
割り込みが入って上位16ビットを書き換えたらもうダメ。

402:デフォルトの名無しさん
07/10/26 18:44:18
×>>400
>>399

403:デフォルトの名無しさん
07/10/26 21:02:16
アトミックとvolatileは全然違う概念だと俺は信じてたけど…?

>>401
>>399は別に、xに2が設定されることが保障されると
言ってはいないと思う。

404:デフォルトの名無しさん
07/10/26 21:30:30
すると。

int X
X = 1+1;
dly_tsk(100); /* ウエイト */
if(X==2)
これはXは必ずしも真とはいえないのと同じか・・・?(割り込みで値なんていくらでも変更できるので)
volatileは最適化の抑止であって値の保証とは違うと思うが。
それともなんか俺、頭がおかしいのか?

最適化といえば、よくあるのがF-ROMのライトシーケンスやイレースシーケンスとかなんか同じアドレスに0xAAだの0x55だの書くから
最適化されるとうまく動かなくなるね。

ちなみに組み込みをやるとハードがらみで泣かされることがしばしば。
センサ情報で何度泣かされたか。ノイズで何度泣かされたか。静電気で・・・

405:デフォルトの名無しさん
07/10/26 21:31:10
setjmpとallocaって、呼び出しの前後順によってはlongjmpが
おきた時に何か問題おきるかな?

406:デフォルトの名無しさん
07/10/26 23:03:52
自信を持っては言えないのだが、多分volatileがあることで、
(処理系の詳細ではなく仕様で定められたセマンティクスの範囲内でも)
実装可能になる並列データ構造とかは存在するんではなかろうか?

407:デフォルトの名無しさん
07/10/26 23:11:46
ハードの熱で泣かされたことが……

408:デフォルトの名無しさん
07/10/26 23:15:14
>>405をおながいします。
allocaでずれたスタックポインタlongjmpで先祖がえりしてしまうような
ことは無いのか、どうなんでしょう?

409:デフォルトの名無しさん
07/10/26 23:15:59
スタックポインタ「が」longjmp

410:デフォルトの名無しさん
07/10/26 23:24:37
>>401
そんなあなたに sig_atomic_t

411:デフォルトの名無しさん
07/10/26 23:28:54
allocaがなんなのか知ってる?

412:デフォルトの名無しさん
07/10/26 23:33:53
void *p;
int result;

result = setjmp();
if (!result) {
 p = alloca(256);
 hoge(); /* hoge calles longjmp, NO RETURN */
 /* NOT REACHED HERE */
}

/* ここで p の指す先は大丈夫か? */

ということ?

413:デフォルトの名無しさん
07/10/27 00:21:05
>>412
そうそんな感じです。C言語として保証されてるのかな?と
ふと思ったので。

414:デフォルトの名無しさん
07/10/27 00:39:46
allocaは標準Cで既定されている関数ではないから、実装依存としか言いようがない。

415:デフォルトの名無しさん
07/10/27 00:40:12
alloca は C の標準関数じゃないので・・・

416:デフォルトの名無しさん
07/10/27 00:45:12
ああそうなんだ。知らなかったっす。どうもありがとう。

417:デフォルトの名無しさん
07/10/27 01:48:57
>>410
それがはC標準関数ではない
標準ではない型を別途定める必要があること自体C標準ではできないことの証明

418:デフォルトの名無しさん
07/10/27 02:26:56
sig_atomic_t は <signal.h> で定義されてる ANSI C 標準の型ですが何か?

419:デフォルトの名無しさん
07/10/27 02:45:54
関数ではないなw

420:デフォルトの名無しさん
07/11/05 22:32:44
規制中につき携帯から失礼します。
2バイト文字の文字コードを持つint型の変数があるときに
この変数の文字コードに該当する文字を取得しようとしたのですが
char型にぶちこもうとしたら1バイトずつに分けられて格納されて、wcharを使っても分けられてしまうようなのですが
どうにか2バイトまとめて一つの文字コードだと判断させる方法はないでしょうか?

421:デフォルトの名無しさん
07/11/05 22:37:42
Java の char と違って、ふつ~ C の char は 8 ビットだからどうにもならない

422:デフォルトの名無しさん
07/11/05 22:40:31
sage忘れたorz

423:デフォルトの名無しさん
07/11/05 22:52:09
>>419
フイタw

424:デフォルトの名無しさん
07/11/05 22:58:14
>>420
何言ってるのか良く分からん。

>wcharを使っても分けられてしまうようなのですが
この部分を検証したコードと実行結果plz

425:デフォルトの名無しさん
07/11/06 00:29:42
scanfを使って整数型の変数に1~100の値を入力された時のみ
続く処理をして、それ以外は再度入力を促すプログラムを作ってます。

入力された値のエラーのチェックにはどんな処理が必要か
わからないので教えてください。

あと数値を入力してEnterを押して実行したあとに
前回入力した数値が残ったままになっているのを
消すにはどうすればいいですか?

426:425
07/11/06 00:32:34
スレ間違いすいません
初心者いってきます

427:デフォルトの名無しさん
07/11/11 14:29:16
typedef struct _target

428:デフォルトの名無しさん
07/11/11 14:42:22
>>427 そんなところに予約識別子使うやつ死ねって思う。

429:デフォルトの名無しさん
07/11/11 19:55:32
>>428
構造体タグは独立した名前空間だから別にいいんじゃね?
C++に移植したときにはまらないとも限らんが。

430:デフォルトの名無しさん
07/11/11 20:09:22
ダメなんだぜ。
7.1.3 Reserved identifiers
> - All identifiers that begin with an underscore are always reserved for use as identifiers
> with file scope in both the ordinary and tag name spaces.

431:デフォルトの名無しさん
07/11/15 10:35:25
>>430
俺が訳してやるぜ

アンダースコアから始まる識別子を使うな、どアホ

432:デフォルトの名無しさん
07/11/15 12:01:23
スレリンク(tech板:328-334番)
> 加減演算子
>
> ポインタオペランド及びその結果の両方が同じ配列オブジェクトの要素、又は
> 配列オブジェクトの最後の要素を一つ越えたところを指している場合、演算に
> よって、オーバーフローを生じてはならない。それ以外の場合、動作は未定義
> とする。

これ見て思ったんだけど、たとえばメモリ空間がアドレス 0x0000-0xffff の環境で、
メモリ空間の終端 16 バイトに char a[16] が割り当てられて a が 0xfff0 を指す場合、
a + 16 は 0x0000 に対応することになると思うんだ。で、さらにその実装が 0x0000 を
ヌルポインタとしていた場合、 a + 16 == 0 が真になるようなことがあるかもしれない。

これはオーバーフローっぽいから配列をそんなところに割り当てないようにしないと
いけないのかもしれないけど、実際のところ a + 16 はオブジェクトを指す必要がないから
ヌルポインタになったところで問題ないのかもしれないとも思う。

配列の最後の要素を一つ越えたところを指しているポインタがヌルポインタと
等しくなるような実装って、規格の範囲内なのかね?

433:デフォルトの名無しさん
07/11/15 12:15:14
だめなんじゃない?

6.5.8 Relational operators の 5
>If the expression P points to an element of an array object
>and the expression Q points to the last element of the same array object,
>the pointer expression Q+1 compares greater than P.

char a[16] に対しては a < a+16 が成立しなきゃいけないらしい

434:デフォルトの名無しさん
07/11/15 12:29:14
効率の面から全然現実的じゃないけど、大小比較においてはぬるぽを特別扱いして
最強としておけば a < a + 16 の要件は満たせる。明示的なぬるぽとの比較は
未定義動作だから、これによって規格から外れるということにはならない・・・かなり苦しいな。

435:デフォルトの名無しさん
07/11/15 12:40:35
ってことは、アドレス 0 をヌルポインタに使っている実装で、 ROM や RAM が
アドレス空間の終端にあるようなときは、ちょっと気をつけて終端ぴったりにオブジェクトが
配置されないようにする必要がある、ってことになるのかな?

リンカに指示するマッピングで終端1ワード(バイト?)ぐらい予約にしてやればいいのか。

436:デフォルトの名無しさん
07/11/15 18:22:24
>>434
>432のメモリモデルでユーザメモリ空間が0x8000以上なら、
ポインタ演算を符合付き整数で行なう実装ができそうだ。

437:デフォルトの名無しさん
07/11/15 21:26:34
いかれた規格野郎のために、これでまともに動作すれば規格合致で portable なことが保証できる、規格の限界を極めた変態処理系とかできないもんかな。

438:デフォルトの名無しさん
07/11/18 00:07:49
#include <stdio.h>
int main (void)
{
int a,b;
scanf("%d",&a);
scanf("%d",&b);
printf("2番目の数みたい%d1番目の数みたい%dこれはどこ?%d");
return 0;
}
printfの%dはいったいどうった仕様でよまれているんでしょうか?

439:デフォルトの名無しさん
07/11/18 00:15:32
URLリンク(www.linux.or.jp)

440:デフォルトの名無しさん
07/11/18 00:19:39
>>438
printfの%dは、何を表示したいか最後に引数で指定しないとだめ

printf("2番目の数みたい%d1番目の数みたい%dこれはどこ?%d", a, b, 42);

441:デフォルトの名無しさん
07/11/18 01:10:04
>>439>>440
どうもです。
よくわからんかったんですけど、stdinのなかでも読んでるのかな?
いつもは書式("%d",a)見たいな感じで使ってるんですけど、
前問題で
scanf("%d",&a);
printf("あなたが入力したのは%dです");
があって、aの値が出力されたのでなんでだろうと思って聞いてみました。

442:デフォルトの名無しさん
07/11/18 01:39:09
未定義動作なので、単なる偶然。
たぶんスタックが関係してるとおもうけど。


443:デフォルトの名無しさん
07/11/18 11:11:03
> よくわからんかったんですけど、stdinのなかでも読んでるのかな?

違います。第2引数以降に順番に対応します。%d に限らずみんなそうです。
>>440 の例をよく吟味してみてください。

> 前問題で
> scanf("%d",&a);
> printf("あなたが入力したのは%dです");
> があって、aの値が出力されたのでなんでだろうと思って聞いてみました。

の答えが >>442 で、何かの問題としてそういうプログラムがあったのだったら、
それは誤植かバグ。

444:デフォルトの名無しさん
07/11/20 12:26:52
10から99までの10進数の数値を1の桁と10の桁に分けたい場合
どうすればいいでしょう?

例えば56を5と6に分けたい場合、どうすればいいのでしょう?

445:デフォルトの名無しさん
07/11/20 12:28:12
56 / 10 → 5
56 % 10 → 6

446:デフォルトの名無しさん
07/11/20 12:36:56
long型なんですが・・・

447:デフォルトの名無しさん
07/11/20 12:37:44
あっ間違えました。ありがとうございました

448:デフォルトの名無しさん
07/11/20 12:48:28
↑のような質問のスレではないので次の質問を書く人は注意

449:デフォルトの名無しさん
07/11/20 15:42:08
>>448
これがゆとり世代と言うもの


450:デフォルトの名無しさん
07/11/23 14:20:32
予約識別子について質問です。
今までは
・下線 _ で始まり英小文字 a-z が続く一般識別子は global namespace で予約済み
というルールから、
type_t function( type_t _parameter ){ return _parameter; };
のような仮引数名は予約識別子ではなかったはず(FAQでも同様の回答)なのですが、
「C99 では Reserved identifiers が『マクロ名を含む』になったから global namespace で #define _paramete されてたら仮引数名も上書きされない?」
と指摘されました。
恥ずかしながら、規格を読んでみても具体的に何が変わったのか私には分かりませんでした。

「今後は避けられるなら避けた方がよい」のは前提として、
既にある _parameter のような仮引数名は今でも安全なのでしょうか?

451:デフォルトの名無しさん
07/11/23 14:33:26
処理系が _parameter というマクロを定義可能になったから、
処理系が _parameter というマクロを定義していた場合に
その引数の _parameter という部分が置き換えられるかもしれない、
という話じゃね。

C99 に対応してないだろう ANSI C/C++ 辞典を見ると、
下線で始まるマクロ名は全て予約識別子らしいから、
今でも問題があるかと。

下線を付ける場合は、普通後ろに1つだけ付ける。

452:デフォルトの名無しさん
07/11/23 15:06:34
>>450
規格の範囲内で問題ないかといえば、問題ない。 >430 にあるように、タグ名を含む
ファイルスコープの識別子として予約されていて、マクロにも使える下線+英大文字とは
区別されている。

ただし、そういう指摘を受けて規格の詳細を見直さないと自信が持てないような
状況を避けるため、はじめから下線始まりの識別子を使わないようにしたほうがいい。

453:デフォルトの名無しさん
07/11/27 15:48:32
C言語ってさ、他のソースに定義してある関数とか引数ちがってmainの中で使ってもコンパイルエラーださないじゃん。

あと、まったく未定義な関数つかっても他のソースにあるかもしれないからとかいう理由でコンパイルエラーだしてくれないじゃん。
とても不便だよね。

なんで、コンパイラはそれくらいのことをしてくれないのかな?別に面倒じゃないと思うんだけど。

454:デフォルトの名無しさん
07/11/27 15:57:06
>>453
大抵のまともなコンパイラなら、(宣言が見つからないと言う理由で)警告を出してくれると思います。
尤も、中にはデフォルトではその警告を出さないコンパイラもありますが。

詳しいことは、それぞれのコンパイラのスレなどでどうぞ。

455:デフォルトの名無しさん
07/11/27 16:03:46
>>453 のような話題のためのスレではないので次の質問を書く人は注意

456:453
07/11/27 16:14:35
>>454 thx 俺のコンパイラがいけんのか。そうか。

やっぱ高いのじゃないとだめだね。なんでも。貧乏人は苦労するよ。

>>455 C言語のコンパイラ全部そうだとおもってたんだよ。俺はトウシロウだから。

457:デフォルトの名無しさん
07/11/27 16:24:38
>>456
ここはコンパイラの使い方のスレではないので程々に。
今無料で利用できるコンパイラの多くが警告を出せると思うので、調べてみてください。

458:デフォルトの名無しさん
07/11/27 16:51:26
gccなら-Wall つけとけ

459:デフォルトの名無しさん
07/11/27 20:47:25
本当はリンカの仕事だからな

460:デフォルトの名無しさん
07/11/28 00:49:19
リンカにその情報は渡らんだろ。渡せるように作れるが。

461:デフォルトの名無しさん
07/11/28 07:14:08
>>460
Cの関数はデフォルトだと内部リンケージだったっけ?

462:デフォルトの名無しさん
07/11/28 10:45:04
いいえ。

463:デフォルトの名無しさん
07/11/28 20:12:34
strcpy と wcscpy のようにアルゴリズムが殆ど同じだが扱う型・定数が微妙に違う関数を同時に実装する必要があるとします。
実装しなければならない数は 2~3 型 x 30~40 関数ぐらいとします。

このような場合、

/* strcpy.cpp */
char *strcpy( char *dst_, const char *src_ ) {
char *head = dst_; while( '\0' != (*dst_++ = *src_++) ){ /* nop */; } return head;
}
/* wcscpy.cpp */
wchar_t *wcscpy( wchar_t *dst_, const wchar_t *src_ ) {
wchar_t *head = dst_; while( L'\0' != (*dst_++ = *src_++) ){ /* nop */; } return head;
}

と一つづつ同じような関数を書いていくのと

/* fallthrough */

464:デフォルトの名無しさん
07/11/28 20:13:12
アルゴリズムだけ書いた

/* template/strcpy.cpp */
#ifdef XCS_IS_CHAR
#define char_t char
#define xcscpy_ strcpy
#define text_( text ) text
#endif

#ifdef XCS_IS_WCHAR
#define char_t wchar_t
#define xcscpy_ wcscpy
#define text_( text ) L ## text
#endif

/* strcpy, wcscpy */
char_t *xcscpy_( char_t *dst_, const char_t *src_ ){
char_t *head = dst_; while( text_('\0') != (*dst_++ = *src_++) ){ /* nop */; } return head;
}

のようなテンプレートを用意して

/* strcpy.cpp */
#define XCS_IS_WCHAR
#include <template/strcpy.cpp>

/* wcscpy.cpp */
#define XCS_IS_CHAR
#include <template/strcpy.cpp>

と読み込ませるので、どちらが良いと思いますか?
あるいは、もっと良い方法がありますか?

465:デフォルトの名無しさん
07/11/28 20:16:38
ちなみに発想は VC++ の crt のソースからです。

>>464 の訂正 /* ファイル名が逆 */

/* strcpy.cpp */
#define XCS_IS_CHAR
#include <template/strcpy.cpp>

/* wcscpy.cpp */
#define XCS_IS_WCHAR
#include <template/strcpy.cpp>


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