C#, C♯, C#相談室 Part93©2ch.net

■ このスレッドは過去ログ倉庫に格納されています
2017/04/22(土) 08:52:00.93ID:iVvswOrb0
■Visual Studio 2017 Community(無償の統合開発環境)等はこちら
http://www.visualstudio.com/downloads/

■コードを貼る場合はこちら
http://ideone.com/

■前スレ
C#, C♯, C#相談室 Part92
http://echo.2ch.net/test/read.cgi/tech/1485589613/

■次スレは>>970が建てる事。
建てられない場合は他を指定する事。
VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
2018/06/09(土) 14:07:54.32ID:VOfp/P7BM
もともと関数がオブジェクトである言語はデリゲートを導入するメリットは少ない
c#にデリゲートが無かったらjavaの様に専用のインターフェイスを継承した無駄なクラスを作らなければならなかった

ActionやFuncやラムダがあればデリゲートが必要なかったと言ってるのは何かを誤解してる
2018/06/09(土) 14:19:40.58ID:MhKfyDgC0
>>376
理解してなくても使えれば問題ないんだよ。
お前だってPCの起動方法(BIOSとか)知らなくてもPC使ってるだろ。
MSIL読めなくてもC#使えるだろ。
CPUの例外/割り込み機構を知らなくてもtry/catch使えるだろ。
一般プログラマにとってはプログラミング言語は道具であって、それ以上でも以下でもない。
新言語を作りたいのなら学術的に正確に理解することが必要だが、普通の人はそうではない。

それ以前にC#が死ぬ可能性を考えた方がいい。
C#専用の「デリゲート」の理解はつぶしが利かない。
他言語にもある「ラムダ」の理解のほうが重要だ。

デリゲートは「クラス」と「関数ポインタ+バインド」で対応した方が良かったと思う。
C#には未だに「バインド」がない=デリゲートでの対応になるが、
実際、後付でバインドすることが出来ないだけ不便だろ。

>>377
Javaみたいなそもそも「関数ポインタ」がなかった糞言語と比較したら駄目だよ。
Cには関数ポインタはあった。
C#はそれを「デリゲート」として拡張した。
他言語は「第一級オブジェクト」として拡張した。
今のところ、後者の方が正解っぽいだろ。
(俺自身にはイマイチ「第一級オブジェクト」である利点/必然性は見えないのだが)
2018/06/09(土) 14:24:48.97ID:VOfp/P7BM
関数がもしobjectクラスから派生したオブジェクトになるとメンバーを持てることになるんだけど
A.B().ToString()のToStringが
B()というメソッド自体に係ってるのか
B()の返した戻り値にかかってるのかがよくわからないことになる
2018/06/09(土) 14:25:53.62ID:54mp5fzVM
Javaってstaticメソッドを関数インターフェースに渡すときは最適化してくれんの?
2018/06/09(土) 14:30:26.04ID:AO7Grx3Qa
1+2*3
こんな計算式があったときに1+2をしてから3かけて答えは9
こうはならないだろ。それは優先順位を定めてるから。(1+2)*3のようにかけば期待通りになる

それと同じで関数がオブジェクトでメンバー持ててもそれに合わせた処理の優先順位を定めればいいだけ
2018/06/09(土) 14:32:21.62ID:VOfp/P7BM
理解しないのと誤解してるのではわかっていないという点では同じだけど
理解してない場合は理解していない前提で行動できる
一方の誤解してる場合は悲惨だ
2018/06/09(土) 14:33:21.85ID:MhKfyDgC0
>>379
お前は右結合と左結合を勉強しろ
2018/06/09(土) 14:35:46.47ID:VOfp/P7BM
>>383
じゃあどういう風に記述したらオブジェクトである関数のプロパティやメソッドにアクセスできるかここに書いてもらいたいが
2018/06/09(土) 14:36:40.18ID:MhKfyDgC0
>>382
お前は日本語を勉強しろ。

俺達は「理解しなくていい」=「完全に理解してはいないという自覚の元で使え」と言っているのであって、
それは「誤解」には繋がらない。
「誤解」ってのは、「理解してない馬鹿が理解しているつもりになっている」事を言う。
例えば、右結合と左結合を知らないお前みたいな馬鹿のことだ。
2018/06/09(土) 14:39:35.51ID:MhKfyDgC0
>>384
意味不明。何を書いて欲しいのか分からん。

