久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

angular.js - angularjs $cacheFactory capacity 怎么理解

瀏覽:182日期:2024-09-17 17:17:03

問題描述

angular.js - angularjs $cacheFactory capacity 怎么理解怎么理解圖中的話,最好有demo

angular.js - angularjs $cacheFactory capacity 怎么理解

自己寫了個(gè)demo超過了限制的capacity:3但是每次緩存cache.info()打印出來的size都一樣。另外$cacheFactory(key,[option])中的key只能是一個(gè)字符串嗎,如何一次定義多個(gè)緩存對象

問題解答

回答1:

capacity相當(dāng)于給該cache規(guī)定了一個(gè)可以使用的最大容量。舉個(gè)簡單例子,假如你有3個(gè)水桶(capacity=3),你裝了第一桶水(put),那么它還是有3個(gè)桶。再裝一桶水,直到裝到第四桶水的時(shí)候,因?yàn)橹挥?個(gè)桶,顯然這桶水裝不下了,怎么辦呢?把最先裝的那桶水倒掉,用這個(gè)桶來裝第四桶水(cache策略:LRU)可以看一下$cacheFatory的實(shí)現(xiàn),應(yīng)該會(huì)有更深的理解

回答2:

capacity 涉及到的是LRU(Least Recenlty Used, 最近最少使用)緩存,如:

var lru = $cacheFactory(’lru’, {capacity: 20});// $http請求$http.get(’/api/users.json’, {cache: lru}).then(function(data){});

現(xiàn)在,最新的20個(gè)請求會(huì)被緩存。第21個(gè)請求會(huì)導(dǎo)致LRU從緩存中將時(shí)間比較老的請求移除掉。

我們還可以通過應(yīng)用的.config()函數(shù),即配置階段給所有$http請求設(shè)置一個(gè)默認(rèn)的緩存:

angular.module(’myApp’, []).config(function($httpProvider, $cacheFactory) { $httpProvider.defaults.cache = $cacheFactory(’lru’, {capacity: 20 });});

相關(guān)文章:
主站蜘蛛池模板: 新乡市| 衢州市| 遵化市| 西丰县| 广灵县| 福泉市| 汾阳市| 江华| 百色市| 惠州市| 扎鲁特旗| 阿克苏市| 沁水县| 黎平县| 永寿县| 老河口市| 陵川县| 长沙市| 横山县| 敖汉旗| 盐边县| 尼勒克县| 榆树市| 塔河县| 木里| 汶上县| 尤溪县| 文安县| 高邮市| 铁力市| 贡觉县| 峨眉山市| 自贡市| 濮阳县| 鄂伦春自治旗| 横峰县| 博湖县| 额敏县| 兴义市| 元朗区| 新沂市|