C言語なら俺に聞け 142 [無断転載禁止]©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
>>776
フラグ以外での除去方法もないのでしょうか?
大量にでるために困っています >>777
警告は、引数リストの外側で必要なものを宣言すべきという意味だ。 https://ideone.com/91sohX
へぇ 構造体のポインタだし通しそうだけど警告出す仕様なのか
(3行目 実体は不明だけど構造体のポインタを受け取るぞ宣言で警告) 関数の前にstruct aho;とでも書いておけ。 >>778
原因はわかっています。
構造体宣言を別のヘッダーで行っているにもかかわらず、
プロトタイプ宣言しているヘッダーより上に定義がないのが原因です
>>780
gcc -w ?
#pragma GCC diagnostic ignored "-w" でしょうか? 本当の定義じゃなくて 仮定義を前に置くだけで消えるのな
struct foo;
void func(struct foo* arg); >>783
やはりそのように潰していくしかないのでしょうね。 >>782
-Wで始まるオプション名は無いので無視するにはコマンドラインで-wを指定するしかない >>784
いや、てか、そのヘッダ書き換えられないのか? 自身のポインタを構造体に宣言するのと同じ様に書けよ。 とりあえず勉強の成果として作ってみたら失敗した
なんでだ
#include <stdio.h>
int main(void)
{
int hyoji;
int kakikomi;
printf("階乗の表示:");
scanf("%d\n",&kakikomi);
for (hyoji = 1;kakikomi > 0;kakikomi--) {
hyoji = hyoji * kakikomi;
}
printf("結果は%dです", hyoji);
fflush(stdin);
getchar();
return 0;
} >>789
scanfのところの\nって要らなくね こんなすぐに桁溢れしちまう様なサンプル作ったら、何を試したいのかわからんだろ。 しかしてfor文の中身を見るに全くの素人じゃあないな 初期化をあんなとこに書いたらコーディング規約で叩かれるしなぁ〜 >>794
forのカッコ内には同じ変数しか書いちゃダメって思ってる初心者はいるかも
個人的には変数名からCOBOLer疑惑の方が強い気がする VS2017でやってるんだがさっき作ったプログラムを保存して別のファイルで勉強を再開しようとして新しくファイルを作ったんだ
そしてテストも兼ねてさっきのプログラムコピペしたら
プリコンパイルヘッダーを検索中に不明なEOFが見つかりました。
'#include"stdafx.h"をソースに追加しましたか?
と出た
さっきは何もなかったのに >>797
それな
よく分からんけど空のプロジェクトってやつでプロジェクト作って自分でソースファイル作成すれば出てこない
まあ詳しい人が教えてくれるかも >>797
プリコンパイルヘッダーというのは、プロジェクト内のヘッダーを事前にまとめてコンパイルしてビルドを早くする仕組みのことだ。
通常、stdafx.hというヘッダーにプロジェクトで使うヘッダーをまとめる。
一つ一つのソースファイルごとのプロパティでプリコンパイルヘッダーを作成するか、使用するかを設定できる。 ソースコード関係の知識は苦Cやらで積めるけどソフトやらの知識はどこで積むんだ プリコンパイルヘッダーを使用するのであれば、プロジェクト内のどこかのソースファイル(例えばstdafx.cpp)を使って、プリコンパイルヘッダーを作成しないといけない。
あるソースファイルにおいてプリコンパイルヘッダーを使用するのであれば、プリコンパイル対象のヘッダーを#includeして、そのソースファイルがプリコンパイルヘッダーを使用することを設定する。
プリコンパイルヘッダーを使用しないなら、すべてのソースのプロパティでプリコンパイルヘッダーを使用しないように設定する(空のプロジェクトの規定値)。 ソースファイルが二、三個なら、とくにプリコンパイルヘッダーは、必要ない。 >>800
おとなしく>>798の言う通りにしろってこと ソースファイルのプロパティは、IDE内のソースファイルのアイコンを右クリックして「プロパティ」を選ぶと設定できる。 >>804
とりあえず空のファイルは作れたけどソースが書けん 新しいプロジェクト
↓
空のプロジェクトを作成
↓
空のソースコードファイルを追加
↓
>>789をコピペ
↓
実行 >>807
空のソースコードファイルどうやって作るんだ >>808
プロジェクト開いたときの右にあるソリューションエクスプローラの中のソースファイルというフォルダを右クリックして「追加」から「新しい項目」をクリック。
「C++ファイル」を選択した状態でファイル名の拡張子を.cに変えて「追加」ボタンを押す。 >>809
できた
もしこれから新しくファイルを作る場合はこれを一からやるのか? >>810
うん。
簡単なプログラムならVSでプロジェクト作るよりもスタートメニューのVSのフォルダの中にある開発者コマンドプロンプト使ってclコマンドでコンパイルした方が手軽だな >>812
ありがとう
これ以上はスレチだからやめておこう スレチかもしれないけどVS2017でANSI C(C99/98, ブロック先頭でしか宣言できないやつ)だけしかかけないようにできますか? みなさんは関数名の後に続く中括弧の前に改行を入れますか?入れませんか?
例えば、
int main(void) {
/* 処理 */
}
のようにするか、
int main(void)
{
/* 処理 */
}
のように書くのか、どちらが多いのか気になります。 if ()
{
}
ならいいけど
for () {
}
だと整合性無いじゃん
って話なら気にするな
だな >>815
改行入れるね。
なんでそうなったかというと、C言語は昔は引数の型をカッコ内に書けなかった。つまり
int main(argc, argv)
int argc;
char *argv[];
{
・
・
・
return 0;
}
のようにしか書けなかった。その当時から覚え始めたというのと、K&R もそれで書いて
あったのでそのまま何も考えず俺の中で改行入れるのが定着した。 for()
{
}
こうしたときに一行増えるから嫌だだっていう人が多そうだな 関数では改行して、制御構文では改行しない
みたいなオレルールにしてる c#みたいにメソッドを直接鉤括弧内にベタ書き出来る言語でもなけりゃ先行改行一択なんだがなあ 今みたいに時間単価での清算が主流になる前は、
ステップ単価清算ってのもあって、K&R以外で書くと
増量しているって言われていたの。
cb とか indent なんてコマンドはその名残かな >>826
無名関数が書けると最初の { 前の改行がおかしい気になるので
自動的に改行入れない派になるという話では? >>815
統計取る方法がないから、確実な答えはわからないと思うよ。
で、戦争のたびに出る結論が「気にするな」「仕事環境に従え」なんだよねー。
で、俺はどうかと言うと、俺も不思議と>>823に落ち着いた。 http://9cguide.appspot.com/15-05.html
これのモードの切り替えってところで判定結果違うんだが俺だけ?
pがでたらめな数字になる
コピペしても変わらなかったから多分タイプミスとかじゃないと思う 下の[実行結果] のように出力されるためには
× printf("p = %d\n",p);
○ printf("*p = %d\n",*p);
でないとな 10 1
scanf("%d%d", a, b);
こう読み込んだ時に空白を飛び越えて読み込んでくれるん?
10,1
この時はエラーになっちゃう? 多分空白はできる
,を入れたかったら%d,%dすれば多分できる scanfのフォーマット指定は面倒だぞ
正直使いこなす気すらない if () {
}
else {
}
このフォーマットだと心が平和 >>828
うん、さっぱり分からん
そもそも鉤括弧って「」だし。 >>837
入力が決められてなかったらscanfじゃあできないからわかるわー >>827
バージョン管理、コーティング規約対応用だろ
空白文字の使い方に無頓着なカスが存在する限り必須 本買うお金がないのですが公式なドキュメントってどこで見れますかね? C言語の仕様は規格が決まってるから、調べれば幾らでもネットに落ちてるんだがなぁ〜 ランタイムライブラリやプラグマやデファインの事なら使ってるコンパイラにドキュメントがあるだろ? ネスティングを気にするかどうかは各自のスタイルによる
気にならない書き方はいくらでもできるし
ファイル分割がいやでべた書きする奴はネスティング気にするだろ どう思う?
#include <stdio.h>
void test(a, b, c)
int *a;
int *b;
int *c;
{
*c = *a + *b;
}
int main(void)
{
auto register int a;
auto register int b;
auto register int result;
a = 10;
b = 32;
test(&a, &b, &result);
printf("%d + %d = %d\n", a, b, result);
return 0;
} ネスティングが浅い記述しか書かない奴にとってはどうでも良い案件なんですよ
技術計算を多用するコード例だとネスティングちゃんとしないと分けがわからなくなる >>852
コンパイラは要素数を数えられるから
(要素数を数えられない場合は省略できない) 配列は何次元でも扱える代わりに中身の管理は利用者に一任されたんだ。 >>853
配列の宣言の時です。
省略してはいけないのはどういう場面ですか? >>856
× int ary[];
○ int ary[] = {1,2,3}; >>850
どうも思わない。
ま、 register はコンパイラが無視するんだろうな。 >>850 すごく… 古くさいです…
それはともかく register 宣言した変数は
アドレス取ろうとした時点でコンパイルエラーじゃなかったかな?
あと俺の環境では auto と register の同時指定がダメと言われる。
古いコンパイラだとどっちも許されるんだっけ。 実装は知らんが、言語仕様だと昔からstorage classの指定は1つだけ registerは可能ならばレジスタに割り当てると言う意味なので、アドレス演算子を使えばレジスタに割り当てられない
利用可能なレジスタ数を超えてregisterが使われうる可能性を考えれば明らか
autoとも併用できないし、半可通としか言いようがない >>863
言いがかりをつけたいなら「規格書のxxにこう書いてある」と調べてからつけろ >>862
の前半、register変数のアドレスを取ろうとすると
gccもclangもエラーになるけど、これは規格違反と? 仕事で5年くらいMATLABやってたけど来月からC言語やらなあかん
難しそうで、もうイヤイヤ期よ
C なんて10年くらい前に大学の講義でチョロチョロってやっただけ
応援メッセージ待ってます!
(´;ω;`) >>866
Visual Studioでもエラーになる
まあ当然だわな >>864
規格書の
6.5.3.2 Address and indirection operators
に
The operand of the unary & operator shall be either a function designator, the result of a [] or unary * operator, or an lvalue that designates an object that is not a bit-field and is not declared with the register storage-class specifier.
こう書いてある K&Rの1stでも
the address-of operator & cannot be applied to them.
って書いてあるよ 俺にはレジスタ変数に割り当てた変数を関数のアドレス渡し引数にする意図が想像できない。
そんなにオーバーヘッド気になるなら、グローバル変数でレジスタ変数宣言してしまえって思う。 >>872
外部宣言にregisterは使えないぞ オーバーヘッド気にしてたらコンテキストスイッチングとかどうすんだ? じゃあそんなクリティカルな問題無い様に、関数化する事自体を諦めた方がいいのでは? ヘッダーファイルにインライン宣言した関数を記述してしまうって解決方法もあるよな? ■ このスレッドは過去ログ倉庫に格納されています