> A.B().ToString()
これはAのメソッドB()を呼んでその戻り値に対してToString()を呼ぶ。
少なくともJavaScriptではそう。

で、何をしたい場合の記述が欲しいんだ?
2018/06/09(土) 14:48:14.18ID:VOfp/P7BM
>>386
思い違いをしていた
A.B().ToString()とA.B.ToString()で区別できる
クラスにフィールドとメソッドを同名にできないから区別できる
右結合と左結合は関係なかったけど
2018/06/09(土) 14:54:44.86ID:MhKfyDgC0
>>384
エスパーすると、言いたいことは分かった。
お前は「第一級オブジェクト」も理解しておらず、「誤解」している。ちゃんと勉強しろ。

「第一級オブジェクト」ってのは、通常のオブジェクトと関数オブジェクトを区別しない。
だから書式は当然同じだし、正しく理解していればこの点が疑問になりようもない。


>>387
なら日本語を勉強しろ
> B()というメソッド自体に係ってるのか
これで何を表現しようとしたか言ってみろ。それは
> A.B.ToString()
ではないだろ。
2018/06/09(土) 15:04:32.47ID:VOfp/P7BM
>>385
誤解は悲惨
delegateを削除しろと言って削除してみたらActionもFuncも使えませんでした
eventも使えませんでした

もちろん言語レベルで変数としてのデリゲートの代わりになるものもありません

>>388
> > A.B.ToString()
> ではないだろ。
いやいやそこはそのままであってるし普通にそう理解できないのか?
A.B.ToString()が正解
逆にどう勘違いしたのか聞きたい
2018/06/09(土) 15:06:54.66ID:VOfp/P7BM
本当にC#からdelegateを削除しろって言ってるんだったらどこかおかしい
何にも理解してない
2018/06/09(土) 15:06:56.64ID:AO7Grx3Qa
プロパティなんて関数オブジェクトみたいなもんだな
プロパティに引数渡してぇ
2018/06/09(土) 15:07:41.71ID:VOfp/P7BM
>>391
っVB.net
2018/06/09(土) 15:18:29.92ID:MhKfyDgC0
>>389
日本語で言うと、
> B()というメソッド自体に係ってるのか
と理解したって事だよ。

>>390
お前がな。
他言語にはdelegateなんて無いが、何も問題ないだろ。
あれ?って思えないのか?
(今すぐ廃止していいかどうかはまた別だが)

>>387
> クラスにフィールドとメソッドを同名にできないから区別できる
これは先見の明があったかもな。
関数を「第一級オブジェクト」に昇格させるのに文法的制約がない。
Javaに対しての利点にはなり、生き残る道かも。
2018/06/09(土) 15:25:50.19ID:MhKfyDgC0
>>391
JavaScriptではオーバーライドすれば出来る。
フィールド/メソッドの区別がなく、名前だけだから。
C#的には派生クラスで「プロパティ」「を同名の「メソッド」でオーバーライドだが、
これが型チェック的に無理なのか?
しかし名前の重複を許していないのだから、今後の拡張は可能のはずだが。

JavaScriptのデタラメ文法はどうかという奴もいるが、慣れてしまうと、
型あり言語の「型が違うだけ」で色々制約されるのも相当な糞だと気づけるぞ。
型検査はエラーではなく警告に留めるべきで、
プログラマがOKすれば型が不一致でも通してくれた方がマジで楽。
一番近いのはCってことになってしまうが。
2018/06/09(土) 15:29:15.96ID:a58WBe6r0
ア土曜の昼間からウアウアーの見本市
2018/06/09(土) 15:29:59.09ID:a58WBe6r0
友人ゼロのキモオタオッサンは他にやることないのかい
2018/06/09(土) 16:02:02.79ID:kvLDmgw/0
他の言語はともかくC#はGUIのイベントの管理にデリゲートのマルチキャスト使ってるんだから無かったら困るだろ
2018/06/09(土) 16:54:07.78ID:DBY1R4Jva
だからメソッドがオブジェクトかどうかなんて話はただの衒学趣味的な無益な話w
そんな話は「ではオブジェクトって何?」って不毛な議論になるだけでしょw
初心者がデリゲートを理解して使えるようになるための屁の役にも立たないよw

