X



C#, C♯, C#相談室 Part93©2ch.net
■ このスレッドは過去ログ倉庫に格納されています
0001デフォルトの名無しさん 転載ダメ©2ch.net (ワッチョイ 1e06-m8Mb)
垢版 |
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
0037(スフッ Sd52-gZQE)
垢版 |
2017/05/06(土) 08:57:56.21ID:BE072L/9d
>>36
UIスレッドでメッセージボックス出しとくと、プロセスを落とす正規ルートからはずれて再現できるとか、なんか色々こねくり回したよ。
今だと仮想マシンあるから、マシンが上がってくるの待つ辛さ無いかもね。
0038デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 06:03:37.70ID:OZ9w4Yf70
ロック処理についてちょっと相談です

●二つ以上のオブジェクトを同時にロックしたい
片側づつ順を追ってロックしていくのはダメ、デッドロックするので。
ロック出来ない状態である限り、ロックは限りなくしないようにしたい。
ロックに失敗までのタイムアウト処理もしたい。

●例えばこれだと、デッドロックを引き起こすので良くない
lock(obj1) lock(obj2) 処理;

●そこで、言語に以下のような構文があれば理想的なのだが
ないので、それらしいヘルパを作りたい、できれば効率的な物。
lock(obj1,obj2, ... ,timeout=1000) {
 ロック成功の場合の処理
}
timeout {
 タイムアウトした場合の処理
}
0039デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 06:03:54.24ID:OZ9w4Yf70
●とりあえず簡単に考えた、しかし無駄が多そうに見える、もっと良いものが欲しい。
DateTime begin = DateTime.Now;
再試行:
bool l1 = Monitor.TryEnter(obj1, 0);
bool l2 = Monitor.TryEnter(obj2, 0);
if (l1 && l2) {
 goto ロック成功;
} else {
 if(l1) Monitor.Exit(obj1); // チェックと共にロックしてしまうので、このコードも残念賞
 if(l2) Monitor.Exit(obj2); // 同上
 if ((DateTime.Now - begin).TotalMilliseconds > 1000) {
  goto タイムアウト;
 } else {
  System.Threading.Thread.Sleep(10); // この待ち方も酷い
  goto 再試行;
 }
}
タイムアウト:
{
 タイムアウト処理
}
ロック成功:
0041デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 07:32:55.17ID:OZ9w4Yf70
>>40
それだとロック粒度が大きくなりすぎて逆にデッドロックの可能性を拡大してしまいますね。
0043デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 07:36:13.98ID:OZ9w4Yf70
>>42
セマフォは重いんですよねぇ
それをやるくらいなら>>39の例の方が効率的ですね。
0044デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 07:50:05.84ID:OZ9w4Yf70
>http://article.higlabo.com/ja/thread_locking.html
lock(Monitor.Enter/Monitor.Exit) 同じプロセス 20ns
Mutex 違うプロセスも可能 1000ns
SemaphoreSlim 同じプロセス 200ns
Semaphore 違うプロセスも可能 1000ns
ReaderWriterLockSlim 同じプロセス 40ns
ReaderWriterLock 同じプロセス 100ns

Semaphoreは高機能すぎて、あまり軽々しくは使えない。
そのわりにはlockと違ってスレッドチェックがないので自家中毒を起こしたりするので、別途そのための対処が必要になったりする。
lock 20nsはやはり捨てがたいものです。
0046デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 08:20:40.14ID:OZ9w4Yf70
>>45
そんな事は無いと思うんだけどな、セマフォに標準で実装されているように
これはマルチスレッドデザインパターンとしては基本になるかと。
というか教科書にある典型ですし。
ところが、Monitorにはなかったので、おや何故ない?となっている所。
せっかく高性能なのに有効活用できないのは勿体ないと。
0048デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 08:34:06.74ID:OZ9w4Yf70
>>47
分からないならレスしないでもらえますか?
流されては叶いません。
0049デフォルトの名無しさん (ワッチョイ 4bcd-yumd)
垢版 |
2017/05/25(木) 08:52:37.16ID:CNpknsWj0
>>39
みたいなことをするぐらいならSpinLockを使った自前実装で処理したほうが良いかもしれない。

もしくは
>>lock(obj1) lock(obj2) 処理;
これでもデッドロックしないように、Lockする順番を厳格にしてコーディングするとか

