C言語なら俺に聞け 147

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
垢版 |
2018/08/16(木) 23:36:02.22ID:fOCSKLtw
C言語の話題のみ取り扱います C++の話題はC++スレへ
質問には最低限の情報(ソース/コンパイラ/OS)を付ける
数行で収まらないソースは以下を適当に使ってURLを晒す
https://paiza.io/
https://ideone.com/
http://codepad.org/

C11
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1570.pdf

C99
http://www.open-std.org/jtc1/sc22/WG14/www/docs/n1256.pdf
http://kikakurui.com/x3/X3010-2003-01.html

C FAQ 日本語訳
http://www.kouno.jp/home/c_faq/

JPCERT C コーディングスタンダード
https://www.jpcert.or.jp/sc-rules/


C言語なら俺に聞け 146
https://mevius.5ch.net/test/read.cgi/tech/1525031257/
2018/08/23(木) 19:51:18.42ID:iNuWULI+
>>206 が必死にググって見つけて来た関係ありそうな(でも全く頓珍漢な)言葉 → ハードセマフォ
自爆志願者かよ w
2018/08/23(木) 19:59:05.89ID:k97Awv43
>>196自体がとんちんかんなわけだがwww
2018/08/23(木) 19:59:23.06ID:EgEtgRif
な、ここのスレは読解力が乏しいのにお互いにマウント取り合って傍から見たらアホちゃうのって奴が多いだろ?
よくもまあLOCK/UNLOCK如きで生産性のカケラもない議論できるわ。
よほど暇なんかな?
2018/08/23(木) 20:01:59.92ID:k97Awv43
LOCK/UNLOCKごとき
だよねえ
2018/08/23(木) 20:17:25.18ID:e3M4pNLl
ハードセマフォってなに…?
2018/08/23(木) 20:24:14.60ID:k97Awv43
ハードウェアセマフォ
2018/08/23(木) 20:25:47.93ID:HinwMmX/
C言語のはなしに戻ってくるのはあと何日先かな
2018/08/23(木) 20:27:03.48ID:k97Awv43
話題があれば
2018/08/23(木) 20:28:12.68ID:EgEtgRif
初心者でもベテランでも新しい気付きがあるような内容に早く戻るといいね。
2018/08/23(木) 20:49:36.75ID:EgEtgRif
400メートルなら連続で泳げるけど、800メートルはよほどペース落とさないと無理だわ。
2018/08/23(木) 20:49:53.03ID:EgEtgRif
あ、ごめんなさい。
誤爆しましたm(_ _)m
2018/08/23(木) 20:50:49.19ID:Uo7RxZ0m
400も800も違わんだろう
2018/08/23(木) 21:08:53.97ID:wxGNRrqx
違うだろ
2018/08/23(木) 21:13:49.03ID:ZsFwDbjK
>>200
客「(コイツらには二度と仕事頼まんとこ、無能すぎ)」
2018/08/23(木) 21:41:28.27ID:OJr5a4rA
>>208
ハードセマフォには敵わないよ w

>>211
ググればどんだけ頓珍漢かよくわかる
2018/08/23(木) 22:03:27.73ID:ZsGoqTtC
>>220
多分両方ともそれなりに正しい方法を知ってるのに
会話の祖語からとんでもないところに着地するケースだな
2018/08/23(木) 22:13:17.45ID:y9Wx8uZn
>>176
> 視点移動が増える書き方で、可読性やメンテナンス性が悪いという人もいる。
それは正しく分割出来てないから。(同じ抽象度で分割する)
読まなくても分かる名前を付けて、結果的に読まないから、視点移動はしない。例えば、以下。

while (1) {
int idx = get_data_idx();
if (idx<0) break;
int* data = prepare_data(idx);
calculate_data(data);
write_back_data(data, idx);
}

この部分はマルチスレッドでのデータ処理だとしよう。
get_data_idxは未演算のデータのインデックスを返し、ない場合は、-1を返すとしよう。
単純に、「インデックスを受け取り、チェックし、データを用意して演算して書き戻す」と読めるだろ。
そこでget_data_idxの中身を見ると、マルチスレッド用だからロックされてる、というだけ。
(余談だが>>107にはこういう具体性が見えないので、
> LOCK/UNLOCKが必要な具体的な場面を想定しての発言には見えない (>>122)
と言われている。これも当たっている)

