欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測

今天就跟大家聊聊有關(guān)怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

網(wǎng)站設(shè)計(jì)、網(wǎng)站制作的關(guān)注點(diǎn)不是能為您做些什么網(wǎng)站,而是怎么做網(wǎng)站,有沒有做好網(wǎng)站,給創(chuàng)新互聯(lián)建站一個展示的機(jī)會來證明自己,這并不會花費(fèi)您太多時(shí)間,或許會給您帶來新的靈感和驚喜。面向用戶友好,注重用戶體驗(yàn),一切以用戶為中心。

什么是LRU

在這里還是要大概介紹一下LRU,LRU算法的設(shè)計(jì)原則是:如果一個數(shù)據(jù)在最近一段時(shí)間沒有被訪問到,那么在將來它被訪問的可能性也很小.也就是說,當(dāng)限定的空間已存滿數(shù)據(jù)時(shí),應(yīng)當(dāng)把最久沒有被訪問到的數(shù)據(jù)淘汰.當(dāng)然在這里并不需要使用到自動淘汰機(jī)制,只需要把未位到達(dá)超時(shí)的連接清除即可。

在C#中如何實(shí)現(xiàn)LRU

C#并不存在這樣的數(shù)據(jù)結(jié)構(gòu),不過有一個結(jié)構(gòu)很適合實(shí)現(xiàn)LRU,這個結(jié)構(gòu)就是LinkedList雙向鏈表,通過以下結(jié)構(gòu)圖就容易理解通過LinkedList實(shí)現(xiàn)LRU

怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測

通過LinkedList的功能我們可以把活越項(xiàng)先移出來,然后再把項(xiàng)移到頭部。在這里需要注意LinkedList的Remove方法,它有兩個重載版本,兩個版本的復(fù)雜度不一樣。一個是O(n)一個是O(1)所以使用上一定要注意,否則在數(shù)據(jù)多的情況下效率差別巨大(這些細(xì)節(jié)都可以通過源代碼來查看)!

代碼實(shí)現(xiàn)

前面已經(jīng)大概講述的原理,接下來要做的就是代碼實(shí)現(xiàn)了。第一步需要制訂一個基礎(chǔ)可控測對象規(guī)則接口,這樣就可以讓現(xiàn)有的已經(jīng)實(shí)現(xiàn)的功能實(shí)現(xiàn)它并可得到相關(guān)功能的支持。

public interface IDetector
  {
    double ActiveTime
    { get; set; }
    LinkedListNode<IDetector> DetectorNode
    {
      get;
      set;
    }
  }

接口定義了兩個屬性,一個是最近活越時(shí)間,另一個就是LinkedListNode<IDetector>這個屬性比交關(guān)鍵,通過LinkedListNode<IDetector>可以讓LinkedList在Remove時(shí)復(fù)雜度為O(1).接下來就要針對基于LRU算法處理超時(shí)制定一個應(yīng)用規(guī)則

 public interface ILRUDetector
  {
    void Update(IDetector item);
    void Detection(int timeout);
    double GetTime();
    Action<IList<IDetector>> Timeout { get; set; }
  }

規(guī)則也是比較簡單,Update用于更新跟蹤對象,一般在處理接受ping或pong包后進(jìn)行調(diào)用;Detection方法是探測超出指定時(shí)間的對象,時(shí)間當(dāng)位是毫秒,如果存在有超時(shí)的對象則觸發(fā)Timeout事件;GetTime是獲取探測器已經(jīng)運(yùn)行的時(shí)間單位毫秒!規(guī)則定好了那接著要做的事實(shí)就是要實(shí)現(xiàn)它:

 class LRUDetector : ILRUDetector, IDisposable
  {
    public LRUDetector()
    {
      mTimeWatch = new System.Diagnostics.Stopwatch();
      mTimeWatch.Restart();
    }
    private Buffers.XSpinLock xSpinLock = new Buffers.XSpinLock();
    private System.Diagnostics.Stopwatch mTimeWatch;
    private LinkedList<IDetector> mItems = new LinkedList<IDetector>();
    public Action<IList<IDetector>> Timeout
    {
      get; set;
    }
    public void Detection(int timeout)
    {
      double time = GetTime();
      List<IDetector> result = new List<IDetector>();
      using (xSpinLock.Enter())
      {
        LinkedListNode<IDetector> last = mItems.Last;
        while (last != null && (time - last.Value.ActiveTime) > timeout)
        {
          mItems.Remove(last);
          result.Add(last.Value);
          last.Value.DetectorNode = null;
          last = mItems.Last;
        }
      }
      if (Timeout != null && result.Count > 0)
        Timeout(result);
    }
    public void Update(IDetector item)
    {
      using (xSpinLock.Enter())
      {
        if (item.DetectorNode == null)
          item.DetectorNode = new LinkedListNode<IDetector>(item);
        item.ActiveTime = GetTime();
        if (item.DetectorNode.List == mItems)
          mItems.Remove(item.DetectorNode);
        mItems.AddFirst(item);
      }
    }
    public void Dispose()
    {
      mItems.Clear();
    }
    public double GetTime()
    {
      return mTimeWatch.Elapsed.TotalMilliseconds;
    }
  }

