2012年06月15日
川俣晶の縁側ソフトウェア技術雑記total 3659 count

C#5と非同期とコンストラクターの甘い罠

Written By: 川俣 晶連絡先

「メトロアプリのGridViewの順番が意味不明の挙動を示して時間を食った」

「単にバインドしたモデルの順番通りじゃないの?」

「そう。その通り。その認識がぐらつくようなバグがあったのだ」

「それはなんだよ」

「つまりさ。初期化に非同期が絡んだ結果、順番が狂ったわけだ」

「というと?」

「初期化の中で気づかないうちに非同期メソッドを呼んでいたのだ」

「await付けて終わるのを待てば同期的な順番で処理が進むだろう」

「ところが、それはコンストラクタの話なのだ」

「await付ければ……」

「コンストラクタ内では付けられない」

「なぜだよ」

「async/awaitを使ったメソッドの戻り値の型はおおざっぱに言えばTaskかvoid。コンストラクタに戻り値の型はない」

「じゃあ、コンストラクタでは使えないってこと?」

「そうなるな」

「じゃあどうするんだよ」

「処理をprivateメソッドに切り出してそれを呼んだ」

「それって、平気なのか? コンストラクタの実行が終わっても初期化が終わってないわけだろ?」

「このプログラムではまあいいかな」

「良くないケースもあるってことだね」

「その時は別の対策を考える必要がありそうだ」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2012年
06月
20日
これがホントのピクチャー・イン・ピクチャー
3days 0 count
total 1644 count
【技術雑記】の前のコンテンツ
2012年
06月
15日
Alt+F4
3days 0 count
total 1952 count
2012年06月15日
川俣晶の縁側ソフトウェア技術雑記total 3659 count

C#5と非同期とコンストラクターの甘い罠

Written By: 川俣 晶連絡先

「メトロアプリのGridViewの順番が意味不明の挙動を示して時間を食った」

「単にバインドしたモデルの順番通りじゃないの?」

「そう。その通り。その認識がぐらつくようなバグがあったのだ」

「それはなんだよ」

「つまりさ。初期化に非同期が絡んだ結果、順番が狂ったわけだ」

「というと?」

「初期化の中で気づかないうちに非同期メソッドを呼んでいたのだ」

「await付けて終わるのを待てば同期的な順番で処理が進むだろう」

「ところが、それはコンストラクタの話なのだ」

「await付ければ……」

「コンストラクタ内では付けられない」

「なぜだよ」

「async/awaitを使ったメソッドの戻り値の型はおおざっぱに言えばTaskかvoid。コンストラクタに戻り値の型はない」

「じゃあ、コンストラクタでは使えないってこと?」

「そうなるな」

「じゃあどうするんだよ」

「処理をprivateメソッドに切り出してそれを呼んだ」

「それって、平気なのか? コンストラクタの実行が終わっても初期化が終わってないわけだろ?」

「このプログラムではまあいいかな」

「良くないケースもあるってことだね」

「その時は別の対策を考える必要がありそうだ」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2012年
06月
20日
これがホントのピクチャー・イン・ピクチャー
3days 0 count
total 1644 count
【技術雑記】の前のコンテンツ
2012年
06月
15日
Alt+F4
3days 0 count
total 1952 count
【技術雑記】のコンテンツ全リスト【技術雑記】の表紙

このコンテンツを書いた川俣 晶へメッセージを送る

[メッセージ送信フォームを利用する]

メッセージ送信フォームを利用することで、川俣 晶に対してメッセージを送ることができます。

この機能は、100%確実に川俣 晶へメッセージを伝達するものではなく、また、確実に川俣 晶よりの返事を得られるものではないことにご注意ください。

このコンテンツへトラックバックするためのURL

http://mag.autumn.org/tb.aspx/20120615231317
サイトの表紙【技術雑記】の表紙【技術雑記】のコンテンツ全リスト 【技術雑記】の入手全リスト 【技術雑記】のRSS1.0形式の情報このサイトの全キーワードリスト 印刷用ページ

管理者: 川俣 晶連絡先

Powered by MagSite2 Version 0.25 (Alpha-Test) Copyright (c) 2004-2017 Pie Dey.Co.,Ltd.