>>397
素直に考えればデリゲート自身にマルチキャストの機能を持たせるんじゃなく、
シングルキャストのデリゲートのリストとして実装する方法もあったはず

なんか理由があって「こういう」風になってるんだろうが俺には積極的理由はよくわからんね。
ジェネリックをデリゲートで制約できないことと関係があるのかもしれないが

なまじマルチキャストなんて機能があるせいで何だかわかりづらくなってる面は否定できないと思う
2018/06/09(土) 17:08:52.90ID:MhKfyDgC0
>>397
GUIに関してはdelegateの導入は不要だったで決着してる。
GUIにはOOPよりMVCの方が数段マシで、WPFもそうなってるだろ。
onclickにthisがバインドされている意味がそもそも無いんだよ。

決着が付いてないのはデータフロープログラミングをするときだ。
JavaScriptではObject.observeの導入が計画され、一部フィーバーしていたが、ポシャった。
https://www.html5rocks.com/ja/tutorials/es7/observe/
以下によると、非同期なのが使えなかったらしい。
http://tech.nitoyon.com/ja/blog/2015/11/18/death-of-oo/
JavaScriptの非同期は最早宗教だが、
はっきり言って無駄に非同期すぎて、余計にやりにくくなっているケースもある。これもそう。

C#は独自eventを実装出来るし、そのためにdelegateが用意されているから、
「データフロープログラミング」を文法的にサポートしているとは言える。
ただ、それ以前に、「データフロープログラミング」が主流ではないが。
お前らも実際、やってないだろ。
関数型の次に来るって事もなさそうだし。

とはいえ、上記の通り、今のJavaScriptではデータフロープログラミングは面倒だし、
getter/setterを頑なに拒むC++ではものすごくウザくなって事実上無理だ。
次の波が来ればevent/delegateも再評価されるかもしれん。
2018/06/09(土) 17:12:21.10ID:MhKfyDgC0
>>398
> シングルキャストのデリゲートのリストとして実装する方法もあったはず
同感。
2018/06/09(土) 17:15:16.30ID:bMpGWGQ30
理解してなくても問題なく使えるからって、それを理解しようとするのは悪い事じゃないけど
もとの発端はなんだったんだこれ
2018/06/09(土) 17:28:51.92ID:AO7Grx3Qa
デリケートじゃないか?w
2018/06/09(土) 17:32:16.71ID:1jan2CXL0
>>401
>>326 のデリケートが事の発端
2018/06/09(土) 17:43:13.42ID:VOfp/P7BM
誰かさんの大好きなLinqはdelegateの塊なんだけどdelegateなくなっていいのかな
他の実装ではdelegate使ってないけど今の.netではデリゲートで実装されている
2018/06/09(土) 18:48:11.73ID:0oARoVrcM
デリゲートにラムダ式にLinq大好きだ!
これ無くして生きてけない!
チームの誰も読めないから放置されて我が道を歩んでいる。
生産性と品質が高いから客には好評です。
2018/06/09(土) 20:25:40.95ID:7jH+OfQ/0
>>405
チームの誰もが読めないという事は保守性に欠けると言う事ですね
2018/06/09(土) 20:33:41.95ID:0oARoVrcM
そうだね。
でも、Linqバリバリ使ったらそうなるよね。
みんなの勉強しろよってこと。
2018/06/09(土) 20:39:16.25ID:h8CnrujR0
Linqが分からないってのはラムダ式を理解できないってことなの?
2018/06/09(土) 20:43:00.38ID:54mp5fzVM
行列計算ライブラリ書いてるときに
おれ掛け算わからんからおれに合わせて全部足し算で実装して
おれはいまお前の案件に関わってないけど将来そのライブラリメンテするかもしれんからヨロシクな
とか言う同僚がいたらこいち頭おかしいのかなって思うじゃん
いやいや掛け算を勉強してからっていうか最低限の単位を取ってからメンテしろよってなるじゃん普通
これがLinqやλやデザインパターンになると当たり前のように底辺至上主義がまかり通る不思議な業界
2018/06/09(土) 20:47:26.87ID:kvLDmgw/0
LINQはC#にしかないからまだわかるけどラムダ式はいまどきの言語ならほぼ実装してるから知ってないとまずいよね
2018/06/09(土) 20:50:03.81ID:2splWvty0
linqてC#にしかないのか
2018/06/09(土) 20:52:58.46ID:54mp5fzVM
Linqにも類似品あるよ
Javaのstreamやpythonのリスト内包表記など
というかそもそも単なるiterator patternでしかないからC#が起源ってわけでもない
2018/06/09(土) 21:00:28.55ID:4y2IVpvw0
Linq以前にIEnumerableの意味が解らない人がいるからどうしようもない
.NET2.0から順に教えろってことかよ・・・
2018/06/09(土) 21:03:28.98ID:MhKfyDgC0
>>409
と、底辺至上主義がまかり通る所の意識高い系が申しております