「視点移動ガー」は読み方を間違っている。
プログラムが階層構造のツリーとして、
縦に掘るのではなく、横に読んで、必要であればその部分だけ縦に読むんだよ。
まず最初は同階層で全体の流れを把握して、必要であればその実装を読む。
実装を読む場合、名前と実装が一致しているかだけのチェックしかしない。

家を建てるとして、
全ての柱が設計図通りに組み上げられているか(全体のチェック)と、
それぞれの柱が設計図通りの仕上がりになってるか(ほぞ穴が正しく加工されてるか)は別にチェックするだろ。
プログラミングも同じで、上位と下位は別にチェックするんだよ。
同時に読まないからいちいち子関数に視点移動なんてしないし、視点移動しなくて済むように同抽象度で分割するんだよ。
2018/08/23(木) 22:16:11.26ID:y9Wx8uZn
>>177
> do while のが軽い場合がある
> って常識だと思ったが
それはお前が何も知らない初心者だから。

do while は初回のチェックが入らない分速い。(逆に言えば、その分だけしか速くない)
君は「なんだか知らないが do-while は速いんだ!」位の理解しかしてないだろ。
そんな馬鹿はC界隈にはいない。

問題は、この「初回チェックしない分速い」のをいちいち取り上げる必要があるか、という点で、
殆どの場合はどうでもいいから do-while は使われない。
ただし、どうしてもケチりたい場合は使われる。
(ルール等で駄目なら手動で初回部分だけインライン展開しても同じだが、それよりは do-while 使った方がいい)

禁止する必要はないけど、使う局面もない、といったところだと思うよ。

初回のチェックが必要ない=その前か上位で初回チェックが必要ないことを保証している、であって、
全くチェックしていないわけではないんだよ。
結果、処理を整理して集約していくと、while文に吸収されることもある。
或いはそうならないとして、ど頭でチェックだけして不要ならショートカットしたい等の場合、
別にチェック+ do-while になるが、それはメトリックスを増やしてしまう。(静的コールグラフ)
どのパスを通るかがデータ依存になり、それがかなり大きな区画になってしまうだろ。
それよりはショートカット出来ないけどどんなデータでも同じパス、
whileで弾かれて空振りするだけ、のほうがメンテナンスが遙かに楽なんだよ。
ここら辺はさんざんメンテナンスしてれば分かるようになるし、してないうちには分からない。
お前は相当それ以前だが。

「僕はdo-whileの方が速いケースもあるのを知ってるんだ!」ってのは痛いだけだから止めとけ。
自分でアホだと言っているようなものだ。
そんなことはみんな知ってて、その上で議論している。
コード分岐を増やすのが、1回のチェックを端折るのと釣り合うか?なんだよ。
2018/08/23(木) 22:18:42.67ID:wxGNRrqx
長文から悔しさがにじみ出てますよ
2018/08/23(木) 22:19:37.23ID:ZsGoqTtC
成功するまでリトライみたいなのってdo-while使わない?
2018/08/23(木) 22:20:37.13ID:wxGNRrqx
do {
} while (0);

こんなのもごくたまに
2018/08/23(木) 22:22:18.83ID:Z2Fii0dD
do-whileはマクロで文をまとめるのによく使うよ。
2018/08/23(木) 22:23:48.32ID:wxGNRrqx
>>227のセミコロンを取ったヤツ
2018/08/23(木) 22:26:06.91ID:y9Wx8uZn
ただマジで、初心者はこの手の話に首を突っ込まない方がいい。
時間の無駄で、上達を阻害するだけ。

コードの美しさ/抽象レベル/分割/隠蔽/疎結合が必要なのは少なくとも200-1000行程度であって、
50行程度ならグダグダ言わずにベタで密結合で書き下した方が分かりやすい。
10行のプログラムを動かすにも苦労する初心者にも、
理解に少なくとも200行程度書ける腕前が必要な内容を教えるから空回りする。
(とはいえ、初段階の洗脳は必要悪だ、というのがJava教団であるが。
そしてFizzBuzzはイテレートするクラス、判定クラス、表示クラスに分割され、
イテレータがインタフェースとして活用される、というのが件の悪ノリだった)