というか、言葉遣いに気を付けたほうが良いと思うよ。
0052デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 09:04:40.54ID:OZ9w4Yf70
>>49
ここにいる知らなくてもレスしないと死ぬ病気にかかっている奴はどうしょうもない。初心者の上にキチガイなら死ねって感じですが。
とりあえず、スピンロックは使いたくないですね、あれはCPUタイムをすり潰しながら高速動作を確保しようとするものだから
それの主用途は、激重計算タスクを並列処理するための物であって、目的とちょっと違いますね。
あと、排他処理をちゃんと勉強すると、順序等を考えていても意味が無くて
ロックする瞬間に作業に必要になるリソースをすべて確保して、必ず抜けられるという事の方がデッドロックに対する対処としては有用です。
でも、上に書かれているように一つのオブジェクトで粒度を上げてしまったら本末転倒になります。
0053デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 09:05:42.97ID:OZ9w4Yf70
>>51
ちゃんとわかっている人を待っているんだから黙ってろ
0054デフォルトの名無しさん (ワッチョイ 2bd4-WXs4)
垢版 |
2017/05/25(木) 09:12:36.71ID:foQMlEN20
アイデアを募るならもっと広い視野で考えたほうがいいってことでしょ
矮小な問題に限定されすぎていて、マイクロベンチマークレベルの不毛な議論にしかならない
状況によっては工夫すればロックフリーな実装もできるかもしれないよ
0056デフォルトの名無しさん (ワッチョイ 4bcd-yumd)
垢版 |
2017/05/25(木) 09:24:19.81ID:CNpknsWj0
>>52
https://www.jpcert.or.jp/java-rules/lck07-j.html
ソースはそれっぽいものを適当に引っ張ってきた
ロックする順序は意味あると思うんだけど、、、

デッドロックが怖いってことだと思うんだけどさ
親から子へ順番守ってロックすればデッドロックしないじゃん?
0057デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 09:24:47.08ID:OZ9w4Yf70
>>55
世の中上には上の奴がいるんだよ、俺なんかよりはるかに知識を持っている奴はいくらでも。
お前より俺の方が知識あるが、そんな俺よりもはるかに凄いやつは山のようにいるんだ。
そろそろ、中二病みたいな全能感は捨てな
0058デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 09:32:43.15ID:OZ9w4Yf70
>>56
親子関係があれば、親についている操作ようのメソッドにロック処理をいれれば問題ないですね。
でも、今回のは完全に独立しているオブジェクト間です。
ちょっと難しいですね。
実際問題としては、順序を使う側にすべて守らせるというのは、理屈では語れても実践的ではないかもしれません。
やはり、ロック時間を短くする事が肝要であり、その為には粒度を小さくするのが基本となるかと。
汎用的なやり方としては、この方法がもっとも優れていると思います。
なので、この方法をより高パフォーマンスで実現できるヘルパーを実装して纏めて利用したい訳です。
だから、別の方法は考えていないです。Monitorを使った高速排他処理が今回の最終目標です。
0059デフォルトの名無しさん (ワッチョイ 0f75-jnQe)
垢版 |
2017/05/25(木) 11:13:36.68ID:5itOJ4P90
楽観的ロックのタイムアウトで、ロールバックするのが確実

人間には絶対にミス・バグがあるから、
デッドロックを100%、起こさないようにする事は、絶対に出来ないから
0061デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 11:39:35.31ID:OZ9w4Yf70
>>59-60
だから、もう来るなって、お前には何も聞きたいことは無いし、そんな話は聞かされたところで新たな何かには全くつながらない。
C#スレには、初心者用じゃないもう一本の匿名ゴミすれあるだろ、そっちいけよ。
分かっている人が来たときにコメントがゴミだらけになる。
0062デフォルトの名無しさん (アウアウイー Sa0f-UhbI)
垢版 |
2017/05/25(木) 12:20:12.43ID:XlAyjrlQa
たぶん質問者の方が俺よりずっと詳しそうだから釈迦に説法だと思うけど、

>●例えばこれだと、デッドロックを引き起こすので良くない
>lock(obj1) lock(obj2) 処理;

これがデッドロックしうるのはこのスレッドがobj1だけをロックした状態で
別のスレッドがobj2をロックして、そのスレッドがobj1を待機してる場合だよね?

この場合このスレッドがobj1をアンロックしない限りobj2もアンロックされないからデッドロック