>>412
どう見てもSQLが起源だろ
2018/06/09(土) 21:07:24.39ID:54mp5fzVM
>>414
クエリ形式の文法はSQLが起源かもしれんが
実装はSQLとは全く関係がないよ
C#などの実装はまさしくiterator patternだけど
SQLの実装をiterator patternでやろうとしたら遅すぎる
2018/06/09(土) 21:07:34.76ID:4W3gH+0Ua
そもそも書けない奴は論外として、使うなってのは同意できる
簡潔に判りやすいラムダ書いてくれりゃいいが、わざとやってんじゃねってぐらい難読化する奴いるからな
正規表現、SQ、掲示板の長文も同じだな
2018/06/09(土) 21:12:52.02ID:0oARoVrcM
Linqに限らず最近のソフトウェア技術は高度で生産性も高くなってる。
昔も人によって生産性に差が出たが、最近だと理解出来るか出来ないか?ぐらいの圧倒的な格差だ。
理由出来ない人は辞めればいい。
生産性が飛躍的に上がってるので理解出来る奴だけで間に合うよ。
418デフォルトの名無しさん (アウアウカー Sa2d-SmnY)
垢版 |
2018/06/09(土) 21:17:22.22ID:ekScYlKMa
自称プログラマー(趣味)ならともかく職業プログラマーでLinqすら理解出来ないやついんの?
2018/06/09(土) 21:23:52.36ID:7jH+OfQ/0
Linqを十分に理解できても、可読性や保守性を大事にする人は
多少冗長でも他人が理解しやすい易しいコードを書くんじゃないの?
2018/06/09(土) 21:25:54.76ID:2splWvty0
Linqてそんな可読性悪くないと思うけどなぁ
コメント書いときゃ何となくわかるべ
2018/06/09(土) 21:26:49.03ID:v7FNkyrH0
>>417
出来ない人にも生活あるから辞めろとは言えないけどチームは分けて欲しい
使えて使いたい人がどんどん流出して出来ない人だけの会社になると悲惨
2018/06/09(土) 21:30:02.70ID:0oARoVrcM
>>419
圧倒的に生産性が高かったらどうなの。
最近の案件は短納期になってるし、昔のコボルみたいに何十年もメンテして使うシステムも少ないと思う。
2018/06/09(土) 21:32:37.20ID:VrCE6n6GM
ゴミのようなやりとり
いや、ゴミに失礼だな
2018/06/09(土) 21:33:12.66ID:0oARoVrcM
LinqよりSQLの方が難しいぞ。
SQLは難しいから使うなって言うのか?
2018/06/09(土) 21:35:27.62ID:ZDY9COOVd
業務でいじるレベルのコードなんて知らないものでもグーグル先生いりゃ大抵なんとかならない?
linqも初めて見たときはとっつきにくくてわかりづらかったけど使ってりゃ嫌でも覚えちゃうよ
つっても当然すべてを使いこなしてるわけじゃなくて自分に必要な範囲のみ理解してる程度
業界によってだいぶ差はありそうだけど
2018/06/09(土) 21:35:56.65ID:7jH+OfQ/0
生産性は保守運用まで含めてトータルで考えるべきで
保守性が損なわれればトータルコストも引き上がる
2018/06/09(土) 21:36:22.73ID:0oARoVrcM
>>423
あんたの書き込みがゴミだから。
オレらのやりとりがゴミだって言うなら、そう感じさせる様な高踏的な書き込み頼む。
2018/06/09(土) 21:51:21.02ID:lCnNI9uz0
保守性の低い Linq のコードってたとえばどんなの?
自分は他人のを読む場合でも特に困ったことないけどな〜。
2018/06/09(土) 22:13:44.82ID:MhKfyDgC0
>>415
イテレータの起源なら、C++(1983)は最初から持ってた。
C++のOOPはSimula発で、そっちが持ってたかは知らん。

