C言語なら俺たちに聞け パート0001
■ このスレッドは過去ログ倉庫に格納されています
scanf の戻り値は、フォーマットに従い変数に代入した個数
1変数ならまあ好きに書けば良いけど
2変数以上の時に間違わないよう習慣付けているのかもしれない 入力文字がアルファベットしかなくて vに整数をつっこんでねーよ って時は
1 にならない C言語初心者です。
windows7
MinGWのgccバージョン4.8.1です。
/*スタート*/
#include <stdio.h>
int main(void){
float pai,r,s;
printf("半径を入力してください=");
scanf("%f&r");
pai=3.14159;
s=pai*r*r;
printf("面積は%fです\n",s);
return 0;
}
/*終わり*/
円の面積を求めるプログラム作りました。コンパイルするのはうまくいくんですが、実行して半径を入力すると○○○.exeは動作を停止しました。とエラーダイアログが表示され結果が出力されません。
何が原因でしょうか? >>468
scanf("%f&r");
ではなくて、
scanf("%f",&r); よくわからんけど、gcc 拡張の警告でチェックしてくれんの?
フォーマット文字列 と 渡した引数数の不一致 >>468
のプログラムをgcc 4.8.1でコンパイルしたら
エラーメッセージは出なくて、実行したら
当然ながら、面積の値が0.000000と誤まった
値が出てきた。
エラーメッセージが出ないのが不思議。
オプションを付ければ、エラーメッセージがでるのだろうか int scanf(const char *format, ...)
int printf(const char * restrict format, ...);
そういうことで。 >>469
ありがとうございます。
実行することができました。 >>471
stdio.hを追っかけていけば、
int scanf(const char *format, ...);
int printf(const char *format, ...);
のようにprintfと同じ形であることがわかる。
printf("hoge");
がエラーでないように
scanf("hoge");
もエラーとはならない。
ただgccは賢くて -Wall をつけると、
formatの中身を解析して警告を出してくれる。(printfも同様) googleでgccのコンパイルオプションについて検索すると
検索結果がゼロになることが何度かあった
ちなみに
gcc -オプション名
みたいな感じ検索してた
どうもman gccの最初の数ページしかgoogleに登録されてないっぽい挙動なんだが google で検索キーワードの前にマイナス記号がついてると、
そのキーワードを含む検索結果を除外する (いわゆるマイナス検索) ようになってるので、
オプションについて検索するときは気をつけような。 数か月前にgoogleで
gcc version-script
gcc bsymbolic-functions
gcc fvisibility
で-抜いて検索しても検索結果ゼロだったのに
今見たら検索結果でるようになってる gcc bsymbolic-functions
が
stackoverflow
ばっかりでgcc本家の
https://gcc.gnu.org/onlinedocs/gcc/Overall-Options.html
が出てこないのは今も同じ
単にstackoverflowの質問が増えたからgoogleに引っかかるようになった? そろそろC言語初心学習者に、もっとも最適な書籍を決めてください
柴田本? 苦C? 林本? やさC? K&R。プログラミング自体初心とかの特殊な人は知らん >>479
C言語は、アセンブリ言語を操れる人にとって簡単に使えるように出来ている。
なのでアセンブリ言語関係の本を先に読むべき。
# ジョークだよ? 学校の課題でc言語でゲームを作るんですが作りやすいものとかないですか? >>485
純粋にCだけでってなると数当て(乱数適当に作っておいて、値を受け取って小さいか大きいかを表示する)なんかも
作り易いと思う。
あとはフルハウスやババ抜きなんかのターン制のカードゲームとか
もっと面倒なのだと数独やオセロなんかの平面に文字を並べればなんとなくそれっぽく見える感じのゲームは作れうるかな なぜ学校でプログラミングをやるのか?
なぜCを使うのか?
目的と手段を履き違えてないか? ィ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;゙t,
彡;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ヽ
イ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;r''ソ~ヾ:;;;;;;゙i,
t;;;;;;;リ~`゙ヾ、;;;;;;;;;;;;;;;;;;;;ノ i,;;;;;;!
゙i,;;;;t ヾ-‐''"~´_,,.ィ"゙ ヾ;;f^! / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
ト.;;;;;》 =ニー-彡ニ''"~´,,...,,. レ')l. < >489 おまえは何を言っているんだ
t゙ヾ;l __,, .. ,,_ ,.テ:ro=r''"゙ !.f'l. \____________
ヽ.ヽ ー=rtσフ= ; ('"^'=''′ リノ
,,.. -‐ゝ.>、 `゙゙゙゙´ ,' ヽ . : :! /
~´ : : : : : `ヽ:. ,rf :. . :.: j 、 . : : ト、.、
: : : : : : : : : : ヽ、 /. .゙ー:、_,.r'゙: :ヽ. : :/ ヽ\、
:f: r: : : : : : : : !丶 r-、=一=''チ^ ,/ !:: : :`丶、_
: /: : : : : : : : :! ヽ、 ゙ ''' ''¨´ / ,i: : : l!: : : : :`ヽ、
〃: :j: : : : : : : ゙i `ヽ、..,,__,, :ィ":: ,ノ:: : : : : : : : : : : :\
ノ: : : : : : : : : : :丶 : : ::::::::: : : : /: : : : : : : : : : : : : : : :\ >>489
目的はこの支配からの卒業
手段は課題消化 メジャーなコンパイラにはなんで実行ファイルの難読化オプションがないんだろうか。
デマングリング不可の関数ラベル名を生成するだけでも相当な難読化になると思うのだが。 本格的な文字列処理を行う場合、内部コードはUTF-16に統一するのが常識なのだろうか。
あと最近はユニコード扱う場合はchar16_t使うのが主流になってたりする? なにかのライブラリ使うならそのライブラリが対応しているエンコーディング使えばいいが、
自前で文字単位の処理やるならマルチバイトよりワイド文字のが楽でしょ。
内部的には結局コードポイントの単位で扱うだろうし。
「本格的な」の内容がUNICODEに定義されたすべての文字を扱えるということを含むなら
UTF-32、基本多言語面だけで十分ならUTF-16でいいだろう。 文字単位が大方2バイトと決まってるUTF16使うのが一番楽。
unsigned short ch = u"あa";
ch[0]; // 'あ'
ch[1]; // 'a'
UTF-8ではこうは行かない。 >>500
その「大方」がつらいんよ。
自分しか使わないプログラムとかなら手抜きしてそういうのでもいいと思うけど。 たいてい「このアプリはBMPまでしか対応しません」で困らん。 if(argc>3|||!strcmp(argv[1],"/?")||strcmp(argv[1],"-?"))
/? と-? て、どういう意味? >504
そのまま。特別に変換するわけでもない文字列。
コマンドラインアプリで引数にヘルプオプション指定されてるか調べてると思われる。
>aaa.exe /?
>aaa.exe -? サッカーブッシュ日本代表日程ぷあたん(しゅっちょうまいくろ教育長交代)春文執行40代売上差額シュガーチョコ
https://www.youtube.com/watch?v=NDq1QoJY0nY宇ドナルドアナリストパワーストーンコーチングとしまえん
サッカーブッシュ日本代表日程古本屋よしたけしゅっちょうちょこしゅがー
ディーラー税務署天才開発者死亡詰みヨミドクターマイクロサービス不足
サッカーブッシュ日本代表日程ぷあたんシフト光金さかい強制バイト人権侵害問題
春分資源執行ニューヨーク低原価ぼったステーキソルトレイク福岡横浜新橋奴隷課金パチシフト強制バイト問題新潟米センター生残
コスメ24チャリティー隠れ40代生活保護プレイボーイバイトレードいたりあん接待問題
マスコミKARDローンケーオーサービス不足婚活パーティー寄付金執行原発ビジネス
FBIチャイニーズタイホテル売上事務所ガチャ決算ガチャキャンペーン(販売報道陣過激派組織向携帯最新情報提供終了
校長発言細心注意ノートン産廃エラー(著作権クレーム中国反応融資高額教育費)(中国捕鯨団体40代社員サッカーコメント
高額入学金ヤフウ新橋大学ヤフウ新橋理事長FX経費 おじや50代資産ガリバズフィード40代エリート C++ならクラス作ってクラスの操作関数を多数登録できますが、Cの構造体で同じことをやろうとしたらどう書くのでしょうか? 構造体に関数ポインターをもたせる
第一引数は構造体のポインター >>508
なるほど、そういうやり方なんですね!ありがとうございます。 >>508
構造体に関数ポインタ持たすの意味なくね? int main(){
char a[20];
char b[20];
scanf("%[^abc]", a);
printf("a[] = %s\n", a);
scanf("%s", b);
printf("b[] = %s\n", b);
return 0;
}
2回入力できないのは、なんで? ネットから拾ってきたソースを参考にしています。
2つのファイルをマージして、コードからメッセージを参照するハッシュリストを
なのですが、どうも無限ループに陥ってしまっているようなのです。
hashlist_lookupのwhile脱出条件であるNULLをhashlist_add内で
セットしなければいけないのはわかるのですが、どのようにすればいいのでしょうか? メインはこのようになっております(関連部分だけの抜粋です)
static struct hashlist message_list;
ハッシュリストの作成部分
hashlist_create( &message_list, 2048, 682 );
マージしてハッシュへ登録部分
if( src1id == src2id ) {
src1ptr += 7 + src1len;
src2ptr += 7 + src2len;
hashlist_add( &message_list, src2id, destptr );
} else
if( src1id > src2id ) {
src2ptr += 7 + src2len;
hashlist_add( &message_list, src2id, destptr );
} else {
src1ptr += 7 + src1len;
hashlist_add( &message_list, src1id, destptr );
}
ハッシュリストを参照する部分(hashlist_lookup内で無限ループ)
struct hashnode* node = hashlist_lookup( &message_list, message_id );
return node ? (char*)node->info : "(null)"; 以下、ハッシュ関連
struct hashnode {
struct hashnode* next;
u32 keycode;
void* info;
};
struct hashlist {
struct hashnode* current;
struct hashnode** table;
int current_table;
struct memblock memblock;
int tablesize;
int n_items;
}; void hashlist_create( struct hashlist* _list, int _tablesize, int _bufsize )
{
memblock_create( &_list->memblock, sizeof(struct hashnode), _bufsize );
_list->table = (struct hashnode**)xmalloc( sizeof(struct hashnode*) * _tablesize );
_list->current = _list->table[0];
_list->tablesize = _tablesize;
_list->current_table = _list->n_items = 0;
memset( _list->table, 0, sizeof(struct hashnode*) * _tablesize );
}
struct hashnode* hashlist_add( struct hashlist* _list, u32 _keycode, void* _info )
{
struct hashnode* node = (struct hashnode*)memblock_alloc( &_list->memblock );
node->keycode = _keycode;
node->info = _info;
node->next = _list->table[_keycode % _list->tablesize];
_list->table[_keycode % _list->tablesize] = node;
_list->n_items++;
return node;
}
struct hashnode* hashlist_lookup( struct hashlist* _list, u32 _keycode )
{
struct hashnode* node = _list->table[_keycode % _list->tablesize];
while( node ) { //ここで無限ループ
if( node->keycode == _keycode )
return node;
node = node->next;
}
return NULL;
} >>512
scanf() の [...] 変換指定子なんて初めて見たよ。
調べたところ、以下のような動作をするみたいね。
scanf("%[^abc]", a);
配列aには a, b, c 以外の文字が入る
(入力文字列の先頭から a か b か c の直前までをaに格納)
上の入力で配列aに格納されなかった分はバッファに残る
scanf("%s", b);
すでにバッファに入っている内容を配列bに格納して関数終了
(配列aへのscanf()を終了させたa, b, cから始まる文字列が待機してるはず)
というわけで入力操作は、
a, b, c を含まない間は scanf("%[^abc]", a); が完了しない
scanf("%[^abc]", a); が完了したら、その途端に scanf("%s", b); も完了 scanfのスキャン集合はよく使われる機能だよ
>>512
2回入力、というのは改行キー(エンターキー)を押して2回入力した、という意味で
使ってるんだろうけど、スキャン集合を使うと改行も入力文字として扱うようになるから、
つまり改行キーがエンターするキーではなくなってるのが、理由。
ttyのcookモードの観点では依然改行でエンターだけど、まあそれは別の話
>>514
引用の範囲は問題ない
http://codepad.org/yoBUyHMg >>518
返信有難うございます
他の部分の調査を行ってみます
お手数をお掛けしてすみませんでした >>520
いやいや>>508の前提では意味ないと思う。
逆に聞きたいんだが、どういうふうに使うのか、もしくはどんな利点があるのか、教えてくれたら嬉しい。 >>521
用途は質問趣旨でメソッド風に使う。
利点は質問者なりにあるんじゃないの。
何故無意味と思うのか具体的に書かないと誰も答えられないと思う。 >>522
そのイメージがわからないから、コードでいいので具体例を示してくれない?
すごい単純なので良いので。
本当にイメージ出来ないんだ。 >>523
イメージがわからないけれど、無意味とは判ったのですか。。。 ひょっとして
「インスタンスには関数ポインタじゃなくてクラス定義へのポインタを持たせろよ」
的なこと? ふつう、インスタンスが違っても関数の定義は一つなので、インスタンスのポインタだけでいいよね。 構造体に関数ポインタを持たせれば、
インスタンスごとに関数の実体を変更できる。
C++でのオーバーライドに相当する使い方。
というのはどうかな。コード示せなくて悪いけど。 ip->func(ip, ほかの引数...)
仮想関数を実現するときぐらいで静的に確定してるなら
func(ip, ほかの引数...)
で十分だよね >>530 を見るまで >>510 の意図を把握できなかったよ。
そういう意味だったのか。 ip->func( ip)
に対応するのは
func_of_some_class( ip)
だよ。ネームスペースが違うんだよ。
自分がそうしないから無意味というような考え方はあまり楽しくないと思うよ。 Cなんだから、単純に構造体に識別子を持たせるだけでいいね >>507
まだ見てる?
func_of_some_class( obj)
よりは
obj->func( obj)
の方が嬉しいだろうけど、関数が多いと *obj が大きくなる。もう気づいてるよね?
それが問題になるようなら関数ポインタのための構造体を1個だけ用意して
some_class . func( obj)
という方法もある。でも、あまり嬉しい書き方ではないだろうね。
そこで、この構造体を指すポインタを *obj に入れて
obj->f->func( obj)
みたいな感じでどうだろう。これなら *obj の大きさはポインタ1個分増えるだけだし
obj->func( obj)
と同様にコードの再利用性も高い。まあ、C で簡単にやりたいなら多少は妥協も必要だけど。 getsって危険な関数って書いてあったけど
putsとputcharって、危険ですか? すまない、ちょっとお尋ねします
debian lenny なんつー古い環境で開発せざるを得ない中、C++で「unsigned long long」型を使おうとしてるんだけど
16ビットずつシフトさせていくと、32ビットを超えた部分が消えてしまう
a = 0x00000000ffffffff;
a << 16;
→ 0x00000000ffff0000
こんな感じ、本来なら0x0000ffffffff0000になるはずだが…
環境変えろは分かるんだが、以前のgccでそんなバグの事例があったかどうかが知りたいです >>537
配布済みパッケージならgcc 3.4, 4.1, 4.2, 4.3があるけど
少なくても 4.3.2 にはそんなアホみたいなバグは無い
http://ideone.com/qN9OJV
とはいえdebian lennyだろうと好きなバージョンのgcc突っ込んで使えばいいと思う >>539
原因が分かりました…
画面にprintf出だしてたんだが、0x%016x にしてたんが問題やった
0x%016llx でちゃんと表示された!コードら正しかった!
お騒がせしました gdbも使えない環境なのはきついね…
gccだって指定されてるから変えらんないのですわ >>541
いかにも「うっかり間違えそうな人」が書いた投稿だね。
よほど慌ててるのか。
cppcheck を試したらどうだろう。
printf() の書式文字列と引数の型の一致もチェックしてくれるよ。 >>544
俺です
たしかにちとパニクってしまった一連の流れではある
まぁこのあとにディストリビューション更改が決まってはいるので、できうる限り俺が主導権握って
いろいろ決めてしまおうかと思ってる int tensu[3]
for(i = 0;i < 3;i++)
scanf("%s %d %d",tensu[i],tensu[i],tensu[i]);
printf("%s %d %d", tensu[i],tensu[i],tensu[i]);
超初心者です
配列がわかりません
文字列を混ぜる場合、どうすればいい?
田中 59 46 char namae[3][128];
int tensuu1[3], tensuu2[3];
for(i = 0;i < 3;i++)
scanf("%s %d %d",namae[i],tensuu1[i],tensuu2[i]);
printf("%s %d %d\n", namae[i],tensuu1[i],tensuu2[i]); char namae[3][128];
int tensuu1[3], tensuu2[3];
for(i = 0;i < 3;i++)
scanf("%s %d %d",namae[i],&tensuu1[i],&tensuu2[i]);
printf("%s %d %d\n", namae[i],tensuu1[i],tensuu2[i]); int lang[3][2]
hound dog
to zu
no nein
2次元配列だけど、scanf使ってこんな感じで
入力したいけど、どうすればいい? C言語でゲラフィック液晶動かしてみたいんだが、簡単に動かせるツールみたいなのある? ___
♪ ∩/ || ̄ ̄||♪ ∩∧__,∧
_ ヽ|.....||__|| 7 ヽ( ^ω^ )7 ゲラフィック♪
/`ヽJ ,‐┘/`ヽJ ,‐┘ ゲラフィック♪
| ̄ ̄\三 / ̄ ̄ ̄/ ´`ヽ、_ ノ ´`ヽ、_ ノ
| | ( ./ / `) ) ♪ `) ) ♪ DENSOの奴はC言語のインターフェースあったかな・・・ ☆ 日本の、改憲を行いましょう。現在、衆議員と参議院の
両院で、改憲議員が3分の2を超えております。
『憲法改正国民投票法』、でググってみてください。国会の発議は
すでに可能です。平和は勝ち取るものです。お願い致します。☆☆ デバッグで初期化してない変数の値見ると
でたらめな値が入ってることあるけど
zaifの2246兆バグもそんな感じなの? あっちでそんな質問にための質問してるのがいたが
教師無し学習中のAIっぽ >>561 その可能性はない、とは言えないね。
未初期化領域からの読み出しは「未定義の動作」らしいから、
口座に多額の振込がされてもANSI規格には反しない。 ■ このスレッドは過去ログ倉庫に格納されています