!extend:checked:vvvvv:1000:512
■Visual Studio 2017 Community(無償の統合開発環境)等はこちら
http://www.visualstudio.com/downloads/
■コードを貼る場合はこちら
http://ideone.com/
■前スレ
C#, C♯, C#相談室 Part93
http://mevius.5ch.net/test/read.cgi/tech/1492818720/
■次スレは>>970が建てる事。
建てられない場合は他を指定する事。
VIPQ2_EXTDAT: checked:vvvvv:1000:512:----: EXT was configured
探検
C#, C♯, C#相談室 Part94
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (ワッチョイ 935f-5Uxj)
2019/03/20(水) 18:57:36.47ID:ZZcTomnN0566デフォルトの名無しさん (テテンテンテン MM4f-wfqF)
2021/06/29(火) 20:27:18.03ID:rWI2BDyVM >>564
まず意味が分からんけどFormなの?Dialogなの?
まず意味が分からんけどFormなの?Dialogなの?
567デフォルトの名無しさん (スップ Sddf-zwXB)
2021/06/29(火) 20:55:15.95ID:Q5UZxny0d568デフォルトの名無しさん (テテンテンテン MM4f-wfqF)
2021/06/29(火) 21:01:59.16ID:rWI2BDyVM それ以前の根本的な問題があるのだろう
君には無理とは言わないがしばらく距離を置こう
君には無理とは言わないがしばらく距離を置こう
569デフォルトの名無しさん (ワッチョイ 3f6a-wfqF)
2021/06/29(火) 21:47:21.44ID:88YgLK/80 変な所でフォーム表示しようとしてんじゃね
そのコードだけじゃなくてメソッドごと見せてみ
そのコードだけじゃなくてメソッドごと見せてみ
570デフォルトの名無しさん (スップ Sddf-zwXB)
2021/06/30(水) 00:22:51.11ID:Fi37N+TOd >>569
FormAにはwebview2を配置していて、ブラウジングさせています
通常のサイト閲覧は何も問題ないのですが、ブラウザ上でエクセルが開けるoffice365を使用中、新規作成で開くときだけ呼び出し元のフォーム(上でこことしたところ)で停止します
既存のエクセルファイルなんかはFormA上のwebview2できちんと開けているのですが
なので、自分で書いた特定のメソッド中のエラーではなく、ページ遷移中に停止し、呼び出し元のShowdialogのところに戻ってハンドルエラーになってしまいます
FormAにはwebview2を配置していて、ブラウジングさせています
通常のサイト閲覧は何も問題ないのですが、ブラウザ上でエクセルが開けるoffice365を使用中、新規作成で開くときだけ呼び出し元のフォーム(上でこことしたところ)で停止します
既存のエクセルファイルなんかはFormA上のwebview2できちんと開けているのですが
なので、自分で書いた特定のメソッド中のエラーではなく、ページ遷移中に停止し、呼び出し元のShowdialogのところに戻ってハンドルエラーになってしまいます
571デフォルトの名無しさん (ワッチョイ 0f24-Z7qm)
2021/06/30(水) 00:39:45.90ID:4AL6ulTf0 再現する最小コードを作る
それでも不明ならその最小コードを公開して質問
それでも不明ならその最小コードを公開して質問
572デフォルトの名無しさん (ラクッペペ MMc6-RqJL)
2021/07/03(土) 03:25:24.72ID:ez5RskFXM ゲイツが収入マイナス7兆円ぐらいで苦しんでる。
c# プログラマから金を集めて、ゲイツに寄付するべきだと思う。
損失の一部 5兆円ほどc#プログラマから強制的に集めたい。国内に5万人ぐらいc#プログラマはいるから、1人1億ぐらい払えばいい。
土地とか家を売ればこんぐらい払えると思う。
払えないひとは肝臓とか売ればいい。
c# プログラマから金を集めて、ゲイツに寄付するべきだと思う。
損失の一部 5兆円ほどc#プログラマから強制的に集めたい。国内に5万人ぐらいc#プログラマはいるから、1人1億ぐらい払えばいい。
土地とか家を売ればこんぐらい払えると思う。
払えないひとは肝臓とか売ればいい。
573デフォルトの名無しさん (ワッチョイ a3b5-U8JP)
2021/07/03(土) 05:01:54.92ID:DAcib8Yu0 >>572
では早速言い出しっぺのあなた様から肝臓を差し出して下さい
では早速言い出しっぺのあなた様から肝臓を差し出して下さい
574デフォルトの名無しさん (ワッチョイ 27ad-Is9n)
2021/07/03(土) 06:04:33.61ID:+HNBKtJi0 では血をとらずに肝臓だけ取り出してください
575デフォルトの名無しさん (テテンテンテン MMc6-jDGG)
2021/07/03(土) 09:59:13.80ID:gTgAsOHbM 何そのハムレット
576デフォルトの名無しさん (ワッチョイ deda-BgM4)
2021/07/03(土) 10:22:53.43ID:ZeViGhZj0 アンキモ以下の脂肪肝なら処分料が欲しいな
577デフォルトの名無しさん (アウアウウー Sacf-jDGG)
2021/07/03(土) 11:22:03.96ID:fanuEOjba ヴェニスの商人では?
578デフォルトの名無しさん (ワッチョイ 6f54-SLQ7)
2021/07/05(月) 15:24:59.38ID:ZSz/R5WI0 DBから取得した重複なしの文字列List (要素数約4000) をComboBoxのDataSourceにセットする処理が、
約900ms〜1100msかかり、その間Formが固まるのですが、どうすれば固まるのを回避できるでしょうか。
A5M2でSELECTクエリの所要時間を見ると、だいたい700ms〜900ms台で、ここは改善のしようがなさそうです。
約900ms〜1100msかかり、その間Formが固まるのですが、どうすれば固まるのを回避できるでしょうか。
A5M2でSELECTクエリの所要時間を見ると、だいたい700ms〜900ms台で、ここは改善のしようがなさそうです。
579デフォルトの名無しさん (ワッチョイ 8e7c-BDhO)
2021/07/05(月) 15:45:29.72ID:5mYpWHh80 ComboBoxで4000の中から選ぶのは大変そうだな
DataSourceに設定する前後にComboBox::BeginUpdate/EndUpdateを呼べば多少は改善すると思う
それ以上はComboBoxじゃ無理じゃないかな 仮想モードもないし
DataSourceに設定する前後にComboBox::BeginUpdate/EndUpdateを呼べば多少は改善すると思う
それ以上はComboBoxじゃ無理じゃないかな 仮想モードもないし
580デフォルトの名無しさん (ワッチョイ 7f7c-Pyw0)
2021/07/05(月) 16:04:21.63ID:yitPGA0i0 やばそう
581デフォルトの名無しさん (ワッチョイ 4a01-J3mH)
2021/07/05(月) 16:35:24.72ID:lQZs6uo50 >>578
DBからデータ取得する処理は非同期に
DBからデータ取得する処理は非同期に
582デフォルトの名無しさん (ワッチョイ 8ae4-06wU)
2021/07/05(月) 16:53:08.67ID:S2aqSQgd0583デフォルトの名無しさん (ワッチョイ 8e2d-NaZp)
2021/07/05(月) 17:11:11.76ID:ynDVyPDO0 awaitしとけばUIスレッドに戻ってくるからInvoke要らんだろ
584578 (ワッチョイ 6f54-SLQ7)
2021/07/05(月) 17:14:42.74ID:ZSz/R5WI0 みなさんありがとうございます。
BeginUpdateとEndUpdateで20〜40msほど早くなりました。
現状、DBからの取得部分は別スレッドにしています。
ただし、フォーム表示時に、
@ComboBox の DataSource に List をセット。
A別の個所で設定した値で、ComboBox.SelectedItemを決定。
BComboBox.SelectedItem に応じて、それに対応するデータを DataGridView に表示。
という処理をしているので、結局ComboBoxへのDataSourceセット待ちになります。
むしろUIと同じスレッドでデータ取得すればスレッド切り替え処理がなくなって微妙に高速化出来るんじゃ?と思ってます。
BeginUpdateとEndUpdateで20〜40msほど早くなりました。
現状、DBからの取得部分は別スレッドにしています。
ただし、フォーム表示時に、
@ComboBox の DataSource に List をセット。
A別の個所で設定した値で、ComboBox.SelectedItemを決定。
BComboBox.SelectedItem に応じて、それに対応するデータを DataGridView に表示。
という処理をしているので、結局ComboBoxへのDataSourceセット待ちになります。
むしろUIと同じスレッドでデータ取得すればスレッド切り替え処理がなくなって微妙に高速化出来るんじゃ?と思ってます。
585578 (ワッチョイ 6f54-SLQ7)
2021/07/05(月) 17:33:32.24ID:ZSz/R5WI0 データ取得をUIスレッドで行ってみましたが、別スレッドでしたケースと比較して、実行するたびに優劣変わる程度でした。
これ以上の改善は無理そうなのでいったん諦めます。
これ以上の改善は無理そうなのでいったん諦めます。
586デフォルトの名無しさん (ワッチョイ 4a01-J3mH)
2021/07/05(月) 17:41:30.27ID:lQZs6uo50 Formが固まるのを回避したいってのは高速化したいということだったのか・・・
ま、がんばって
ま、がんばって
587デフォルトの名無しさん (ワッチョイ 6b01-Q9JX)
2021/07/05(月) 17:41:33.62ID:ykFrWqkT0 >>578
転送時に圧縮かけたら高速化するんじゃね
構成わからんからあてずっぽうでいうけど
DBサーバと近いWEB鯖のPHPでデータ一覧取得してJSONとかで転送(要するにPHPでAPI作成)
サーバの設定等でHTTP圧縮をON
圧縮かかってるから転送そのものが高速化される
どうやって圧縮かけるかは他にも色々やり方あるだろうけどね
LAN内に全てそろってる(例えば同一PC内)としてもかなり速くなるはずだよ
クエリで700msってのが気になるけど時間かかりすぎじゃないかな
Explainみた?
プロファイラはどう?昔はEQATEC Profiler使ってたけど今は何がいいんだろうね
どこにどれぐらいの時間がかかってるかわからないと理論値と比較できない
初見の感想は4000件程度で700msもかかってるのが気になる
応答だけ?それとも結果の羅列まで込みの時間かな
クラサバでそんなにかかる処理ってあまりないと思う
転送時に圧縮かけたら高速化するんじゃね
構成わからんからあてずっぽうでいうけど
DBサーバと近いWEB鯖のPHPでデータ一覧取得してJSONとかで転送(要するにPHPでAPI作成)
サーバの設定等でHTTP圧縮をON
圧縮かかってるから転送そのものが高速化される
どうやって圧縮かけるかは他にも色々やり方あるだろうけどね
LAN内に全てそろってる(例えば同一PC内)としてもかなり速くなるはずだよ
クエリで700msってのが気になるけど時間かかりすぎじゃないかな
Explainみた?
プロファイラはどう?昔はEQATEC Profiler使ってたけど今は何がいいんだろうね
どこにどれぐらいの時間がかかってるかわからないと理論値と比較できない
初見の感想は4000件程度で700msもかかってるのが気になる
応答だけ?それとも結果の羅列まで込みの時間かな
クラサバでそんなにかかる処理ってあまりないと思う
588デフォルトの名無しさん (ワッチョイ 6b01-Q9JX)
2021/07/05(月) 17:46:44.69ID:ykFrWqkT0 そもそも一瞬で取得すれば固まらないからね
あとはUIに先回りして裏で取得するとか、DB側でキャッシュするとか、小出しにしていくとか・・・
まぁ、一番簡単なのは画面にプログレスバー出してめっちゃ高速に処理してる風を装う事とかだけど
ただ、何も知らずに直観でいうと100msは切るはず
あとはUIに先回りして裏で取得するとか、DB側でキャッシュするとか、小出しにしていくとか・・・
まぁ、一番簡単なのは画面にプログレスバー出してめっちゃ高速に処理してる風を装う事とかだけど
ただ、何も知らずに直観でいうと100msは切るはず
589デフォルトの名無しさん (エアペラ SDd6-fsCC)
2021/07/05(月) 17:58:05.85ID:7JzKdw7cD 実処理時間と言うより、
取得中に割り込み入れないと固まったように見えるってだけの話では
取得中に割り込み入れないと固まったように見えるってだけの話では
590デフォルトの名無しさん (ワッチョイ 8e2d-NaZp)
2021/07/05(月) 18:09:58.95ID:ynDVyPDO0591デフォルトの名無しさん (アウアウウー Sacf-US9C)
2021/07/05(月) 19:11:56.65ID:IA8ZeXCsa たぶん「犯人」はComboBoxだろうが一応問題の切り分けが必要だと思って
public Form1()
{
InitializeComponent();
var asm = Assembly.GetAssembly(typeof(Form));
var bl = new BindingList<Type>();
foreach (var item in asm.GetTypes()) bl.Add(item);
var sw = Stopwatch.StartNew();
comboBox1.DisplayMember = "Name";
comboBox1.DataSource = bl;
Console.WriteLine($"Time = {sw.ElapsedMilliseconds} ms, Number of Items = {bl.Count}");
}
こんなコードを書いてみた。10年前のポンコツPCで実行してるが約2400個のアイテムをぶち込むのに
デバッグモードでも10ms程度の時間しか掛からない。
つまり「犯人」はComboBoxじゃないんじゃないの?知らんけど。
public Form1()
{
InitializeComponent();
var asm = Assembly.GetAssembly(typeof(Form));
var bl = new BindingList<Type>();
foreach (var item in asm.GetTypes()) bl.Add(item);
var sw = Stopwatch.StartNew();
comboBox1.DisplayMember = "Name";
comboBox1.DataSource = bl;
Console.WriteLine($"Time = {sw.ElapsedMilliseconds} ms, Number of Items = {bl.Count}");
}
こんなコードを書いてみた。10年前のポンコツPCで実行してるが約2400個のアイテムをぶち込むのに
デバッグモードでも10ms程度の時間しか掛からない。
つまり「犯人」はComboBoxじゃないんじゃないの?知らんけど。
592デフォルトの名無しさん (ワッチョイ 8e2d-NaZp)
2021/07/05(月) 19:44:16.85ID:ynDVyPDO0593デフォルトの名無しさん (ワッチョイ ab2c-Ijop)
2021/07/06(火) 01:07:39.66ID:AJxevGXU0 DB の実行計画を見れば?
インデックスを使わずに、全件探索でもしてるのでは?
2分探索なら、2 ^ 10 = 1,024
2 ^ 12 = 4,096
つまり、12回探索するだけ
ミックの本でも読んだ方がよい
インデックスを使わずに、全件探索でもしてるのでは?
2分探索なら、2 ^ 10 = 1,024
2 ^ 12 = 4,096
つまり、12回探索するだけ
ミックの本でも読んだ方がよい
594デフォルトの名無しさん (アウアウウー Sacf-uurJ)
2021/07/06(火) 07:28:36.60ID:kC5iABNna >>593
その前にソートな
その前にソートな
595デフォルトの名無しさん (ワッチョイ 27ad-Is9n)
2021/07/06(火) 07:38:26.90ID:4w9diVqq0 何言ってんだこいつ
596デフォルトの名無しさん (テテンテンテン MMc6-rRq2)
2021/07/06(火) 07:47:40.70ID:Jcre+LWcM インデックス張ったら挿入や更新の度に毎回ソートしてるとでも思ってるんだろ
597デフォルトの名無しさん (ワッチョイ 3a33-S78d)
2021/07/06(火) 08:22:21.59ID:PbL+Rk1v0 全件探索なら1回探索するだけ♪
598デフォルトの名無しさん (ワッチョイ bb2f-Ijop)
2021/07/06(火) 08:54:22.76ID:4hP0mNbe0 約900ms〜1100msの処理のうち
クエリが700ms〜900ms台で、改善のしようがないっていってるんだから
それがホントなら速度的なものはどうしようもないと思うんだが
画面が固まる対策ならクエリを非同期に(正確にはUIスレッド以外で、か)しろで終わりだろ
クエリが700ms〜900ms台で、改善のしようがないっていってるんだから
それがホントなら速度的なものはどうしようもないと思うんだが
画面が固まる対策ならクエリを非同期に(正確にはUIスレッド以外で、か)しろで終わりだろ
599デフォルトの名無しさん (ブーイモ MMb6-Xiw8)
2021/07/06(火) 09:08:47.43ID:juTGPN6qM ルビおじに絡むおじさんはルビおじよりさらに無能だからな
600デフォルトの名無しさん (ワッチョイ 8662-FWAm)
2021/07/06(火) 11:25:26.74ID:J1QHRuI00 やったことないけど、コンボボックスも仮想化できるらしいから試してみたら?
データ取得を非同期に出来てるなら画面が固まることは無くなりそう
https://docs.microsoft.com/ja-jp/dotnet/desktop/wpf/advanced/optimizing-performance-controls?view=netframeworkdesktop-4.8#controls-that-implement-performance-features
データ取得を非同期に出来てるなら画面が固まることは無くなりそう
https://docs.microsoft.com/ja-jp/dotnet/desktop/wpf/advanced/optimizing-performance-controls?view=netframeworkdesktop-4.8#controls-that-implement-performance-features
601デフォルトの名無しさん (ワッチョイ 8e2d-NaZp)
2021/07/06(火) 11:36:28.26ID:azFxX9aU0602デフォルトの名無しさん (ワッチョイ 7f7c-Pyw0)
2021/07/06(火) 18:11:30.42ID:RaE3JhC/0 WinFormsのComboBoxに仮想モード追加する例ってありそうで無いな
603デフォルトの名無しさん (ワッチョイ a3b5-U8JP)
2021/07/06(火) 21:55:13.16ID:Rt0qzyHm0 じゃ俺がWinFormsのComboBoxを仮想化する知恵を貸そうか?
604デフォルトの名無しさん (ワッチョイ 27ad-Is9n)
2021/07/06(火) 22:04:24.92ID:4w9diVqq0 まああてにするな
605デフォルトの名無しさん (アウアウウー Sacf-US9C)
2021/07/06(火) 22:18:48.94ID:HsJYefQaa どうぞどうぞって言おうと準備してたのにw
606デフォルトの名無しさん (ワッチョイ 0ada-Cqho)
2021/07/07(水) 02:05:48.56ID:jIHjttY10 じゃあ代わりに言うか
「どうぞどうぞ」
「どうぞどうぞ」
607578 (ワッチョイ 6f54-SLQ7)
2021/07/07(水) 03:00:22.72ID:sX4an4wR0 みなさん本当にありがとうございます。
原因は、約4000の要素をDBから取り出す所要時間でした。
約60万レコード内の、文字列カラムのデータを、重複しないように、GROUP BYする処理が時間食ってました。
なので、該当の文字列カラムだけを重複なしで格納するキー一覧テーブルを作り、
データINSERT時に、キー一覧テーブルの既存レコードと一致しない文字列だけをキー一覧テーブルに追加するトリガー処理を作りました。
そして、ComboBox の DataSourceにはそのキー管理テーブルのデータをセットするようにして、表示所要時間を5〜6割短縮出来ました。
原因は、約4000の要素をDBから取り出す所要時間でした。
約60万レコード内の、文字列カラムのデータを、重複しないように、GROUP BYする処理が時間食ってました。
なので、該当の文字列カラムだけを重複なしで格納するキー一覧テーブルを作り、
データINSERT時に、キー一覧テーブルの既存レコードと一致しない文字列だけをキー一覧テーブルに追加するトリガー処理を作りました。
そして、ComboBox の DataSourceにはそのキー管理テーブルのデータをセットするようにして、表示所要時間を5〜6割短縮出来ました。
608デフォルトの名無しさん (テテンテンテン MMc6-rRq2)
2021/07/07(水) 06:50:16.04ID:oDfnQi3+M 高々60万レコードの group by に700msって遅くね?
DBMS 何使ってるのかわからんけどインデックス張るだけで良いような気もするが…
DBMS 何使ってるのかわからんけどインデックス張るだけで良いような気もするが…
609デフォルトの名無しさん (ワッチョイ 0aba-Sdyw)
2021/07/07(水) 07:38:37.09ID:F/xqoSBh0 マテリアライズドビュー作るとか
610デフォルトの名無しさん (ワッチョイ 8f02-kf3V)
2021/07/07(水) 10:41:15.77ID:qNxZ5hgE0 GROUP BY自体が遅いもんよ
SQLが悪いとインデックス使っても無視されてFULL検索になってしまう
SQLが悪いとインデックス使っても無視されてFULL検索になってしまう
611デフォルトの名無しさん (アウアウウー Sacf-US9C)
2021/07/07(水) 12:33:18.92ID:GxuaumQya それより結局ComboBoxは何の関係もなかったってことだよね?
つまりボトルネックがどこにあるのか計測して確認もせず思い込みで
ComboBoxが悪いとミスリードな質問をした。
ここは反省して欲しい。
つまりボトルネックがどこにあるのか計測して確認もせず思い込みで
ComboBoxが悪いとミスリードな質問をした。
ここは反省して欲しい。
612デフォルトの名無しさん (アウアウウー Sacf-uurJ)
2021/07/07(水) 12:57:56.68ID:urFk1IqDa >>611
やれやれ
やれやれ
613デフォルトの名無しさん (ワッチョイ 7f7c-Pyw0)
2021/07/07(水) 13:00:11.32ID:FuIb4wxP0 最初の質問で問題の処理に約900ms〜1100msかかっていてそのうちクエリの所要時間が700ms〜900ms台と書いていて、その上でクエリ以外の部分(約200ms)を改善したいという話だったから測ってないわけではないかと
クエリ部分は改善不可能と思い込んでたのはあるが
クエリ部分は改善不可能と思い込んでたのはあるが
614デフォルトの名無しさん (ワッチョイ a3b5-U8JP)
2021/07/07(水) 13:00:41.99ID:ylMxxyrU0 >>611は毎度お馴染みで皆さんご存知の、
ComboBoxに責のあるマイクロソフトの犬
ComboBoxに責のあるマイクロソフトの犬
615デフォルトの名無しさん (ワッチョイ 8662-FWAm)
2021/07/07(水) 15:16:07.20ID:Z3N+pbe10 最初に戻ると結局画面は固まってなかったってことなんだろうな
これが一番のミスリード
これが一番のミスリード
616デフォルトの名無しさん (ワッチョイ 6b01-Q9JX)
2021/07/07(水) 15:26:49.85ID:jKQg8TjQ0 FormのLoadで何も表示されないまま1秒以上かかるとかなり固まった感は強い
だからスプラッシュやプログレスバーというのは非常に大事
これがあるだけでクレーム率はかなり下がる
速度最適化というのは実際のレスポンスやスループットだけではなくて
体感速度も最適化するべきなんだ
だからスプラッシュやプログレスバーというのは非常に大事
これがあるだけでクレーム率はかなり下がる
速度最適化というのは実際のレスポンスやスループットだけではなくて
体感速度も最適化するべきなんだ
617デフォルトの名無しさん (ワッチョイ bb2f-Ijop)
2021/07/07(水) 15:38:40.22ID:O4oUzSnJ0 いや、クエリの間は固まってたんじゃね
そういう意味ではコンボボックスは無関係だな
そういう意味ではコンボボックスは無関係だな
618デフォルトの名無しさん (ワッチョイ 8662-FWAm)
2021/07/07(水) 19:17:38.62ID:Z3N+pbe10 別スレッドで取得してるって言ってんのに?
619デフォルトの名無しさん (ワッチョイ 4a01-J3mH)
2021/07/07(水) 20:02:39.26ID:vUBZA2na0 別スレッドの処理終了を同期で待ってたら固まるよね
620デフォルトの名無しさん (スップ Sdaa-gkPs)
2021/07/07(水) 20:04:38.68ID:iooPCaard 別スレッドでの取得結果を待たずにコンボボックスが表示できるとは知らんかった
621デフォルトの名無しさん (ワッチョイ 7f09-TMbC)
2021/07/07(水) 20:05:37.60ID:UGIg3KO/0 空のはできるんじゃないの?
622デフォルトの名無しさん (スップ Sdaa-gkPs)
2021/07/07(水) 20:07:38.45ID:iooPCaard >>621
それが期待する動作だったとは読み取れなかったわ…
それが期待する動作だったとは読み取れなかったわ…
623デフォルトの名無しさん (ワッチョイ 4a01-J3mH)
2021/07/07(水) 20:37:31.96ID:vUBZA2na0 なるほど
同期で待つのと非同期で待つ違いがわかってなかったのか
同期で待つのと非同期で待つ違いがわかってなかったのか
624デフォルトの名無しさん (アウアウウー Sacf-US9C)
2021/07/07(水) 20:54:47.64ID:GxuaumQya625デフォルトの名無しさん (ワッチョイ deda-BgM4)
2021/07/07(水) 21:14:19.97ID:WowgMcxm0626デフォルトの名無しさん (テテンテンテン MMc6-rRq2)
2021/07/07(水) 21:32:17.55ID:PTZA0JCFM627デフォルトの名無しさん (ワッチョイ bb2f-Ijop)
2021/07/07(水) 23:15:16.70ID:O4oUzSnJ0 その間ってのがどこからどこまでか
固まるとはどういうことか
が、普通に考えるのとずれてるんだがな
固まるとはどういうことか
が、普通に考えるのとずれてるんだがな
628デフォルトの名無しさん (アウアウウー Sacf-uurJ)
2021/07/08(木) 05:59:22.31ID:bp32MkoMa >>623
初心者なので詳しく教えてください。
初心者なので詳しく教えてください。
629デフォルトの名無しさん (テテンテンテン MMc6-rRq2)
2021/07/08(木) 06:08:48.29ID:4npUp7i4M お前さんの普通なんて知らんがな
630デフォルトの名無しさん (ワッチョイ 7f7c-Pyw0)
2021/07/08(木) 07:08:26.32ID:ynxscpbq0 今回みたいなケースは再現しようがないから想像するしかないんだよな
齟齬が出るのはしょうがない
齟齬が出るのはしょうがない
631デフォルトの名無しさん (ワッチョイ 355f-xNKK)
2021/07/10(土) 10:35:48.26ID:o1Fr1a0g0 メインウィンドウが開かれるのに時間がかかる場合って自動的にマウスカーソルに砂時計付くよね
これってWindows 10だけの機能なのかな?
スプラッシュはそういうことに気付かない人にはわかりやすいからいいと思うけど
これってWindows 10だけの機能なのかな?
スプラッシュはそういうことに気付かない人にはわかりやすいからいいと思うけど
632デフォルトの名無しさん (ラクペッ MM31-dTRA)
2021/07/11(日) 15:20:44.65ID:ODsLgHFcM C#について詳しくなりたい。
.net独学だからテクニックが全く身についてこない。
働きながら学べる人たちが羨ましい。
.net独学だからテクニックが全く身についてこない。
働きながら学べる人たちが羨ましい。
633デフォルトの名無しさん (アウアウクー MM21-pM4a)
2021/07/11(日) 16:47:39.95ID:UTF+PuFAM >>632
働いてはどうでしょうか
働いてはどうでしょうか
634デフォルトの名無しさん (ワッチョイ ab2d-O0xy)
2021/07/11(日) 16:53:56.36ID:JpOAcHlL0 >>632
Effective C#とMore Effective C#買って読めば
Effective C#とMore Effective C#買って読めば
635デフォルトの名無しさん (ワッチョイ cd02-0sKs)
2021/07/12(月) 09:28:12.82ID:ReFnqSuP0636デフォルトの名無しさん (ワッチョイ f573-DcAx)
2021/07/12(月) 14:04:49.78ID:DOYT8O/O0 ひとが使いためのライブラリ作らない限りテクニックなんかロクに身に付かんでしょ。
テクニックが要らないように作られれてるのが人気があるライブラリなんだから。
テクニックが要らないように作られれてるのが人気があるライブラリなんだから。
637デフォルトの名無しさん (ワッチョイ 8d54-8NFQ)
2021/07/12(月) 17:05:33.06ID:ihSDWtOf0 async・awaitを使った非同期処理の並列処理数をSemaphoreSlim使って制御しています。
https://qiita.com/tadokoro/items/28b3623a5ec58517d431
を見ると、SemaphoreSlimのパフォーマンスはそこまで良くないらしいんですが、async・awaitを使いつつパフォーマンスを上げる方法はないでしょうか?
並列処理数の上限は4が理想です。※多ければ多いほどいいのはいいです。
SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1,4)
await semaphoreSlim.WaitAsync();
try {
await 自分の非同期メソッド
}
finally {
semaphoreSlim.Release();
}
https://qiita.com/tadokoro/items/28b3623a5ec58517d431
を見ると、SemaphoreSlimのパフォーマンスはそこまで良くないらしいんですが、async・awaitを使いつつパフォーマンスを上げる方法はないでしょうか?
並列処理数の上限は4が理想です。※多ければ多いほどいいのはいいです。
SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1,4)
await semaphoreSlim.WaitAsync();
try {
await 自分の非同期メソッド
}
finally {
semaphoreSlim.Release();
}
638デフォルトの名無しさん (ワッチョイ 2379-a+1V)
2021/07/12(月) 18:01:24.85ID:AiE5hxvs0 必要な場所にだけlockを掛ける
lock不要なロジックにする
lock不要なロジックにする
639デフォルトの名無しさん (ワッチョイ cbe3-C4NE)
2021/07/12(月) 18:04:26.22ID:hnMq5MVY0640デフォルトの名無しさん (ワッチョイ a301-knaX)
2021/07/12(月) 18:33:51.33ID:4WArcuIG0641デフォルトの名無しさん (ワッチョイ f5ad-3Ofv)
2021/07/12(月) 19:18:50.72ID:xUxV3tpC0 async,awaitってlock使えないのか。。
642637 (ワッチョイ 8d54-8NFQ)
2021/07/12(月) 19:21:57.66ID:ihSDWtOf0643デフォルトの名無しさん (ワッチョイ 236a-0sKs)
2021/07/12(月) 20:54:40.73ID:LswkHmLx0 これだけだとロックのパフォーマンス差なのかawaitのオーバーヘッドなのか分からん気がする
644デフォルトの名無しさん (スッップ Sdfa-gawc)
2021/07/16(金) 12:04:19.61ID:JqVxPGJSd #region を使うのは駄目ですか?
開くの面倒だ!ってセンパイに怒られました・・・
開くの面倒だ!ってセンパイに怒られました・・・
645デフォルトの名無しさん (アウアウウー Sa39-yayT)
2021/07/16(金) 12:24:45.09ID:QqSxNnhma うちじゃ使わなかったらレビューで指導が入るけど
646デフォルトの名無しさん (ワッチョイ 5524-TYDt)
2021/07/16(金) 12:30:58.12ID:81zoecY+0 コーディング規約に従え
個人的には使わないし他人が使ってても気にしない
メソッド1個ずつにregionあったらちょっとうざいけど、ショートカット一発で全部開けるしどうでもいいかな
個人的には使わないし他人が使ってても気にしない
メソッド1個ずつにregionあったらちょっとうざいけど、ショートカット一発で全部開けるしどうでもいいかな
647デフォルトの名無しさん (アウアウウー Sa39-yayT)
2021/07/16(金) 12:53:50.69ID:QqSxNnhma648デフォルトの名無しさん (ワッチョイ 25ac-9owZ)
2021/07/17(土) 06:06:49.16ID:Mspzx0w60 規約ちょうだい
649デフォルトの名無しさん (ワッチョイ 6e62-COnk)
2021/07/17(土) 11:35:23.95ID:tiRnOuXY0 regionは規約がないなら使わないのが無難
特に〜のプロパティ、〜のメソッドみたいな囲いかたは最悪で、今後regionを意識してメンテしなきゃいけないのが面倒
折りたたまないと把握出来ないほどぐちゃぐちゃになってますって言ってるようなものだしね
特に〜のプロパティ、〜のメソッドみたいな囲いかたは最悪で、今後regionを意識してメンテしなきゃいけないのが面倒
折りたたまないと把握出来ないほどぐちゃぐちゃになってますって言ってるようなものだしね
650デフォルトの名無しさん (ワッチョイ bdad-1ivc)
2021/07/17(土) 14:53:32.71ID:Wlqcfoar0 #region (規約)
把握できないほどグチャグチャになるくらいなら囲んだ方がマシ
#endregion
把握できないほどグチャグチャになるくらいなら囲んだ方がマシ
#endregion
651デフォルトの名無しさん (ワッチョイ 4597-jsLU)
2021/07/17(土) 19:23:55.27ID:1SEym9JY0 画面のクラスとかだとregion的な機能つかいたくなることはあると思うけどなあ。
画面って結局、人間にとって都合のいいように複数のデータを出すものなので、そのデータ毎にregion作ったりするのは変じゃないと思うけど。 Formに依存するコードを、 Form外の別クラスに書いたりしたくないじゃん。
画面って結局、人間にとって都合のいいように複数のデータを出すものなので、そのデータ毎にregion作ったりするのは変じゃないと思うけど。 Formに依存するコードを、 Form外の別クラスに書いたりしたくないじゃん。
652デフォルトの名無しさん (スプッッ Sdda-S+fN)
2021/07/18(日) 01:36:46.77ID:jHDjUzT3d コメントを書かない論者と同じ臭いがする
誰が読んでも自然言語と同じレベルで即座に理解可能かつ
解釈の余地の入らない完璧なコードを書けていて
しかもチームの全員がそのレベルに達しているという
地球上に存在しないチームで働いているかのような思い込みをしている
誰が読んでも自然言語と同じレベルで即座に理解可能かつ
解釈の余地の入らない完璧なコードを書けていて
しかもチームの全員がそのレベルに達しているという
地球上に存在しないチームで働いているかのような思い込みをしている
653デフォルトの名無しさん (ワッチョイ bdad-cccd)
2021/07/18(日) 02:29:32.38ID:fZXK3W//0 自分しか読まない使い捨てのテストコードならコメントも書かないし、ましてや#regionなんて使わない
654デフォルトの名無しさん (ワッチョイ 462d-BuM5)
2021/07/18(日) 02:41:59.86ID:gMJXIBls0 #regionはあまり使わないが
IDisposableパターンの実装とか定型文的なのはでregionで畳んでおくな
IDisposableパターンの実装とか定型文的なのはでregionで畳んでおくな
655デフォルトの名無しさん (ワッチョイ b17c-qDzH)
2021/07/18(日) 07:23:51.05ID:Ncq1Qbn/0 俺もそんな感じだな
インターフェースを継承するクラスは定形文が多くなるから囲んで畳んじゃう
インターフェースを継承するクラスは定形文が多くなるから囲んで畳んじゃう
656デフォルトの名無しさん (ワッチョイ 9142-kbnc)
2021/07/18(日) 09:20:30.72ID:SEUoEBF50 IDisposeパターンなどはpartialでクラスごと隔離するのがお薦め
657デフォルトの名無しさん (ワッチョイ 69ad-zcwp)
2021/07/18(日) 10:15:41.72ID:f26THqN50 子供は肉が好き!
658デフォルトの名無しさん (ワッチョイ 7db0-Lyc+)
2021/07/18(日) 10:18:34.20ID:duOzNEUP0 partialはお勧めかなぁ?
一見、Disposeが必要なメンバーを持っているのにIDisposableパターンを実装し忘れたクラスに見えてしまいそう。
一見、Disposeが必要なメンバーを持っているのにIDisposableパターンを実装し忘れたクラスに見えてしまいそう。
659デフォルトの名無しさん (ワッチョイ da01-+scu)
2021/07/18(日) 11:31:45.33ID:SQx5QkWC0 自動生成してくれるならpartialでもいいけど自分で書くなら俺はやはりひとつのクラスにするな
660デフォルトの名無しさん (ワッチョイ 6a33-kXUd)
2021/07/18(日) 19:03:11.29ID:x1tAdumV0 VSでクラスから別に定義されたpartialクラスに飛ぶ方法がよく分からないので、partialは使わない。
661デフォルトの名無しさん (ワッチョイ da01-+scu)
2021/07/18(日) 19:38:24.99ID:SQx5QkWC0 まあクラスに飛ぶとか言ってる時点で使わない方が無難だろうね…
662デフォルトの名無しさん (スッップ Sdfa-Vhyu)
2021/07/18(日) 21:11:55.98ID:wT9cmlucd F12とかCtrl+F12とかできなかったっけ
知らんけど
知らんけど
663デフォルトの名無しさん (ワッチョイ da6a-kbnc)
2021/07/18(日) 22:09:14.51ID:zdDSWDaE0 >>661
言い方が雑なだけでおかしなこと言ってるようには見えないけどなあ
言い方が雑なだけでおかしなこと言ってるようには見えないけどなあ
664デフォルトの名無しさん (ワッチョイ da79-S+fN)
2021/07/18(日) 22:10:16.34ID:ZnA++D2G0 partial は元々自動生成コード用の機能であってクラスを分割する機能ではない
明らかインターフェイスの実装を#region化する方が可読性が高い
明らかインターフェイスの実装を#region化する方が可読性が高い
665デフォルトの名無しさん (ワッチョイ 0d01-kXUd)
2021/07/19(月) 02:47:17.54ID:GZMIZdMt0 >>663
相手を否定せずにはいられない可哀想な人達が一定数いるから、そっとしておいてやりなよ。
相手を否定せずにはいられない可哀想な人達が一定数いるから、そっとしておいてやりなよ。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【速報】中国、水産物輸入停止と通達 「処理水」理由、日本政府へ ★3 [おっさん友の会★]
- 【速報】中国、水産物輸入停止と通達 日本政府に ★2 [おっさん友の会★]
- 【速報】中国、水産物輸入停止と通達 「処理水」理由、日本政府へ ★4 [おっさん友の会★]
- 高市首相答弁を“引き出した”立民・岡田克也氏が改めて説明「なぜ慎重な答弁をされなかったのか。非常に残念に思っている」 [ぐれ★]
- 中国側が首相答弁の撤回要求、日本側拒否★6 [夜のけいちゃん★]
- 【速報】 米大使「はっきりさせておこう、米国は尖閣諸島含め日本の防衛に全面コミット、中国がどうしようが変わらない」 [お断り★]
- 【速報】高市首相「つい言い過ぎた」 存立危機事態の答弁について [237216734]
- 【ネトウヨ朗報】イギリスのトラス元首相、高市有事で高市早苗の支持を表明 [603416639]
- ネトウヨ論調決まる「まず危ない質問を高市さんにした岡田が悪いんだから岡田が中国に謝罪しろ😡」 <mark>[ひまわり学級]</mark> [511393199]
- 【高市訃報】ホタテ業者、死亡😇😇😇 [573041775]
- 【速報】中国、水産物輸入停止★2 [989870298]
- 【悲報】高市早苗さん、たった一人で日本を崩壊へ導く [714769305]