いずれにしても、Java発の技術は存在しないぞ。
C#はLinqと、多分asyncもか?頑張ってる方だと思うが。
(あとちょっと違うがIDEのインテリセンスもC#が初のはず)
2018/06/09(土) 22:18:01.39ID:a58WBe6r0
クソカスの分際で人間様に話しかけてくるな
クソカスが引っ付くわ
2018/06/09(土) 22:36:24.46ID:d5fCz/GJ0
>>429
> (あとちょっと違うがIDEのインテリセンスもC#が初のはず)
インテリセンスはVB5.0の時代からあるんだが...
2018/06/09(土) 22:41:24.00ID:MhKfyDgC0
>>425
> 自分に必要な範囲のみ理解してる程度
多分これくらいが適正で、これなら大して問題にならないんだよ。

問題は、意識高い系馬鹿の>>417
> 昔も人によって生産性に差が出たが、最近だと理解出来るか出来ないか?ぐらいの圧倒的な格差だ。
みたいな、おかしな奴がいることだよ。

Linq自体でそんなに格差が出来るはずもない。
仮に、Linq部分を関数呼び出しに変えたところで、本体のコード構造は全く変わらないだろ。
便利機能だが、その程度でしかないんだよ。
逆に言うと、制御構造の違いで勝負出来ない、
新文法が読めることしか威張れない馬鹿がそこに無駄に拘っている気がする。
2018/06/09(土) 23:00:28.94ID:0BGOlb7W0
linq で Where と OrderBy 使ったところをチームリーダーから For と List<T>.Sort() に書き換えられたことはある。理由は「他と違うから」
他と書き方を合わせておくのが大事なのはわかるけど…
2018/06/09(土) 23:10:59.82ID:1jan2CXL0
コーディング規約があるのならそれに合わせろよ
2018/06/09(土) 23:45:05.02ID:v7FNkyrH0
>>433
他と違うからって理由で直すのは良くないと思うな
本来関係ないはずのクラスの間に存在しないはずの関係性を作りこんでしまう
その結果、必要ない作業や、縛りを生み出して生産性を下げることになる
俺が経験したものだと
すでに書き終えたforeachをすべてforに統一
テスト済のDAO、DTOのsnake_caseを他レイヤに合わせてCamelCaseに統一
この2つが最高にバカバカしかった
2018/06/09(土) 23:56:36.61ID:wFjp4I59M
カプセル化を知らない人が少なくないのかな
「publicメンバーはクラス間のコミュニケーション円滑化のために規約として形式化しましょう」ぐらいならまあ理解できるが
「Linqはやめてループにしてくれ」なんて内部実装の形式にまで踏み込んでくるなよな
クラススコープで違和感なければそれでいいだろ
2018/06/09(土) 23:59:33.29ID:MhKfyDgC0
>>433
俺はC#erではないが…。

単発のLinqも認めてもらえないのならご愁傷様。あれは普通に読める範囲だ。
見た目、Linq自体にはサブクエリ無しか?ならそんな酷いことにはならないはずだが、
例えばSQLでは再帰呼び出しが出来たりして、
マンデルブロだパズル解くだとか、おかしな事になってる。
https://www.sqlite.org/lang_with.html
Linqでどこまで出来るか知らんが、こんなん書かれたら殴りたくもなるだろ。

基本的には関数呼び出しにしてその先は隠蔽、
つまりLinq実装かFor/List/Sort実装かは上位からは見えない、ってことにすれば関係ないはずだ。
ただ、その場にベタで「何を選択しているか」が書かれている方が読みやすいことは多々あり、
Linqもその局面で使われているとは思うので、全面書き直しだと余計に読みにくくなるとも思うが。
2018/06/10(日) 00:07:12.73ID:wNo6w9bX0
LINQってCube扱えるんだっけ?
2018/06/10(日) 00:11:20.35ID:FNJYuW1ra
>>436
どうでもいい議論だけど、一言。
カプセル化っていうのは「メソッドの中は可読性考えなくてよい」って意味じゃないよw

LINQ(というかクエリ式)嫌いの大半は批判してる人間がそもそも理解してないだけだと思うが一理はある。
それは使い方によっては複数の処理が有機的につながった、適切に分割統治されてない、
可読性の低いコードになるからだ

実際、筋の悪いプログラマが好む100行オーバーのメソッドに近い物になりうる
2018/06/10(日) 00:20:43.11ID:kZ6+r7gZM
>>439
どう読んだら「メソッドの中の可読性は考えなくていいよ」になるんだろ
外部の都合を内部実装にまで持ち込むな
クラス内での可読性が十分ならそれでいいだろ
って主張な
正しく動いて綺麗なコードを他のクラスの都合で書き直す
俺はこれある意味カプセル化破壊と言っていいと思う
もちろん本来の意味でのカプセル化とは違うのはわかってる
2018/06/10(日) 02:00:10.36ID:gGHljlXMa
>>440
どう読んでもそうとしか読めません
自分で自分の書いてあることが理解できないのかw

「メソッドの中は可読性考えなくてよい」と言っているのでなければ
>>436の1行目と4行目はつながらない。

カプセル化を理解していてもメソッドの中の可読性、例えば
「Linqはやめてループにしてくれ」と言うことはあり得る。

なぜなら、カプセル化とは「メソッドの中の可読性は考えなくていいよ」という意味ではないからだ
2018/06/10(日) 02:01:02.37ID:gGHljlXMa
>>441
いきなり訂正

× >>436の1行目と4行目はつながらない。
>>436の1行目と3行目はつながらない。
2018/06/10(日) 05:17:43.99ID:4PiVyKtW0
ランダムな指定回数オブジェクトを作成する方法ないですか
7時まで待つ
2018/06/10(日) 06:46:45.50ID:Kj8YEAmO0
>>441
横からだけど、そう思えるのはお前さんがLinq使ったら可読性悪くなるって決めつけてるからじゃないの?
2018/06/10(日) 06:46:55.66ID:CFkipoua0
Random
2018/06/10(日) 08:32:28.14ID:RI4Vnlqm0
>>435
コーディング規約を読んでないお前か
コーディング規約を定めてないお前の組織がバカなだけ
2018/06/10(日) 08:41:39.38ID:HMOXZXoS0
この話いつまでやるの?
2018/06/10(日) 08:43:37.52ID:kZ6+r7gZM
>>446
コーディング規約がバカなんだよ
2018/06/10(日) 09:22:16.29ID:z8uYskXvM
就職できるように頑張れ
450デフォルトの名無しさん (ワッチョイ 13e3-LHz9)
垢版 |
2018/06/10(日) 09:35:53.15ID:0WF1gq+N0
スレにも規約作って変な奴は矯正しないといかんな。
2018/06/10(日) 09:58:39.22ID:kZ6+r7gZM
変数を関数の先頭に書く
returnは1つまで
変数名の先頭に型の略字を書く
varは使ってはいけない

こういうひと昔前まで大衆が信じてたバカ規約
システム全体で統一感のあるコードを書くって規約もいずれその仲間入りするとおもう
いまはまだIT業界全体が未熟だからみんな気付いてないだけ
2018/06/10(日) 10:22:35.79ID:YCs8n+CmM
ちょっといいですか、この関数100行超えてます。
規約違反で可読性なくなります!
レビューで積極的に発言するサル、何も知らないで自分は立派なプログラム書いてると思っている。
ちなみににLinqの方が可読性上がるよ。
Linqはやりたいことをズバッと書ける。
古いやり方だと、このforループなに?ってなる。
forループは実装手段であって目的じゃないから。
単に慣れ、新しいこと勉強したくない連中が可読性だの規約だの持ち出す。
2018/06/10(日) 10:39:02.74ID:0nkwjY0q0
分割すれば良いじゃん
それが出来ないことを相手のせいにするな
2018/06/10(日) 11:01:43.43ID:wNo6w9bX0
魔板でやれや
2018/06/10(日) 12:09:56.40ID:ycwHE1rSa
>>444
どこが決めつけてる>>439
456デフォルトの名無しさん (ブーイモ MM05-UL3Q)
垢版 |
2018/06/10(日) 13:05:02.68ID:fXHYwG6AM
C#のLinqを使っているのならPythonの方が2倍速くなる
https://qiita.com/yniji/items/6585011633289a257888

C# の Linq が python の2倍遅い、は嘘
https://qiita.com/Akira_Kido_N/items/d9519b05ccee6a67158f
2018/06/10(日) 13:22:36.14ID:8jSf3er6M
俺が知りたいのは、オブジェクトをx回作るやり方なんだよ
2018/06/10(日) 13:47:05.85ID:FyF+mujLM
for(var i=0;i<n;i++)Days[i]=new Day(i);
2018/06/10(日) 14:27:51.17ID:A9qrJ+Er0
linqで発狂してるジジイはSQL絡みでよくわからないエラーに出くわして理解できなかったんじゃないの
2018/06/10(日) 17:59:54.77ID:Nj3/us+lM
もう全部varでええやろ
2018/06/10(日) 18:16:30.94ID:Ve8EHXbu0
保守性の低い Linq を使ったコードの実例を見たいんだけど。
2018/06/10(日) 18:55:50.21ID:FyF+mujLM
クエリ式を使ったのは単純なのはわかりやすいけど複雑になるとお手上げ
メソッド形式で使ったとしても逆にクエリ式のfromを二重の使ったほうがいいのにSelectManyを使ってるやつは非常に醜い
JoinやAggregateも可読性が以上に低い
2018/06/10(日) 18:58:38.79ID:0FFsGNUEa
意見は分かれると思うが、川俣大先生が連載記事で引用してた
このサンプルあたりがボーダーラインかね
https://docs.microsoft.com/ja-jp/dotnet/csharp/programming-guide/concepts/linq/how-to-query-for-duplicate-files-in-a-directory-tree-linq

個人的にはこれも読みづらい

実にどうでもいい話だが、LINQは頭字語のはずなのでLinqって表記には違和感しか感じない。
あと、これもくどいが、LINQじゃなくてクエリ式の話をしてるんじゃないのかと
2018/06/10(日) 19:04:29.50ID:FyF+mujLM
>>463
これはだめな例じゃないかな?
何をやってるかがわからない
2018/06/10(日) 19:22:31.41ID:0nkwjY0q0
これの事?
var queryDupNames =
  from file in fileList
  group file.FullName.Substring(charsToSkip) by file.Name into fileGroup
  where fileGroup.Count() > 1
  select fileGroup;

基礎的なものだけで構築されていて何をやっているか一目瞭然じゃん
2018/06/10(日) 19:59:10.70ID:7XGbwrsW0
これがわかんないって言うならもうlinq禁止しか無いね
そんな人間がいるプロジェクトには関わりたくないけど
2018/06/10(日) 20:06:35.03ID:kZ6+r7gZM
全員linq読めても将来読めない人がメンテするかもしれないから禁止
実際にあった話
2018/06/10(日) 20:19:14.72ID:Ve8EHXbu0
ああこれが分からないってんなら確かに LINQ 禁止だわ。w
でもそんなのに付き合ってやる義理はないんじゃね? あとは規約の問題だな。
2018/06/10(日) 20:29:40.62ID:FyF+mujLM
自分ならメソッド構文で書く
2018/06/10(日) 21:47:34.28ID:WVhS1nfV0
分からないなら勉強するなり聞くなりすればいいじゃんとは思うけどな
可読性あげるのは理解できるが便利な関数を規制するのはおかしいくない?
いつまでたっても個人の技術力上がらなくなるけどいいの?とは思う
2018/06/10(日) 21:54:10.88ID:FyF+mujLM
わからないって意味を誤解してるだろ

var queryDupNames = fileList.Groupby(f=>略, f=>略).Where(g=>g.Count>1);

メソッドだとほぼ一瞬で何をやってるかわかるだろ
わざわざ行数を割いて理解に時間のかかるクエリ式を使う意味はねえよ
2018/06/10(日) 22:13:28.91ID:WVhS1nfV0
あークエリ式じゃなくてラムダで書いた方が見やすいって話?
それなら同意
2018/06/10(日) 22:39:32.51ID:7XGbwrsW0
そんなんリファクタすりゃ済む話じゃん
2018/06/10(日) 22:43:36.88ID:mLmPdblh0
リファクタリングするにもユニットテストで担保取れないレベルの酷いプログラム沢山あるからなあ
2018/06/10(日) 22:53:21.31ID:kZ6+r7gZM
低レベルなプログラマに合わせたコードはテストしにくいひどいコードになりがち
インターフェース禁止だとか当たり前のように言ってくるからねあいつら
2018/06/10(日) 22:54:32.29ID:SjjA9sVt0
今日も自閉症の見本市
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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