1000行程度も書けない初心者は、まず1000行書けることを目指せ。(1000行程度なら勢いで書ける)
コードの美しさその他はその辺になればだんだん分かってくる。
その後に、自分で「コードを減らす」練習をした方がいい。
(コードを「書く」よりも「減らす」方が上達する、と言う奴は居て、俺もそう思う)

それまでは自分でコーディングルールの優劣を判定する頭もないのだから、(これはちゃんと認めた方がいい)
オレオレルールではなくて、コードを書いている連中のルールをそのまま使った方がいい。
俺はgoogleがいいと思うが。
(なお意識高い系C++erはgoogleのルールはもう古い!と言いだした模様。
俺は布教用のルールなんてゴミだと思っているが、まだチェックはしてない)


>>180-181
MISRAは「自分でどのルールが無駄か判断出来る人向け」であって、
お前らみたいな「自分では判断出来ない初心者向け」ではないんだよ。
素直にとりあえずgoogle使っとけ。
2018/08/23(木) 22:27:16.39ID:wxGNRrqx
こいつNG
2018/08/23(木) 22:28:37.43ID:y9Wx8uZn
>>184
> 覗かないですむほど関数仕様を単純化すると今度は関数が増えて管理の手間が増える矛盾。
管理の手間は増えないと思うが。

もし増えていると感じるのなら、それはCには階層がないことの弊害だ。
関数内関数が普通に使える状況であれば、
関数切り出しは「処理を纏めて名前を付けただけ」でしかなく、
外部からその関数が呼ばれることが文法的にないことを保証出来るから、手間は増えない。

そしてこの点に、妥協的だが現実的なのは「名前に階層も付けてしまう」だ。
つまり、AAA階層内の関数はAAA_get_data_idx()等にし、
もし仮にAAA_get_data_idx内でさらにローカル関数が必要な場合は、AAA_get_data_idx_BBBにしてしまう、というものだ。
関数名が長くなる点を除いて問題はないし、「grep出来るから便利」 by Linus。
OOPも実質同じで、フルパスで呼ぶなら AAA->get_data_idx->BBB()等、_ が -> に代わるだけだが、
実際はオブジェクトポインタ=途中のポインタだから、obj->BBB()となり、長くならずに済む。
(ただし、grep出来なくなる)

俺もCに階層記述能力がないのは問題だと思っているが、
現実的に分割/疎結合化が必要なのは200-1000行単位であり、
ここは「ファイル」(=モジュール)で分割しろ、というのがCだ。
だから不満ではあるが結果的に何とかなってしまうのも事実で、だからこそCがまだ生きながらえている、というのはある。

