佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 基于自定義Unity生存期模型PerCallContextLifeTimeManager的問題

基于自定義Unity生存期模型PerCallContextLifeTimeManager的問題

熱門標簽:銀行業(yè)務 科大訊飛語音識別系統(tǒng) 團購網(wǎng)站 Linux服務器 阿里云 電子圍欄 Mysql連接數(shù)設(shè)置 服務器配置

PerThreadLifetimeManager的問題
使用Unity內(nèi)置的PerThreadLifetimeManager生存期模型時,其基于ThreadStatic的TLS(Thread Local Storage)設(shè)計,也就是說對于每個托管的ManagedThreadId,其會緩存已生成的對象實例。

由于CLR維護了托管線程池,使用過的線程并不會立即銷毀,在需要的時候會繼續(xù)復用。在類似ASP.NET PerCall或WCF PerCall條件下,當Call1在線程ManagedThreadId1中處理完畢后,Call2發(fā)生,而Call2很有可能也在線程ManagedThreadId1中處理。這種條件下Call2會自動復用處理Call1時生成并緩存的對象實例。

如果我們希望每次調(diào)用(PerCall)都生成專用的對象實例,則PerThreadLifetimeManager在此種場景下不適合。

解決辦法有兩種:

1.繼續(xù)使用PerThreadLifetimeManager模型,不適用ThreadPool,而手動創(chuàng)建和銷毀線程。
2.自定義對象生存期模型
PerCallContextLifeTimeManager

復制代碼 代碼如下:

public class PerCallContextLifeTimeManager : LifetimeManager
    {
      private string _key =
        string.Format(CultureInfo.InvariantCulture,
        "PerCallContextLifeTimeManager_{0}", Guid.NewGuid());

      public override object GetValue()
      {
        return CallContext.GetData(_key);
      }

      public override void SetValue(object newValue)
      {
        CallContext.SetData(_key, newValue);
      }

      public override void RemoveValue()
      {
        CallContext.FreeNamedDataSlot(_key);
      }
    }


使用舉例
復制代碼 代碼如下:

private static void TestPerCallContextLifeTimeManager()
    {
      IExample example;
      using (IUnityContainer container = new UnityContainer())
      {
        container.RegisterType(typeof(IExample), typeof(Example),
          new PerCallContextLifeTimeManager());

        container.ResolveIExample>().SayHello();
        container.ResolveIExample>().SayHello();

        Actionint> action = delegate(int sleep)
        {
          container.ResolveIExample>().SayHello();
          Thread.Sleep(sleep);
          container.ResolveIExample>().SayHello();
        };

        Thread thread1 = new Thread((a) => action.Invoke((int)a));
        Thread thread2 = new Thread((a) => action.Invoke((int)a));
        thread1.Start(50);
        thread2.Start(55);
        thread1.Join();
        thread2.Join();

        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 50);
        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 55);
        Thread.Sleep(100);

        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 50);
        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 55);
        Thread.Sleep(100);

        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 50);
        ThreadPool.QueueUserWorkItem((a) => action.Invoke((int)a), 55);
        Thread.Sleep(100);

        example = container.ResolveIExample>();
      }

      example.SayHello();

      Console.ReadKey();
    }

您可能感興趣的文章:
  • 解決unity3d導入模型貼圖材質(zhì)丟失的問題
  • Unity使用EzySlice實現(xiàn)模型多邊形順序切割
  • Unity實現(xiàn)鼠標或者手指點擊模型播放動畫
  • Unity UI拖拽模型選擇功能
  • Unity3D實現(xiàn)模型淡入淡出效果
  • Unity3D網(wǎng)格功能生成球體網(wǎng)格模型
  • Unity實現(xiàn)模型點擊事件的方法

標簽:蚌埠 江蘇 大理 棗莊 萍鄉(xiāng) 廣元 衢州 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標題《基于自定義Unity生存期模型PerCallContextLifeTimeManager的問題》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    泊头市| 永年县| 杨浦区| 谢通门县| 常熟市| 齐河县| 洪洞县| 道孚县| 伊通| 湘阴县| 汝南县| 遵义县| 元氏县| 登封市| 新闻| 和平区| 沈阳市| 沙湾县| 郴州市| 武穴市| 眉山市| 天祝| 常德市| 布拖县| 礼泉县| 南平市| 深圳市| 竹山县| 山东省| 黄大仙区| 岐山县| 巴楚县| 天柱县| 兴山县| 兰坪| 普陀区| 若尔盖县| 鄯善县| 阜城县| 石阡县| 达拉特旗|