1 名前:名無C mailto:sage [2019/03/07(木) 06:35:41.12 ID:6L3KEJfe0.net] !extend:checked:vvvvv:1000:512 次スレを立てる時は↑を2行冒頭に書くこと(1行分は消えて表示されない為) 「どんなにくだらないC#プログラミングやVisual C#の使い方に関する質問でも誰かが優しくレスをしてくれるスレッド」です。 他のスレッドでは書き込めないような低レベルな質問、 質問者自身なんだか意味がよく分からない質問、 ググろうにもキーワードが分からないなど、勇気をもって書き込んでください。 内容に応じて他スレ・他板へ行くことを勧められることがあります。ご了承下さい。 なお、テンプレが読めない回答者、議論をしたいだけの人は邪魔なので後述のC#相談室に移動して下さい。 C#に関係の無い話題や荒らしの相手や罵倒レスはやめてください >>980 を踏んだ人は新スレを建てて下さい。 >>980 が無理な場合、話し合って新スレを建てる人を決めて下さい。 ■関連スレ C#, C♯, C#相談室 Part93 mevius.5ch.net/test/read.cgi/tech/1492818720/ ■前スレ ふらっと C#,C♯,C#(初心者用) Part141 mevius.5ch.net/test/read.cgi/tech/1544839627/ ■コードを貼る場合は↓を使いましょう。 ideone.com/ https://dotnetfiddle.net/ ■情報源 https://docs.microsoft.com/ja-jp/dotnet/standard/class-libraries https://docs.microsoft.com/ja-jp/dotnet/csharp/language-reference/index https://docs.microsoft.com/en-us/dotnet/standard/class-libraries referencesource.microsoft.com/ VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
458 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 11:39:31.85 ID:cgZSyzeqa.net] >>448 https://docs.microsoft.com/en-us/dotnet/api/system.collections.generic.list-1.sort > This implementation performs an unstable sort ついでにいうとArray.Sortも不安定ソートで、Enumerable.OrderByと.ThenByは安定ソート
459 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 12:31:18.60 ID:3jwnQLuZ0.net] ソートはプログラムを覚えるために勉強するもので 実用上はライブラリ使えばいい ただ、勉強するネタとしては割と上質なもの
460 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 12:34:57.35 ID:y1/myRC20.net] (回答する方も)初心者スレらしくていい流れだね
461 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 12:46:19.25 ID:WZ0UQqME0.net] こういうの、listにロックをかけたのに何で同listを使う後続処理がすぐ実行されちゃうの? https://paiza.io/projects/e/EbjQiWv8ebNkW4bbkAY_YQ using System.Collections.Generic; using System.Threading.Tasks; using System; public class Hello{ public static void Main(){ var list = new List<int>(); for(int i=1; i<=1000; i++) { list.Add(i); } Task.Run(()=>{ lock(list){ Task.Delay(10000); } }); Console.WriteLine(list[123]); } }
462 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 12:51:36.48 ID:9BhkjmpP0.net] まだ、そんな産廃機能いじってんのか
463 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 13:00:01.62 ID:cgZSyzeqa.net] >>455 https://ufcpp.net/study/csharp/sp_thread.html#lock lock文はMonitor.EnterやMonitor.Exitを使った糖衣構文であって Monitor.Enterでロックを取得する(=既にロックされているなら、それが解放されるまで待つ) 例示コードではTask中ではlockしているもののConsole.WriteLine箇所はlockがないので、すぐに実行される
464 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 13:12:13.25 ID:6I4G/mIH0.net] >>455 lockの使い方が間違ってる(>>457 )のと、Task.Delay()の使い方が間違ってる。 Task.Delay()は通常awaitして使うがlockステートメント中では使えないので、Task.Delay().Wait()するか代わりにThread.Sleep()にする。 後、Task.Run()で作ったタスクが実行開始されたか考慮していないから、大抵はConsole.WriteLine()が先に実行される。
465 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 14:40:03.19 ID:T6P0EJpRd.net] >>441 俺だよ俺
466 名前:デフォルトの名無しさん [2019/04/21(日) 15:32:01.70 ID:WZ0UQqME0.net] ありがとう、このコードだと欠陥だらけなのか・・・・ 使用箇所ごとにLockが必要なのか、それとタスクより先に次の行が実行されてる可能性が高いのは全く気づいてなかった ただ、 >Task.Delay()は通常awaitして使うがlockステートメント中では使えないので、Task.Delay().Wait()するか代わりにThread.Sleep()にする。 っていうのはどういうことなの?Lock外にスレッドを返されちゃうのかしら?
467 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 16:07:55.74 ID:i587kr5jd.net] >>459 よおキチガイ
468 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 16:32:29.56 ID:RWXhngOc0.net] >>460 Task.Delay()だけだと完了を待ってないから、実質無いのと同じ
469 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 17:35:25.00 ID:F9kXeXwV0.net] >>460 ピーコックアンダーソンの非同期動画みてみればすぐに理解できるぞ
470 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 22:18:43.95 ID:rykfOnh80.net] 速度がどうとか言うんだったらc#なんか使うなよと少し思いました
471 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 22:35:33.45 ID:CLsKfNj20.net] >>464 少しってなんだよ!
472 名前:デフォルトの名無しさん mailto:sage [2019/04/21(日) 23:52:50.47 ID:SWXjVSz30.net] >>465 a little
473 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 04:23:42.26 ID:29e/0Uiq0.net] じゃあ残りの大半は何を思ってたの
474 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 19:50:45.64 ID:DglGSvcP0.net] ソートってポインタやmalloc, memcpyとか使ってこねくり回すのが楽しいのにC#だとイマイチだよね
475 名前:デフォルトの名無しさん [2019/04/22(月) 20:39:27.38 ID:Xu5D3g840.net] 独自に作成したユーザコントロールをdataGridViewのカラムに追加する処理を作成しているんですが 追加したものをそのまま削除するとうまく削除出来ず、一方のユーザコントロールが必ず画面上に残ってしまうんですが なぜでしょうか?原因がわからず悩んでいます どなたか教えてください //@ひとまず空のデータを作成してdataGridViewに格納 DataTable dt = new DataTable(); dt.Columns.AddRange(new DataColumn[] {new DataColumn(), new DataColumn(), }); dt.Rows.Add(new object[] { "", "" }); this.dataGridView1.DataSource = dt; //Aユーザコントロール1をdataGridViewに追加 UserControl1 userControl1 = new UserControl1(); this.dataGridView1.Controls.Add(userControl1); userControl1.Location = this.dataGridView1.GetCellDisplayRectangle(0, 0, true).Location; //Bユーザコントロール2をdataGridViewに追加 UserControl1 userControl2 = new UserControl1(); this.dataGridView1.Controls.Add(userControl2); userControl2.Location = this.dataGridView1.GetCellDisplayRectangle(1, 0, true).Location; //C追加したユーザコントロールを削除→何故かユーザコントロール2だけが残る dataGridView1.Controls.Clear();
476 名前:469 [2019/04/22(月) 20:40:58.08 ID:Xu5D3g840.net] ちなみに私が試したのはvisualStudioの2017です
477 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 20:42:29.96 ID:5zGuWDFU0.net] c#だと遅くて無理みたいな高尚なプログラム触ってないからよくわからん cppとc#でどれくれい違うん?
478 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 20:52:55.67 ID:doLks5OSd.net] >>471 何するかによるし言語仕様理解せずにコーディングすればC++だろうがC#だろうが遅くはなる 早くしたけりゃどの言語だってコンパイラが吐くコード見ろになるし極論アセンブラしてろになる シビアな演算速度求められるようなソフトじゃなきゃ気にするような速度は無い 個人的にいろいろ開発してて速度面で困ったことはない
479 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 21:35:41.32 ID:puVU3XKCM.net] 特定のアプリを監視して表示された文字(画像)をテキストにするアプリ作ったけど c#だとチェックに1秒、c++とGDIのDLLだと0.01秒とかそんな感じだった c#で作って必要ならc++にコンバートするのでいいと思う
480 名前:デフォルトの名無しさん mailto:sage [2019/04/22(月) 21:59:37.22 ID:a2wjQuhnM.net] >>468 unsafe使えば
481 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 00:01:21.36 ID:5LmBAPnu0.net] 画像処理とかその部分はunsafeとかcだろ。それぐらいは当たり前
482 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 00:14:05.59 ID:Bc6Ot9Tr0.net] 別にC#でいくらでも早くできるけどそれしないでC++より遅いってそりゃそうだよねとしか GCの恩恵受けてunsafe使わずセーフティな状態でしょ 突き詰めたC++と突き詰めたC#なら.NETで動く分C#が不利なのは仕方ない 突き詰める必要がない部分で恩恵を受けられるんだから、処理速度以外にメリット感じないなら速い言語やればいい 言語なんて所詮道具なんだから適材適所
483 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 00:15:59.36 ID:lAbUfbw70.net] sleepが1ms単位指定なのに平気で30msくらいかかったりする
484 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 00:21:34.72 ID:Qu51xl5v0.net] >>477 Windowsの仕様なのでC#と関係なく発生するよ
485 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 00:22:35.63 ID:1xhRm/Xtd.net] OSの内部クロックのせい
486 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 02:07:58.81 ID:TPVsn91QM.net] >>473 そりゃあおまえさんのコードが糞なだけや
487 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 02:09:14.72 ID:V6IaHlzqa.net] OSにクロックはないでしょうw いやスケジューリングとかタイムスライスとかそんなことが言いたいんだとは思うけど
488 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 02:35:38.55 ID:1xhRm/Xtd.net] >>481 え…
489 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 07:53:20.75 ID:5v63vvPIa.net] TickCountの事だと思う。
490 名前:デフォルトの名無しさん [2019/04/23(火) 11:11:38.25 ID:D0U8cwP90.net] awaitのついた文の次の文を実行する際に、await前と同じスレッドに帰ってきてもらうことってできないの?
491 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 11:25:52.45 ID:NBcK336D0.net] 元のスレッドがそういうことできる機能を持ってればできるよ WinFormやWPFのGUIスレッドはメッセージループで実現してて それらの場合はGUIスレッドでawaitすればGUIスレッドに戻ってくるのが既定だし
492 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 12:18:02.90 ID:m6tbNaeWM.net] Pythonでカラー画像をRGBごとに分割して出力するスクリプトを書いたんだけど、 opencv使わずにC#でも出来るのかな? C#でもnumpyみたいなの無いの?
493 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 12:20:58.93 ID:4ETsFZLA0.net] どんだけ馬鹿なんだよ
494 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 13:00:40.13 ID:N4fQ2uHcd.net] >>486 numpyってrubyですか?
495 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 15:41:23.24 ID:elaW7zc+0.net] >>486 まんまは無いけど部分的にだったら何らかのライブラリで補完できるんじゃないかな? これとか https://numerics.mathdotnet.com
496 名前:デフォルトの名無しさん [2019/04/23(火) 16:29:44.88 ID:D0U8cwP90.net] >>485 コンソールアプリ等だとなかなか難しいんかな
497 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 16:33:48.41 ID:EaCRsjQU0.net] >>490 Task.WaitAnyとかでできんもんか?
498 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 17:58:47.89 ID:xFm0RmkHa.net] >>484 いやいや最初から同じスレッドですからww そもそも同一メソッド内で別のスレッドを起動することはあっても 実行中に途中のスレッドに切り替わるとかそんなのありえへんwww
499 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 19:05:14.26 ID:hvzt5+/sd.net] >>492 しょうもない嘘をつくな
500 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 19:28:13.89 ID:2vLu2U8QM.net] 誤解が誤解を生む 仕様について理解が足りない
501 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 19:35:04.22 ID:xFm0RmkHa.net] ネタじゃなくて本気で変な誤解してるのか... メソッドの途中で行が変わると別のスレッドで実行されるとかそんな言語怖くて使えないよwww
502 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 19:36:05.31 ID:2vLu2U8QM.net] お前は勘違いしてる GUIとCUIで仕様が違ってる
503 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 19:50:14.81 ID:2vLu2U8QM.net] await/asyncは単なるTask非同期処理を簡易的に書ける糖衣構文 次にawaitの次をどのスレッドになるかはその時の状態次第 GUIではそれでは困るのでデフォルトで同じスレッドが処理をするようにしてあるだけ
504 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 20:19:35.25 ID:xFm0RmkHa.net] 訳のわからん勘違いをしてるのはどっちだよ 自信満々で馬鹿じゃないマジで
505 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 20:30:14.95 ID:aIitEIPQ0.net] https://ufcpp.wordpress.com/2012/11/12/asyncawait%E3%81%A8%E5%90%8C%E6%99%82%E5%AE%9F%E8%A1%8C%E5%88%B6%E5%BE%A1/
506 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 20:30:27.32 ID:PlCSQgU2M.net] deligate
507 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 20:36:54.48 ID:iDnak3xha.net] >>495 https://ideone.com/7wVOXT
508 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 20:41:16.72 ID:xFm0RmkHa.net] 勘違いをしているのは俺の方だった... 申し訳ないですw
509 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 21:04:08.70 ID:2vLu2U8QM.net] すなおでいいんでない?
510 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 21:19:00.48 ID:7omDh/oid.net] 煽る時点で目糞鼻糞
511 名前:デフォルトの名無しさん [2019/04/23(火) 21:57:22.24 ID:D0U8cwP90.net] 同じスレッドに戻ってきてもらうのに、簡単な方法ってないのかな・・・・
512 名前:デフォルトの名無しさん mailto:sage [2019/04/23(火) 22:10:23.58 ID:iDnak3xha.net] >>505 >>490 を見るに、コンソールアプリで特定スレッドで処理したいみたいだけど、どういった理由? GUIなら、時間がかかる処理は別スレッドで、画面更新は絶対にUIスレッドで、といった使い分けがあるけど CUIで特定スレッドを意識する理由がちょっと思いつかないんだ
513 名前:デフォルトの名無しさん [2019/04/23(火) 22:42:29.23 ID:D0U8cwP90.net] >>506 WebAPIサーバを作りたく、その中で扱うデータについてトランザクション処理みたいなことをしたかったんです 通信関連でAwaitが多用されている中でも、データのロックをできるだけ減らしたい、またうっかりミスしてロック外に出ないでほしいと思ったんです
514 名前:デフォルトの名無しさん mailto:sage [2019/04/24(水) 00:21:10.86 ID:9Dlmymg8a.net] >>507 それを聞いても、「特定スレッドで絶対に処理したい」が主目標にはならない気がする 「ロックにReaderWriterLockSlimを使っていて、ロック取得と解放は同じスレッドで行う必要がある」のような状況ならまだ分かるんだけど もしもこの状況であるなら、SemaphoreSlimでロックするようにすれば、WaitOneAsyncで待つスレッドと、Releaseするスレッドを別にできる(=間でawaitできる) 万一本当に何か理由があって特定スレッドで処理を続けたいのなら、Taskをawaitするのでなく.Wait()で待つようにすれば、スレッドは切り替わらなくなる > うっかりミスしてロック外に出ないでほしい これが「ロックを取得したけど、解放を忘れる」ことを指すのであれば try {} finally {} や、ラップクラスを作ってIDisposable実装してusing() {} するのが対策になるかもしれない 取得と解放がメソッドを跨いだりするなら面倒くさくなるけど……
515 名前:デフォルトの名無しさん mailto:sage [2019/04/25(木) 23:50:01.61 ID:1l/c830P0.net] https://ideone.com/TM1zJh if (ob.volume == volume)この部分なのですが 左辺は引数で取ったobのメンバ変数であることは分かるのですが右辺はどのメンバ変数なんでしょうか? 入門書のコードなのですが…
516 名前:デフォルトの名無しさん [2019/04/25(木) 23:52:47.61 ID:LJHMbymK0.net] >>509 6行目
517 名前:デフォルトの名無しさん mailto:sage [2019/04/25(木) 23:54:19.01 ID:LJHMbymK0.net] いや、thisって答えた方が良いのか
518 名前:デフォルトの名無しさん mailto:sage [2019/04/25(木) 23:59:26.79 ID:8Sf9N2Ww0.net] 19行目にも同じ構造があるけどそっちはすんなり入ったんだろうか
519 名前:デフォルトの名無しさん mailto:sage [2019/04/26(金) 00:01:25.44 ID:6Aa9jI4a0.net] >>510 メソッドを呼び出したob1のメンバってことですかね? 理解できました。ありがとうございます
520 名前:デフォルトの名無しさん mailto:sage [2019/04/26(金) 23:30:08.64 ID:9lAtl2Yi0.net] コンストラクタ内で例外をthrowするのはご法度ですか?
521 名前:デフォルトの名無しさん mailto:sage [2019/04/26(金) 23:43:18.42 ID:p/I2x8fjd.net] >>514 定石ですよ [] [ここ壊れてます]
523 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 00:06:35.36 ID:Ern7/KCha.net] >>514 ご法度ではないし、むしろインスタンスを正しく構築できないなら積極的にthrowしてほしい 例えばStreamReader(String)の場合、ArgumentException系列から FileNotFoundExceptionやDirectoryNotFoundExceptionのIOException系列までthrowする
524 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 00:38:42.27 ID:yEc5G7yUM.net] 悪いとは言わないけど、最近はあまりコンストラクタで例外投げるような処理やらなくなったなあ 何故かと考えたら、async/awaitのせいだと気付いた コンストラクタではawaitできないから、昔みたいにコンストラクタでファイル読んだりするのはほぼ無くなった
525 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 00:45:53.35 ID:k66IsG4/a.net] あとDIと相性が悪い DI使ってると、コンストラクタで例外投げたらそもそもアプリが起動しない
526 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 02:44:50.91 ID:ni4YCIMc0.net] ドキュメントもコンストラクタで投げる可能性のある例外一覧が必要になるけど 実際あげきれなくて手薄になりがち そうなると設計できない 例外の種類でその後の動作をハンドリングしたいときに動かしてみて キャッチの種類を分けるしかない 仕様書に書いてあるこのエラー出せないんすけど? このときの例外増やしてもらえます? →入れた引数から判断できるでしょ?とかキチガイかよって
527 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 02:55:41.53 ID:TtZ/uEZc0.net] >>519 例外の種類を完全に把握できないのはコンストラクタに限ったことではないだろ
528 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 03:07:26.16 ID:ni4YCIMc0.net] >>520 そもそも例外嫌いなんよ俺 ビジネスロジックだとほぼ全部把握しないといけないのに 丸っと渡されると困るだけじゃん
529 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 03:45:53.67 ID:TtZ/uEZc0.net] その例外を全部把握しなきゃいけないというのがアホな考えなんだよ 予期できないのはExeceptionとしてまとめてキャッチして処理しとけばなんの問題もないね
530 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 06:32:15.89 ID:QhVWSAZD0.net] どっちも乱暴だな
531 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 07:35:46.92 ID:3SWE0tmA0.net] 例外は握りつぶすのが定石
532 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 08:12:46.03 ID:PiMoxWjk0.net] >>522 設計書になんて書くん? 俺んとこ例外使うなら設計書に書いてない例外出しちゃうと大変なんだよ MSのドキュメントも全部はねーし マジ厄介 でもお客の言い分もわかる気がするんだよね 流石に何が来るかわかりませんってのはどうなの? って思う
533 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 08:15:07.62 ID:PiMoxWjk0.net] >>522 ああ、だから例外返さないよねそれ
534 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 08:34:22.02 ID:9yG2LI1yd.net] 例外の発生要因なんてあらゆるものがあるんだから全部明示しろというお客の主張が不条理 設計書に例外全部明示しろとか要求されたことないね
535 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 08:51:37.56 ID:yNGf8etVa.net] 規約が足かせになってる場合は無視したほうがいい スキル低い人が大昔に作った規約かもしれないし 例外は復旧可能かつ復旧したいものだけキャッチして対処 それ以外はアスペクトでまとめて処理すればいいよ
536 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 09:11:45.63 ID:ibduGkrL0.net] コンストラクタで例外がってC+出身者みたいだな
537 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 09:25:13.44 ID:YyIkYDM+0.net] >>529 .NET Frameworkクラスもコンストラクタで例外投げるのに?
538 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 09:26:49.68 ID:k66IsG4/a.net] >>529 C++のその説は迷信だけど、C#では事実としてawaitができないという重大な制約があるからなあ コンストラクタで例外を投げてはいけないわけではないが、そもそも例外を投げる可能性のあるような処理をコンストラクタでやらせることができるケースが少ないのは間違いない
539 名前:531 mailto:sage [2019/04/27(土) 09:33:56.80 ID:k66IsG4/a.net] もちろん、ArgumentNullExceptionのようにバグを検出してアプリを落とすことを目的とする例外は別だよ そういうのを除けば、例外を投げうる処理ってのはだいたいIOを含んでいてawaitが必要になるケースが多い
540 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 09:36:37.55 ID:yyWoHVeQa.net] いまだにオブジェクト倶楽部のをベースにしたC#コーディング規約なのかな 10年くらい前の時点でも悪評ぷんぷんだったのにどれだけ時代遅れなことしてるんだ コーディング規約作ってる奴のスキルが低い/古すぎ/多言語の知識しか持ち合わせてなくて クソな規約になってることはよくある コンストラクタで例外吐くのが望ましくないのはC++の話であってC#ではそんなこと全然ない 例外すべて列挙しなきゃいけないのはJavaの話であってC#にもそれを持ち込むのはナンセンス でも大抵規約のクソさ加減と規約作成者・組織の老害度は比例するんだよな 指摘しても直ることはないだろうから「これはクソなコードだ」と自覚を持ったうえで 規約通りのコードを書くしかない
541 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 11:46:22.17 ID:V1c8eqNrM.net] >>527 それって制御できないって言ってるんだよね? その時はtry catchで握り潰せばいいんだけど 君はどうなればいいと思ってるの? ある日例外が起きてアプリが止まっちゃってもそれは時代の流れでしょうがないと思ってるってこと?
542 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 12:00:49.48 ID:ASguEO4td.net] >>534 予期せぬ例外が起きたら発生箇所のスタックトレースを表示させてバグ修正に役立てるよ 客もその画面キャプチャを送ってくれる Execeptionにはそういうデバッグに役立つ情報入ってるからマジ便利だわ
543 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 12:01:52.85 ID:reMuF7mTd.net] >>535 客にスタックトレース見せちゃだめw
544 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 12:22:00.72 ID:yNGf8etVa.net] コンストラクタで例外を出すのが妥当なら出すべきだ しかし、例外を出すような責務は得てしてファクトリやリポジトリなど外部のクラスが担うことが多い傾向にある なので正確に言うと、オブジェクトの生成という責務を分離してない汚いプログラムはダメだ、なんだけど それが誤って拡散した結果、コンストラクタで例外を出すプログラムはダメだ、に拡大解釈されてしまったのだろう // コレは生成責務が分離されてないからダメだ class Hoge { public Hoge(int id) { var dto = DB.FindHoge(id); // 例外なげる m_id = id; m_name = dto.name; } // コレは責務が分離されてるからOK class HogeRepository { public Hoge Find(int id) { var dto = m_db.FindHoge(id); // 例外なげる return new Hoge(id, dto.name); // 実装次第で投げたり投げなかったり } // コレもOK 例外投げるが責務としては妥当 class Hoge { public Hoge(int id, string name) { if (id < 0) throw new BadHogeFormat("id"); if (UTIL.NotMatch(@"^H\d{8}$", name)) throw new BadHogeFormat("name"); m_id = id; m_name = name; }
545 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 13:20:27.71 ID:rUmkpmPg0.net] >>533 > コンストラクタで例外吐くのが望ましくないのはC++の話であって そんな話は聞いたことないが?
546 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 13:38:48.88 ID:ibduGkrL0.net] C+の話は C+のコンストラクタとデストラクタの言語仕様をよく理解してない奴の誤解だから もともと正しくない
547 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 13:43:38.03 ID:bs+zTlgP0.net] >>539 お前はさっきから何の言語の話をしているんだ?
548 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 13:45:42.92 ID:ibduGkrL0.net] 話しかけるなゴミが
549 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 13:46:18.87 ID:vrUpwJdGa.net] ダメも糞も引数が不適切なら例外投げるしかないねそもそもw もちろん(注意喚起とか)何らかの意図を持ってあえてコンストラクタではなく ファクトリーメソッドやTryCreateXxxxにする方法もあるけど、 少なくとも誰が考えても引数が不適切なら例外発生が予見できるなら コンストラクタで例外投げて何も問題ない
550 名前:デフォルトの名無しさん [2019/04/27(土) 16:53:30.48 ID:hssASZhyF.net] デストラクタで例外吐くのはあり?
551 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 16:57:52.36 ID:krlg75LI0.net] どこならokとかngとかじゃなくて例外が発生したなら吐かなきゃ駄目 例外の前提を変えちゃ駄目
552 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 19:59:50.65 ID:UyCSNWt+M.net] >>543 基本的になし デストラクタの意味がなくなるから
553 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 20:00:47.02 ID:rUmkpmPg0.net] >>543 なし
554 名前:デフォルトの名無しさん [2019/04/27(土) 20:39:48.83 ID:ucBEJWSU0.net] デストラクタって解放し忘れたアンマネージドリソースの解放をするためにある奴でしょ? ただそれだけの処理に例外とか要る?
555 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 20:43:57.48 ID:xE/0VH9u0.net] >>547 どんな想定かわからないし入れたい人は入れればいいんじゃないの
556 名前:デフォルトの名無しさん [2019/04/27(土) 21:09:36.81 ID:ucBEJWSU0.net] C#のデストラクタは実行タイミングが不明な上に 他でキャッチできないからそのままクラッシュする事になるが それが目的なら
557 名前:デフォルトの名無しさん mailto:sage [2019/04/27(土) 22:32:08.58 ID:krlg75LI0.net] デストラクタであろうと例外が発生したなら吐くべき デストラクタで例外なら大体最終的にアプリ落とす結果になるだろうけど 普通に設計すりゃまずデストラクタで例外が必要にはならんとは思うが
558 名前:デフォルトの名無しさん mailto:sage [2019/04/28(日) 07:43:44.94 ID:Rwl5KJzI0.net] そりゃどこでも例外が出りゃ吐くべきだろ。デストラクタで出た例外は握りつぶせとでもいうのかよ