それにしても「関数内関数」は欲しいんだけどね。あと、ラムダも。
(gccでは前者は標準、後者はマクロで対応出来るが)
2018/08/23(木) 22:34:14.90ID:za+Z/fW8
>>230
1000業かけるお題を教えてください(。・´_`・。)
2018/08/23(木) 22:35:46.52ID:4VjbPjMt
親切に俺condwaitって書いたのに…
2018/08/23(木) 22:37:11.87ID:ZsGoqTtC
関数のレベル感あわせるのむずい
あわないだろ
2018/08/23(木) 22:49:21.25ID:OJr5a4rA
>>224
> do while は初回のチェックが入らない分速い。(逆に言えば、その分だけしか速くない)
違う、>>177はコンパイラがあまり賢くない時代の知識で止まってるロートルってだけ
2018/08/23(木) 22:50:32.61ID:/xlV6A++
現在通過中
風はそれほどでも無いが雨量がヤバい、尋常じゃない
2018/08/23(木) 22:50:52.78ID:/xlV6A++
誤爆した
2018/08/23(木) 22:50:52.87ID:wxGNRrqx
「軽い場合がある」
2018/08/23(木) 22:52:49.79ID:wxGNRrqx
デメリットは数文字ソースコードが増えるだけ
生成されるバイナリが悪くなることは無い
良くなる可能性はある
241デフォルトの名無しさん
垢版 |
2018/08/23(木) 22:54:11.95ID:qYtPM3Ou
>>223
> それは正しく分割出来てないから。
そう。だから、>>113は正しく分割できていない、という人がいると書いたんだが。
2018/08/23(木) 22:54:57.75ID:wxGNRrqx
do while を使わない(使えない)人っているよね
2018/08/23(木) 22:57:34.92ID:wxGNRrqx
常に正しく分割されてるコードしかいじらないわけでも無いだろうし
常に正しく分割出来るとも限らないし
正しいか正しくないかは視点によっても違う

理想だけ語るだけで実際にコードを組んだ事が無さそうな人がいるようだけど
244デフォルトの名無しさん
垢版 |
2018/08/23(木) 23:01:12.83ID:FIun2PeI
>>237
気圧申告しないと!
2018/08/23(木) 23:01:58.95ID:wCnARv+4
ワッチョイないのに結局レスするんか
2018/08/23(木) 23:03:30.31ID:NMfUyUL+
>>230
>FizzBuzzはイテレートするクラス、判定クラス、表示クラスに分割され、イテレータがインタフェースとして活用される、というのが件の悪ノリだった
どんなコードになるのでしょうか?一度みてみたいものです…

fizzbuzz はこんなコードを書いたことがあります
https://mevius.5ch.net/test/read.cgi/tech/1434079972/25
https://ideone.com/i8wMea
2018/08/23(木) 23:18:47.64ID:y9Wx8uZn
>>226
具体例あるか?
それ以前に「成功するまでリトライ」自体がよろしくないが。


>>236
do-whileに対して何か特殊な最適化がかかるという話なら、
俺は知らんから突っ込めない。
が、そうだとしても、それでコードを汚すこと自体が間違いだが。


>>241
そう思うんならそれでいい。
平行線だし、議論しても結果は出ない。
君のコードを見て他の人がどう思うかはそれぞれの自由だ。

俺はこの場合関数に括り出す方を選択する。
同様の連中もここにいるだろ。それだけの話さ。

ただそれ以前に、アトミックなんて最初から関数に括り出されていると思うが。
インラインアセンブラを使う気でなければそもそも無理だし。例えば、以下。
https://msdn.microsoft.com/ja-jp/library/dd78zt0c(v=vs.110).aspx


>>245
あー、8は俺だ。
ワッチョイありで立て直してくれればそっち行くわ。
(俺が立て直してもいいが)
2018/08/23(木) 23:43:58.22ID:y9Wx8uZn
>>246
俺の記憶では、「FizzBuzz Implementation in Java」みたいなタイトルでGitHubに在ったはず。(だが出てこない)
★も2000位ついていたと思った。
クレームついて取り下げるとも思えないから、検索順位下げられたんじゃね?

そんなに見たければ自分で探せよ。多分まだそのまま公開してると思うぜ。
2018/08/23(木) 23:45:37.65ID:Ml8TmHvL
1000行書けるお題を教えてください
2018/08/23(木) 23:49:35.97ID:HinwMmX/
宿題で出されているの?
2018/08/23(木) 23:52:07.74ID:NMfUyUL+
>>248
キーワードありがとうございます
これですね
https://github.com/EnterpriseQualityCoding/FizzBuzzEnterpriseEdition
2018/08/23(木) 23:55:52.97ID:0/a4zf/K
>>249
RPGゲーム
これは26万行

ttps://github.com/naota/hengband/tree/master/src
2018/08/23(木) 23:59:12.07ID:y9Wx8uZn
>>251
それだ。
(俺のキーワードが役に立ったようには見えないが…まあ辿り着けたようだしよしとしよう)
2018/08/24(金) 00:05:09.13ID:iMeaBiRp
>>247
> ただそれ以前に、アトミックなんて最初から関数に括り出されていると思うが。
そうだな。すでに atomic 実装されていたら俺も使うわ。

関わっているプロジェクトや文化にも依存するから、絶対はない。
例えば Kernel とかだと大半は関数化していない。俺は見た記憶がない。
まあそれだけの話。
2018/08/24(金) 00:16:45.53ID:O3WQJa8X
>>254
> 例えば Kernel とかだと大半は関数化していない。俺は見た記憶がない。
それソース出せるか?さすがに嘘だと思うぜ。

> C 言語ではアトミック操作を保証できないことから、Linux は基礎となるアーキテクチャーに依存してアトミック操作を提供します。
> https://www.ibm.com/developerworks/jp/linux/library/l-linux-synchronization.html
いちいちインラインアセンブラでは設計効率が悪すぎる。
APIにも当然用意されてるし、普通の人ならそれを使うし、Linusも当然そうだと思うけど。

根本的に「ロック」自体を勘違いしている気がするが。
2018/08/24(金) 00:18:45.88ID:iMeaBiRp
>>255
俺は見たことがないだけ。気になったら探してくれ。
2018/08/24(金) 00:34:08.73ID:O3WQJa8X
>>256
grepすれば出てきそうだが探す気はない。

linux kernel内でひたすらインラインされているとしたら、
おそらくスタック容量(1スレ当たり256バイトだったか?)の為だろう。
「関数化」はされていなくても「マクロ化」されていて、
ソースコード的には意味が同じという落ちじゃないか?
それなら君の噛みつき方は悪質だと思うがね。(意図的に議論を空回りさせててる)
2018/08/24(金) 00:37:30.88ID:iMeaBiRp
>>257
わざわざ自前で関数化していない、という話だぞ。
2018/08/24(金) 00:43:06.32ID:O3WQJa8X
>>258
それが論点のすり替えなんだよ。
分かってないようだからそれでいいが。

というわけでこの件は終わりだ。
2018/08/24(金) 00:44:16.19ID:iMeaBiRp
>>259
>>113 が自前で関数化する意図でしか読み取れないからな。
あれが自前実装でないというのであれば、それまでだ。
2018/08/24(金) 00:49:47.27ID:VJLc5wt0
ソースを示して、突っ込んだ話になることを期待w
2018/08/24(金) 00:53:41.22ID:ljcg8c0k
wktk
2018/08/24(金) 00:53:57.99ID:TjDOkMEc
そしてまた質問者が置き去りになるのであった
2018/08/24(金) 01:26:32.42ID:VJLc5wt0
C言語なら俺に聞け(答えるとは言っていない)ですか?
2018/08/24(金) 01:28:36.02ID:A5L5xSI8
>>253
「github にある」が重要なヒントとなりました
2018/08/24(金) 05:28:07.79ID:Nyovr5Qp
>>242
> do while を使わない(使えない)人っているよね
このスレでも>>161とかな
while(){}に比べたら使用頻度は低いけど使用する機会があるから多くの言語で使えるようになってるのになぜかdo〜while使わない俺かっけーとか思ってそうw
ただ今どきパフォーマンスがいいからdo〜whileにすると言うのはナンセンス
2018/08/24(金) 05:50:10.13ID:Nyovr5Qp
>>247
> 俺は知らんから突っ込めない。
知らないなら突っ込むなよ…
> do while は初回のチェックが入らない分速い。(逆に言えば、その分だけしか速くない)
とか馬鹿丸出しだぞ
2018/08/24(金) 05:54:34.00ID:Nyovr5Qp
>>255
あんたの言ってるアトミック操作が>>107のLOCK/UNLOCKに相当する
わざとなのか理解してないのかは知らんけどレイヤーの違うものを混ぜて語られてもそりゃ噛み合わんよw
2018/08/24(金) 07:43:07.97ID:ZkSPfVdV
>>247
コードを汚す?
do whileに慣れてないと
無限ループでdo whileを使うのがコードを汚す
になるのか?
2018/08/24(金) 07:52:13.74ID:ZkSPfVdV
>>266
> ただ今どきパフォーマンスがいいからdo〜whileにすると言うのはナンセンス

forやwhileを選ぶ理由がある所でも
パフォーマンスを気にしてdo whileを選ぶべき
なんて話はしていない

どれを選んでも良いときに
forを選ぶ人、whileを選ぶ人、do whileを選ぶ人がいると言うだけ
2018/08/24(金) 07:57:40.75ID:ZkSPfVdV
わざわざCを使うってことは
8bitのチープなマイコン、チープなコンパイラだったり
OSやドライバの開発だったり

アセンブラも混ぜて使うこともありそうな
一番低級な高級言語

他の言語よりも記述方法によるパフォーマンスの差
が語られても良いと思う
2018/08/24(金) 07:58:09.19ID:KrjEv78J
自己防衛のためだけのレスになってきたな
そろそろこの話題も終わりかな
2018/08/24(金) 08:00:01.51ID:Hnd+Ihtp
ソース見て do {...} while (1); で無限ループになってたら
さすがに「なんで for (;;) や while (1) にせんの?」と尋ねるわ。

…でも「ループ先頭の(決して成立しない)終了判定が入らないから速いんだ」
と言われたら受け入れるかも。分かってやってるんだな、という意味で。
実際のところ for (;;) は無論のこと while (1) でも判定しないと思うけど。
2018/08/24(金) 08:06:02.46ID:ZkSPfVdV
>>273
3個とも超基本構文だと思うけど

そのレベルだと
「なんでfor(;;)なの?」って聞く人もいそうだな
275デフォルトの名無しさん
垢版 |
2018/08/24(金) 08:10:04.46ID:29l6jjMs
そういやループの話でgoto使うってレスないな
ネストが浅くなるし好んで使う人は・・・さすがに居ないか
2018/08/24(金) 08:12:56.91ID:LUWnMn3S
無限ループって怖くね?
2018/08/24(金) 08:14:01.23ID:LUWnMn3S
>>274
K&R以来の伝統のCのイディオムだから?
2018/08/24(金) 08:16:04.10ID:ZkSPfVdV
goto label2

label1:
処理

label2:
条件判断
if (偽) goto label 1;

----
コンパイル結果的にはforやwhileはこんな感じ
条件が無かったとしても goto label2が入る
最適化しない場合やチープなコンパイラだと
このまま最適化されないかもしれない

goto label2
が不要な時にこれを除いたのがdo while
これのほうがバイナリはシンプル
2018/08/24(金) 08:18:32.35ID:ZkSPfVdV
>>175
多重ループから抜ける時
関数の終了処理
ガシガシに最適化をする時

使いどころはこんな感じ
2018/08/24(金) 08:18:56.33ID:ZkSPfVdV
アンカーミス
>>275
でした
2018/08/24(金) 08:30:42.38ID:ZkSPfVdV
gotoを使わない(使えない)人だと
多重ループから抜ける為だけにフラグを使ったり
多重ループから抜ける目的の為だけの理由で
関連する複数のループを分けたりする

double data[4][4];

例えばこんな構造のデータのある統計情報を返す関数
ただし、データに非有限値が入っていたらNaNを返す
デバッグ用に計算結果を出力するコードが入っている
どういうコードにする?
2018/08/24(金) 08:42:44.31ID:srP6ovAZ
>>270
> どれを選んでも良いときに
無限ループ以外にそんなケースあるか?
かつそれでdo〜whileの方が効率的になるケース示してみ
2018/08/24(金) 09:30:50.97ID:L5DguHRe
マウント取りたくて必死w
2018/08/24(金) 10:27:50.33ID:tx++RsbT
do…whileの方が初回の判定がないから速いとしてもループ回数が多いと誤差レベルだし無限ループならコンパイラで最適化されて差がなくなると思う
2018/08/24(金) 10:54:27.69ID:ZlD+iWMs
4.3BSDのccを-Oなしで使った場合の話をまだしてるやついるのか
2018/08/24(金) 11:04:28.35ID:Cl8BSI3h
いろいろ誤解が多いので口出ししておく。

アセンブリ言語に手で変換してみるとすぐわかるんだが、
whileは先頭付近に条件分岐が必要な他に、末尾に必ず無条件のジャンプが必要。
対してdo-whileは末尾の条件分岐だけでいい。
このおかげでループ1回あたり命令実行が一つ減る。

しかしコンパイラはwhile文をif文とdo-while文相当に置き換えて最適化するから、差は出ない。
ヘボコンパイラなら最適化しないかもしれないが、
その場合は他の部分も最適化されるはずもないので、速度云々いうだけ無駄。
2018/08/24(金) 11:18:54.46ID:ZlD+iWMs
そんな誤解しかねないやつ
いるとしたらおまえだけ
2018/08/24(金) 11:36:54.26ID:/2nrSUYs
do whileは最後に条件を書くのが気に入らないので使わないです
2018/08/24(金) 11:38:27.58ID:C22mUEBr
環境に依る 以上
2018/08/24(金) 11:40:55.91ID:7MrYBE0R
使いどころを知らない自慢

forはwhileの上位互換だからwhileを使わない
ていうならまだわかる
2018/08/24(金) 11:44:59.31ID:7MrYBE0R
>>282
1回目が必ず条件TRUEになることがわかっているwhileループ全て

話題は無限ループだけど
2018/08/24(金) 12:22:55.87ID:srP6ovAZ
>>286
> しかしコンパイラはwhile文をif文とdo-while文相当に置き換えて最適化するから、差は出ない。
if文?
do 〜whileに置き換えて単に最後の条件文に飛ぶジャンプ命令入れるだけだぞ
2018/08/24(金) 12:29:41.83ID:9+ua1c/R
アセンブラのジャンプ命令や条件分岐の使い方が分かってない様子だね
ループ全体で命令が1回増えるだけなのにループ1回当たりの命令実行回数が増えるとか言ってるし
2018/08/24(金) 12:30:27.52ID:7MrYBE0R
----gotoの使用例----

for (y = 0; y < 9; y++){
. . for (x = 0; x < 9; x++){
. . . . if (判定) goto break_loop;
. . . . 処理
. . }
}
break_loop:


----do whileの使用例----

if (FindFirst()){
. . do {
. . . . 処理
. . } while (FindNext());
}
2018/08/24(金) 12:31:56.80ID:srP6ovAZ
>>291
> 1回目が必ず条件TRUEになることがわかっているwhileループ全て
それ1回目は必ず実行してその結果で2回目以降を実行するかどうかを決めるってことだよね?
典型的なdo〜whileパターン w
むしろそのパターンでwhile(){}使ってるなら単なるアホとしか思えない
2018/08/24(金) 12:34:47.80ID:7MrYBE0R
>>295
>>294の上のようなループを書くことない?
この場合はforだけど
2018/08/24(金) 12:35:02.93ID:srP6ovAZ
>>293
昔の話をしてるなら>>286の前半読め
今の話をしてるならそんなことみんなわかってるからいちいちドヤるな
2018/08/24(金) 12:38:53.07ID:srP6ovAZ
>>296
それは実行結果でループ制御してるわけじゃないだろ
x, y の値はループに入る時には条件満たしているべきだからdo〜whileなんて使っちゃダメ
2018/08/24(金) 12:39:50.18ID:TJU8554I
do whileってそんな語ることあるの?良くも悪くも単なる構文だと思うけど

ダラダラと長いループだと継続条件が下方に隠れるので嫌ってのはある
それ以外は正直どうでも良い
2018/08/24(金) 12:40:30.21ID:7MrYBE0R
>>297
今とか昔とかじゃなくて...

PCのプログラムしかしたことが無い人は分からないだろうけど
組み込みのチープなマイコンのコンパイラは
いまだに糞なのはたくさんあるよ

あと、
様々な事情により最適化をOFFにして出荷する事もある
2018/08/24(金) 12:40:57.41ID:7MrYBE0R
>>298
その条件、何か関係ある?
2018/08/24(金) 12:42:26.92ID:7MrYBE0R
>>299
単なる構文を無条件で悪とする人がいるって話
2018/08/24(金) 12:53:42.33ID:90B7//Ue
みんな議論に夢中で楽しそう w
2018/08/24(金) 13:07:51.92ID:sQPXKPEp
>>299
gotoも単なる構文だしね
あるものは便利に使っていこう
305デフォルトの名無しさん
垢版 |
2018/08/24(金) 13:32:55.56ID:Dz3bxc41
https://twitter.com/kondo_orange/status/1032690721822633985


俺は毒舌だから〜、ズバッと切れ味鋭いことも言っちゃうよ〜w、みたいな人、その意見が的を射ていない場合マジでイタイ奴だから気をつけろよ。

勘違いしてる奴けっこういるぞ。

斜に構えて逆張りするならそれなりに思考深めて来ないと。

田端さんとか意見が的外れだったらただのイヤな人だ(笑)
https://twitter.com/5chan_nel (5ch newer account)
2018/08/24(金) 13:41:35.51ID:B0ktSP35
構造体はメモリのスタックとヒープのどちらに格納されるのでしょうか?
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況