代碼并不復(fù)雜,相信不用過多解釋也能看懂相關(guān)操作原理。

測試

既然功能已經(jīng)實(shí)現(xiàn),接下來就要對代碼進(jìn)行測試看運(yùn)行效果。測試代碼比較簡單首先開啟一個Timer定時(shí)執(zhí)行Detection,另外開一個線程去調(diào)用Update方法

class Program
  {
    public class TestDetector : IDetector
    {
      public double ActiveTime { get; set; }
      public string Name { get; set; }
      public LinkedListNode<IDetector> DetectorNode { get; set; }
    }
    static void Main(string[] args)
    {
      LRUDetector lRUDetector = new LRUDetector();
      lRUDetector.Timeout = (items) =>
      {
        foreach (TestDetector item in items)
          Console.WriteLine($"{(item.Name)} timeout {lRUDetector.GetTime() - item.ActiveTime}ms");
      };
      System.Threading.Timer timer = null;
      timer = new System.Threading.Timer(o =>
      {
        timer.Change(-1, -1);
        lRUDetector.Detection(5000);
        timer.Change(5000, 5000);
      }, null, 5000, 5000);
      System.Threading.ThreadPool.QueueUserWorkItem(o =>
      {
        int i = 0;
        while (true)
        {
          System.Threading.Thread.Sleep(500);
          i++;
          TestDetector testDetector = new TestDetector();
          testDetector.Name = "my name is " + i;
          lRUDetector.Update(testDetector);
        }
      });
      Console.Read();
    }
  }

運(yùn)行效果:

怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測

看完上述內(nèi)容,你們對怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

文章標(biāo)題:怎么在C#中通過LRU實(shí)現(xiàn)通用高效的超時(shí)連接探測
瀏覽地址:http://aaarwkj.com/article26/gjcijg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站收錄自適應(yīng)網(wǎng)站、服務(wù)器托管做網(wǎng)站、

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站
日本精品三级一区二区视频| 亚洲人妻av一区二区三区 | 国产91黑丝视频在线观看| 美女网站色在线免费观看午夜精品| 欧美一级纯黄电影视频| 亚洲精品国产av一区| 中文字幕乱码亚洲精品一区 | 日韩在线中文字幕精品| 2020中文字字幕在线不卡| 国产av网站精品成人| 午夜视频在线观看麻豆| 一本在线不卡中文字幕| 熟妇人妻精品视频一区二区| 国产在线视频不卡福利片| 女人被爽到高潮呻吟免费看| 精品妇女一区二区三区| 欧美日韩国产免费,日日骚| 日韩国产一区二区在线观看| 日本人妻风俗店中文字幕| 成人免费av在线网址| 亚洲中文字幕一区乱码| 中文字幕乱码在线观看一区| 97国产免费全部免费观看| 国产欧美日本精品视频| 亚洲国产欧美日韩一区| 特黄一级黄色大片免费看| 亚洲毛片一区在线播放| 啊啊啊用力好大视频| 视频一区视频二区在线| 黄色亚洲大片免费在线观看| 欧美三级特黄在线播放| 日韩欧美中文字幕区| 欧美成人日本在线播放| 国产亚洲av综合人人精品| 久久热在线观看免费高清| 免费在线观看日韩av大片| 国产精品日韩一区视频| 国产成人自拍激情视频| 天堂网一区二区三区四区| 久草免费福利视频资源站| 一本久道久久综合狠狠老|