C# と VB.NET の質問掲示板
ASP.NET、C++/CLI、Java 何でもどうぞ
掲示板トップ
C# と VB.NET 入門
新規作成
利用方法
ツリー表示
トピック表示
ランキング
記事検索
過去ログ
ログ内検索
キーワードを複数指定する場合は 半角スペース で区切ってください。
検索条件は、(AND)=[A かつ B] (OR)=[A または B] となっています。
[返信]をクリックすると返信ページへ移動します。
キーワード
/
検索条件
/
(AND)
(OR)
検索範囲
/
(現在のログ)
(全過去ログ)
(過去ログ1)
(過去ログ2)
(過去ログ3)
(過去ログ4)
(過去ログ5)
(過去ログ6)
(過去ログ7)
(過去ログ8)
(過去ログ9)
(過去ログ10)
(過去ログ11)
(過去ログ12)
(過去ログ13)
(過去ログ14)
(過去ログ15)
(過去ログ16)
(過去ログ17)
(過去ログ18)
(過去ログ19)
(過去ログ20)
(過去ログ21)
(過去ログ22)
(過去ログ23)
(過去ログ24)
(過去ログ25)
(過去ログ26)
(過去ログ27)
(過去ログ28)
(過去ログ29)
(過去ログ30)
(過去ログ31)
(過去ログ32)
(過去ログ33)
(過去ログ34)
(過去ログ35)
(過去ログ36)
(過去ログ37)
(過去ログ38)
(過去ログ39)
(過去ログ40)
(過去ログ41)
(過去ログ42)
(過去ログ43)
(過去ログ44)
(過去ログ45)
(過去ログ46)
(過去ログ47)
(過去ログ48)
(過去ログ49)
(過去ログ50)
(過去ログ51)
(過去ログ52)
(過去ログ53)
(過去ログ54)
(過去ログ55)
(過去ログ56)
(過去ログ57)
(過去ログ58)
(過去ログ59)
(過去ログ60)
(過去ログ61)
(過去ログ62)
(過去ログ63)
(過去ログ64)
(過去ログ65)
(過去ログ66)
(過去ログ67)
(過去ログ68)
(過去ログ69)
(過去ログ70)
(過去ログ71)
(過去ログ72)
(過去ログ73)
(過去ログ74)
(過去ログ75)
(過去ログ76)
(過去ログ77)
(過去ログ78)
(過去ログ79)
(過去ログ80)
(過去ログ81)
(過去ログ82)
(過去ログ83)
(過去ログ84)
(過去ログ85)
(過去ログ86)
(過去ログ87)
(過去ログ88)
(過去ログ89)
(過去ログ90)
(過去ログ91)
(過去ログ92)
(過去ログ93)
(過去ログ94)
(過去ログ95)
(過去ログ96)
(過去ログ97)
(過去ログ98)
(過去ログ99)
(過去ログ100)
(過去ログ101)
(過去ログ102)
(過去ログ103)
(過去ログ104)
(過去ログ105)
(過去ログ106)
(過去ログ107)
(過去ログ108)
(過去ログ109)
(過去ログ110)
(過去ログ111)
(過去ログ112)
(過去ログ113)
(過去ログ114)
(過去ログ115)
(過去ログ116)
(過去ログ117)
(過去ログ118)
(過去ログ119)
(過去ログ120)
(過去ログ121)
(過去ログ122)
(過去ログ123)
(過去ログ124)
(過去ログ125)
(過去ログ126)
(過去ログ127)
(過去ログ128)
(過去ログ129)
(過去ログ130)
(過去ログ131)
(過去ログ132)
(過去ログ133)
(過去ログ134)
(過去ログ135)
(過去ログ136)
(過去ログ137)
(過去ログ138)
(過去ログ139)
(過去ログ140)
(過去ログ141)
(過去ログ142)
(過去ログ143)
(過去ログ144)
(過去ログ145)
(過去ログ146)
(過去ログ147)
(過去ログ148)
(過去ログ149)
(過去ログ150)
(過去ログ151)
(過去ログ152)
(過去ログ153)
(過去ログ154)
(過去ログ155)
(過去ログ156)
(過去ログ157)
(過去ログ158)
(過去ログ159)
(過去ログ160)
(過去ログ161)
(過去ログ162)
(過去ログ163)
(過去ログ164)
(過去ログ165)
(過去ログ166)
(過去ログ167)
(過去ログ168)
(過去ログ169)
(過去ログ170)
(過去ログ171)
(過去ログ172)
(過去ログ173)
(過去ログ174)
(過去ログ175)
(過去ログ176)
(過去ログ177)
(過去ログ178)
(過去ログ179)
強調表示
/
ON
(自動リンクOFF)
結果表示件数
/
20件
30件
40件
50件
100件
記事No検索
/
ON
大文字と小文字を区別する
No.17274 の関連記事表示
ヒット / 14件
(1-14 を表示)
<<
0
>>
■17274
Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 13:53:01)
分類:[ASP.NET (C#)]
こんにちは。
ASP.NETを用いてWebサービスを作成しております。
環境としては仮想ディレクトリにasmxファイルとApp_Codeディレクトリ(ソースファイルが入ってる)
といった構成です。
Webサービスクラスが提供するWebメソッドが2つありまして、その2つのメソッドで
静的なインスタンスを共有したいのですが、
クライアントからWebメソッド1呼び出し⇒Webメソッド2呼び出しとすると
静的なインスタンスが初期化されてしまいます。
延々とWebメソッド1だけを呼び出す場合、静的なインスタンスは初期化されずに
更新する値を保持します。
ASP.NETの場合、WebMethod属性を付けた、同一のクラスメソッドであっても
それぞれの呼び出し時にはコンパイルが走るのでしょうか?
(コンパイル時インスタンスが破棄される)
大変お手数ですが、どなたかご教授ください。よろしくお願い致します。
親記事 /過去ログ34より /
関連記事表示
削除チェック/
■17276
Re[1]: Webサービスのコンパイルタイミング
□投稿者/ はつね -
(2008/04/21(Mon) 14:09:20)
>
■
No17274
(烈海王 さん) に返信
> ASP.NETを用いてWebサービスを作成しております。
> 環境としては仮想ディレクトリにasmxファイルとApp_Codeディレクトリ(ソースファイルが入ってる)
> といった構成です。
1仮想ディレクトリに1asmxファイルがあって、2Webメソッドが実装されているってことですか?
そうだとすれば、JITコンパイルは2Webメソッドまとめて行われますよ。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17277
Re[2]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 15:19:26)
■
No17276
(はつね さん) に返信
> ■
No17274
(烈海王 さん) に返信
>>ASP.NETを用いてWebサービスを作成しております。
>>環境としては仮想ディレクトリにasmxファイルとApp_Codeディレクトリ(ソースファイルが入ってる)
>>といった構成です。
>
> 1仮想ディレクトリに1asmxファイルがあって、2Webメソッドが実装されているってことですか?
> そうだとすれば、JITコンパイルは2Webメソッドまとめて行われますよ。
>
回答ありがとうございます。
そうなのですか。ただ気になっているのは
@Webメソッド1⇒Webメソッド1⇒Webメソッド1
AWebメソッド1⇒Webメソッド2⇒Webメソッド1
上記@の場合はサクサク動いてくれるのですが、
Aの場合は呼び出すメソッドが変わるたびに
5秒程の時間(@に比べるとかなり遅い)かかります。
それもあり、これはコンパイルされているのかな??と
思った次第です。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17278
Re[3]: Webサービスのコンパイルタイミング
□投稿者/ はつね -
(2008/04/21(Mon) 15:38:00)
>
■
No17277
(烈海王 さん) に返信
> そうなのですか。ただ気になっているのは
> @Webメソッド1⇒Webメソッド1⇒Webメソッド1
> AWebメソッド1⇒Webメソッド2⇒Webメソッド1
>
> 上記@の場合はサクサク動いてくれるのですが、
> Aの場合は呼び出すメソッドが変わるたびに
> 5秒程の時間(@に比べるとかなり遅い)かかります。
メソッドが変わるたびに遅いのですか?
それはWebメソッド側のJITコンパイルとかの話ではなく、Webサービスの接続とかの問題って事はないですか?
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17279
Re[4]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 15:49:07)
■
No17278
(はつね さん) に返信
> ■
No17277
(烈海王 さん) に返信
>>そうなのですか。ただ気になっているのは
>>@Webメソッド1⇒Webメソッド1⇒Webメソッド1
>>AWebメソッド1⇒Webメソッド2⇒Webメソッド1
>>
>>上記@の場合はサクサク動いてくれるのですが、
>>Aの場合は呼び出すメソッドが変わるたびに
>>5
秒程の時間(@に比べるとかなり遅い)かかります。
>
> メソッドが変わるたびに遅いのですか?
> それはWebメソッド側のJITコンパイルとかの話ではなく、Webサービスの接続とかの問題って事はないですか?
その可能性もあるのでしょうか。@のパターンがある以上、接続の問題は関係ないと考えていました。
それと今試して気付いたのですが、Webサービスクラスはクライアントから要求があるたびに生成されるのですね。
Webサービスクラスのコンストラクタに静的インスタンスを初期化する処理を加えたら
@のパターンでも常に初期値を返すようになりました。
本件の問題(Webメソッド1とWebメソッド2で静的インスタンスを共有できていない)
これは静的インスタンスのスコープの問題なのでしょうか。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17280
Re[2]: Webサービスのコンパイルタイミング
□投稿者/ 渋木宏明(ひどり) -
(2008/04/21(Mon) 16:33:25)
>
> 1仮想ディレクトリに1asmxファイルがあって、2Webメソッドが実装されているってことですか?
> そうだとすれば、JITコンパイルは2Webメソッドまとめて行われますよ。
そうなんでしたっけ?
少なくとも Windows Forms では JIT はメソッド単位で行われます。
ASP.NET もこれの応用なら、.aspx や .asmx への初回アクセスで .dll 作成、呼び出されたメソッドが順次 JIT されつつ実行、なのかと思ってました。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17283
Re[3]: Webサービスのコンパイルタイミング
□投稿者/ ネタ好き -
(2008/04/21(Mon) 17:39:44)
2008/04/21(Mon) 17:48:27 編集(投稿者)
列海王さんへ
もしかしたら、違うセッションと判断されているのかもしれませんね。
だから、メソッド2を呼び出した時点でインスタンスが新たに作られるのかも。
ためしにWebサービス内でアプリケーションの情報を出力しては如何でしょうか?
コンパイルについては、メソッド単位だと思います。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17284
Re[4]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 17:45:54)
■
No17283
(ネタ好き さん) に返信
> 2008/04/21(Mon) 17:40:08 編集(投稿者)
>
> 列海王さんへ
> もしかしたら、違うコネクションと判断されているのかもしれませんね。
> だから、メソッド2を呼び出した時点でインスタンスが新たに作られるのかも。
> ためしにWebサービス内でアプリケーションの情報を出力しては如何でしょうか?
> コンパイルについては、メソッド単位だと思います。
>
なるほど、新たにインスタンスが作られるのであればこの動作は
納得ですね。
(さらに、同一のメソッドを連続して呼び出す場合はコンパイルは
発生しないということですか、、)
大変恐縮ですが、アプリケーションの情報はどのようなものを
出力すればメソッド間の差異を効率よく発見できるのでしょうか。
お手数ですが、ご教授下さい。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17285
Re[5]: Webサービスのコンパイルタイミング
□投稿者/ ネタ好き -
(2008/04/21(Mon) 17:54:20)
2008/04/21(Mon) 18:06:17 編集(投稿者)
2008/04/21(Mon) 17:55:06 編集(投稿者)
烈海王 さんに返信
例えば、
public class Foo {
private static DateTime timeStamp;
[WebMethod]
public static void Foo1(-省略-) {
timeStamp = DateTime.Now;
-省略-
}
[WebMethod]
public static void Foo2(-省略-) {
Debug.Write(timeStamp.ToString())
}
}
ってな感じでどうでしょうか?
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17295
Re[6]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 18:36:39)
下記のWebサービスを作成し、試してみました。
Set()とGet()で情報の共有が出来ていることを確認しました。
もし、メソッドごとにコンパイルが発生する場合、
Set()で設定した情報はリセットされるものと
考えてましたが、、、いかがでしょう。
さらに、現在の私の問題に近づけるため、
_xと_yを保持した静的クラスを別途設け、Set()とGet()で
参照するようにしたところ、これも同一のインスタンスを
参照できていました。
public class Service : System.Web.Services.WebService
{
public Service () { }
static int _x;
static int _y;
[WebMethod]
public void Set(int x, int y) {
_x = x;
_y = y;
}
[WebMethod]
public int Get()
{
return _x + _y;
}
}
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17299
Re[7]: Webサービスのコンパイルタイミング
□投稿者/ 渋木宏明(ひどり) -
(2008/04/21(Mon) 20:06:15)
>
> もし、メソッドごとにコンパイルが発生する場合、
> Set()で設定した情報はリセットされるものと
> 考えてましたが、、、いかがでしょう。
「コンパイル」つーのがどういう動作を指しているかによって異なります。
「.aspx や .asmx から .dll を生成する」のと「実行対象となったメソッドが JIT される」のはまったく別の動作です。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17301
Re[8]: Webサービスのコンパイルタイミング
□投稿者/ なちゃ -
(2008/04/21(Mon) 20:29:03)
小さなサイトで何秒もかかるのは、アプリが再起動してる場合が多いです。
※もちろん他の可能性もありますが
で、例えばbinディレクトリに書き込みしてないかとか、
そういうところの方が確認が要りそうです。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17302
Re[9]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 21:05:51)
■
No17301
(なちゃ さん) に返信
> 小さなサイトで何秒もかかるのは、アプリが再起動してる場合が多いです。
> ※もちろん他の可能性もありますが
>
> で、例えばbinディレクトリに書き込みしてないかとか、
> そういうところの方が確認が要りそうです。
>
!!!
今、衝撃が走りました。
Webメソッド2ではbinディレクトリ配下を操作しています。
まだ試していませんが、恐らくこれですね・・・。
記事No.17274 のレス /過去ログ34より /
関連記事表示
削除チェック/
■17304
Re[10]: Webサービスのコンパイルタイミング
□投稿者/ 烈海王 -
(2008/04/21(Mon) 21:15:35)
今、確認しました。
なちゃ さんの忠告どおり、binディレクトリ内の情報更新によって
リコンパイルされていたことが原因です。
別のことに気を取られていました。
とてもお恥ずかしいです・・・。
皆様ご協力ありがとうございました。
記事No.17274 のレス / END /過去ログ34より /
関連記事表示
削除チェック/
<<
0
>>
パスワード/
-
Child Tree
-