だから、ネストの内側のock(obj2) だけをタイムアウト付きのMonitor.TryEnterに置き換えれば
効率的かどうかはどうかはともかく、要件は満たせるんじゃいないの?
知らんけど
0063デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 12:28:42.96ID:OZ9w4Yf70
>>62
まさにその通りです、それが直下に書いた雑な例です。
このヘルパーを作りたいという訳です、見るからに美しくないので詳しい人の登場をお待ちしているという所です。
必要な全ロック取得に失敗したら即座に全て解放して、乱数時間まって次を伺う。
これはよくある教科書通りです。
0066デフォルトの名無しさん (ワッチョイ 4bcd-yumd)
垢版 |
2017/05/25(木) 13:51:23.71ID:CNpknsWj0
http://ideone.com/GHvgKN
勢いで書いた。
0067デフォルトの名無しさん (ワッチョイ fbf7-Ksx5)
垢版 |
2017/05/25(木) 13:59:41.85ID:OZ9w4Yf70
>>66
いいっすね、いいっすね
Thread.Sleep(100); ← ここがもうちょっとマシな待ち方になるといいんですがw
自分はインターフェイスは、IDispose使ってロック範囲を lock で書いたような雰囲気にしてます。
タイマーは、初ロック失敗の後にスタートさせて、ロック成功(大半のケース)でロスが少ないようにしてます。
なかなか素敵な感じになってくれませんw
0068デフォルトの名無しさん (ワッチョイ 1f1b-6//c)
垢版 |
2017/07/11(火) 08:22:12.16ID:MCsEtOKi0
↓のテンプレートとジェネリックの違い、にある
https://docs.microsoft.com/ja-jp/dotnet/csharp/programming-guide/generics/differences-between-cpp-templates-and-csharp-generics
トップ項目にある
・C# ジェネリック クラスでは、ユーザー定義演算子は呼び出すことができますが、算術演算子を呼び出すことはできません。
"算術演算子を呼び出すことはできません"ってどーいう意味っすか?
算術演算子って+-*/のこと?
0071デフォルトの名無しさん (ワッチョイ 6a90-qWRz)
垢版 |
2017/07/29(土) 20:36:18.47ID:Gw88XuqA0
ジェネリックに算術演算子を使うなら、そんなに速度が要求されないんなら
(dynamic)にキャストしてからなら演算子が使える
まあこれキャッシュ付きのリフレクションだから速度は期待しないでよー
0072デフォルトの名無しさん (ワッチョイ 331b-z1u6)
垢版 |
2017/08/21(月) 18:56:43.94ID:LgNyTwHt0
C++ではテンプレートに焦点をあてた書籍はいくつかあるけど
C#でジェネリックに絞ったオススメ書物ってのはありますか?
C++のテンプレートテクニックのどれが使えないか?ってのは知りたい。
0076デフォルトの名無しさん (ワッチョイ da1b-KdCs)
垢版 |
2017/08/27(日) 02:29:03.34ID:/hywh0UG0
式テンプレートジェネリックでどー書くんだよ
0077デフォルトの名無しさん (アウアウウー Sa39-B8PL)
垢版 |
2017/10/09(月) 21:40:27.74ID:dzl0TrLma
すみません。ちょっと急いでいます。

C#でクラスを宣言する際に、
class {...} とpublic class {...}
このふたつの違いが判りません。
教えてください。
0078デフォルトの名無しさん (ワッチョイ dad2-B8PL)
垢版 |
2017/10/09(月) 21:54:29.58ID:rAF1hT8M0
お願いします。同じものですか?
0081デフォルトの名無しさん (ワッチョイ dad2-B8PL)
垢版 |
2017/10/09(月) 22:03:58.01ID:rAF1hT8M0
ありがとうごぜます。
internalですね。アセンブリ言語レベルの話のようなので
まだそこまで至ってないのでpublic, private, protectedだけ使います。
すみませんでした。
0086デフォルトの名無しさん (ワッチョイ 7d80-Wlpn)
垢版 |
2017/10/10(火) 00:40:47.02ID:pliWVB3X0
今となっては、いや初めから忘れてもいい話だったけど
ファイル単位の物理的なまとまりはモジュール(.netmodule)で
モジュールをまとめた論理的まとまりがアセンブリ(.dll/.exe)
Visual Studioが2002の初めから一貫してサポートしてないこのモジュールって単位をMSはどう使うつもりだったんだろう
0087デフォルトの名無しさん (ワッチョイ 718a-QWl5)
垢版 |
2017/10/10(火) 21:13:43.71ID:9Raz+qz10
最終的に1つのライブラリにしたいものをC#とF#で部分ごとに書き分けるとかそういう例は見た事あるけど
(ものによってはF#のほうが書きやすいとか)
実際それが必要なユーザがどれだけいるのかって話な
0088デフォルトの名無しさん (ワッチョイ b66c-XSap)
垢版 |
2017/10/10(火) 23:25:11.21ID:I+aeGBiR0
C++/CLIとC#の組み合わせがある。

最終的な呼び出し元はネイティブと同じ口なんだけど、
dynamicやasync/awaitなどを使いたいため、
dllexport付近の薄皮一枚だけ C++/CLI、
残りは全部C#で記述して1つの.dllにってのに.netmoduleを使う。

C#とF#の組み合わせとか、ほとんど無意味に思えるが…
0090デフォルトの名無しさん (ワッチョイ 0b7a-7iB9)
垢版 |
2017/10/18(水) 13:52:47.94ID:ufsScDVj0
event解除ってnullぶっこんでもいいのかしら?
何処見ても-=でしろってのばかりで全解除の適切なやり方載ってないんだけど
一応null代入で動いてるぽいけどちと不安
0092デフォルトの名無しさん (ワッチョイ 0b7a-7iB9)
垢版 |
2017/10/18(水) 14:18:32.71ID:ufsScDVj0
全解除ってそれなりに需要あると思うんだが何処も扱ってない不思議
+=って内から外へ処理出しする訳だから
インスタンスが破棄されたら当然破棄されるべきなのにどうもそうなってない
nullぶっこめばGC回収されるみたいだけど正しいやり方なのかな
0094デフォルトの名無しさん (アウアウエー Sae3-FoSE)
垢版 |
2017/10/18(水) 15:34:04.84ID:jnsT8t6ma
購読側じゃなく発行側が勝手に解除ってのがちょっと...
むしろどういう場面で必要になるのか想像できないな

> +=って内から外へ処理出しする訳だから
> インスタンスが破棄されたら当然破棄されるべきなのにどうもそうなってない
ここは何を言ってるのかよく分からない

まあ、イベントというかデリゲートのマルキチャストの仕組みが分かりづらいのはわかる
0096デフォルトの名無しさん (ワッチョイ 0b7a-7iB9)
垢版 |
2017/10/18(水) 16:11:03.50ID:ufsScDVj0
>>94
例えば非同期通信でデシリアライズ終わったらイベント投げて後は勝手に死ね、って場合
-=だと発行側で解除するのが困難でリークしちまう
最新VerC#ならTaskで後処理書けばいいけど、Unityだとつい最近まで3.5だったから
0097デフォルトの名無しさん (アウアウエー Sae3-FoSE)
垢版 |
2017/10/18(水) 16:24:45.96ID:jnsT8t6ma
>>96
俺の理解不足だったらごめん

リークするのはイベントの購読側のオブジェクトLがイベントの購読を解除しないまま
Lを参照する変数がなくなった場合で、発行側のオブジェクトPのイベントに
Lのメソッドが登録されたままPへの参照がなくなってもそれはリークにならないと思うんですが
0098デフォルトの名無しさん (ワッチョイ 0b7a-7iB9)
垢版 |
2017/10/18(水) 16:39:10.41ID:ufsScDVj0
>>97
そう思ってた時期が俺にもありました
しかし実際はリークしてOutofMemoryが出る
どうも購読側参照が残ってると到達可能と見られてGC回収されないぽい
本当にそういう理屈かは知らんけどnullぶち込むと例外でなくなる
0100デフォルトの名無しさん (ワッチョイ 93b3-meYy)
垢版 |
2017/10/18(水) 17:46:05.16ID:GswCLlj60
>>98
>どうも購読側参照が残ってると到達可能と見られてGC回収されないぽい

登録解除してないから購読側は発行側から参照されてて回収されない
その状態で購読側が発行側を参照してるんなら発行側も回収されないよね
0101デフォルトの名無しさん (ワッチョイ 7996-lqEX)
垢版 |
2017/10/18(水) 19:19:26.31ID:j/PgXgnk0
循環参照しててもルートから到達不能なら回収されるよ
されないなら単に循環参照以外の参照が何かしら残ってるだけ

いいや解放されないね!とかいう思い込みに付き合う気はないから
口ごたえがしたければ、VSのメモリーアナライザーで
リークしているというオブジェクトの参照状態のスナップショットを撮って
ここに貼り付けてから続けるように
0103デフォルトの名無しさん (ワッチョイ 318a-SWEl)
垢版 |
2017/11/07(火) 14:20:16.62ID:7CEykIkZ0
WebBrowserコントロールを使うと、レジストリ編集しないと自動的にIE7相当になってしまうんですが、
レジストリ編集無しでIE11相当にするにはどうしたらいいでしょうか?

もしくは、dllファイル1つで済むなら、他のブラウザコンポーネントでもいいです。
0107デフォルトの名無しさん (ワッチョイ dfb3-iA8U)
垢版 |
2017/12/18(月) 07:59:20.53ID:mWvJQqvN0
#EntityFrameworkの質問ってここでよいですか?

EFCore+Sqliteで開発してるんですが、".db"ファイルのパス指定で困ってます。

コネクション作成時に、以下でdbパス指定をしています。
var connectionString = new SqliteConnectionStringBuilder { DataSource = @"./app.db" }.ToString();

この場合、理由がよく分かってないのですが、
Update-Databaseを実行した時(CreateDatabaseが発行される時)、プロジェクトフォルダからの相対パスになり、
SaveChangesを実行した時(Insert文が発行される時)、/bin/debugからの相対パスになります。

毎回相対パス指定を変えるのが面倒で、かつ絶対パス指定はしたくないもので。
何か良い方法はありませんでしょうか。
0111107 (ワッチョイ dfb3-iA8U)
垢版 |
2017/12/18(月) 23:30:30.75ID:mWvJQqvN0
>>109
プロジェクトフォルダにできます。
ただ、プログラム実行時は別のパス見てるからDBないエラーになります。

>>110
あー、それいいかもです。
やってみます。
0126デフォルトの名無しさん (ワッチョイ 7b17-Ogju)
垢版 |
2018/01/08(月) 21:07:22.93ID:ff9XOb220
ILMergeについて質問です

例えば自作アプリ X.EXE に外部ライブラリ A.DLL と B.DLL を結合して X2.EXE を作ったとします
この X2.EXE を配布する場合、A.DLL と B.DLL の著作権情報を明記すれば問題ないという認識で合っていますか?
0130デフォルトの名無しさん (ワッチョイ bad2-4vN5)
垢版 |
2018/01/31(水) 23:46:33.39ID:3zSQiFnB0
ラムダ式から右辺の情報を取得する事は出来ますか?

.net MVC のソースコードを見ていて思ったのだけど、たとえば razor の Html.LabelFor メソッドは第一引数に
m => m.name などと書いて、引数 m で示すクラスインスタンスの name プロパティの DisplayName 属性の値を
ラベルとして表示していたりします。

ということは、ラムダ式 m => model.name から name プロパティの属性情報を取得しているのだと思うのですが、
どうやってるのかさっぱり分からず。
調べるべきキーワードだけでもいいので、ヒントをいただけませんか。
0132130 (ワッチョイ 9fd2-K3c3)
垢版 |
2018/02/02(金) 00:27:05.13ID:eoTWLp2s0
>>131
ありがとー。
軽く見てみましたが、Expression ってよく分からないですね。。
式ツリーでも、もっと調べてみます。
0134デフォルトの名無しさん (ワキゲー MM8a-/z5x)
垢版 |
2018/02/13(火) 20:22:55.89ID:ElvL/+ZbM
とりあえず一般的には
FindWindowやEnumWindowsで目的のウィンドウのウィンドウハンドルを手に入れて
SetWindowPosする
>>133のウィンドウがこれでできるかどうかはそのプログラムの作り次第
0135デフォルトの名無しさん (ワッチョイ 6eed-nHV3)
垢版 |
2018/02/13(火) 20:56:39.50ID:KbLCHvlc0
>>134
ありがとうございます
それで移動、サイズ変更できないウィンドウをどうにかできないかなと思い質問してみました
ユーザーが移動サイズ変更できないウィンドウでも強引にしてしまうプログラムがあるらしいので、どうしてるのかな?と
■ このスレッドは過去ログ倉庫に格納されています

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