国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

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

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

問題描述

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

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

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

問題解答

回答1:

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

回答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個請求會被緩存。第21個請求會導致LRU從緩存中將時間比較老的請求移除掉。

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

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

相關文章:
主站蜘蛛池模板: 星子县| 罗江县| 湄潭县| 桐乡市| 宜黄县| 南宁市| 德安县| 浑源县| 和顺县| 大田县| 普洱| 垦利县| 岑溪市| 阿图什市| 鄂尔多斯市| 两当县| 吉水县| 会同县| 福安市| 宁南县| 建宁县| 莆田市| 葵青区| 宁城县| 溆浦县| 波密县| 集贤县| 大名县| 游戏| 彰化县| 万安县| 鹿邑县| 东城区| 祥云县| 集安市| 伊吾县| 景德镇市| 静宁县| 阿荣旗| 塔河县| 抚松县|