{"id":71,"date":"2021-04-26T17:13:48","date_gmt":"2021-04-26T09:13:48","guid":{"rendered":"https:\/\/blog.king011.com\/?p=71"},"modified":"2021-04-27T09:19:22","modified_gmt":"2021-04-27T01:19:22","slug":"%e5%be%9e%e9%9b%b6%e9%96%8b%e5%a7%8b%e7%9a%84%e7%b7%a9%e5%ad%98%e7%94%9f%e6%b4%bb-%e6%a6%82%e8%bf%b0","status":"publish","type":"post","link":"https:\/\/blog.king011.com\/?p=71","title":{"rendered":"\u5f9e\u96f6\u958b\u59cb\u7684\u7de9\u5b58\u751f\u6d3b-\u6982\u8ff0"},"content":{"rendered":"\n<p>\u7de9\u5b58\u662f\u63d0\u9ad8\u7a0b\u5f0f\u6548\u7387\u6700\u5feb\u6700\u7c21\u55ae\u7684\u65b9\u6848\uff0c\u8a08\u7b97\u6a5f\u7684\u5404\u500b\u90e8\u4ef6\u90fd\u5145\u65a5\u7740\u7de9\u5b58\uff0c\u672c\u7cfb\u5217\u6587\u7ae0\u4e3b\u8981\u8a0e\u8ad6\u5167\u5b58\u7de9\u5b58\u548c\u5e38\u898b\u7684\u5be6\u73fe\u7b97\u6cd5\uff0c\u53e6\u5916\u56e0\u7232\u672c\u55b5\u89ba\u5f97\u5beb golang \u4ee3\u78bc\u5f88\u8f15\u9b06\u6545\u4ee3\u78bc\u5c07\u4ee5 golang \u66f8\u5beb(\u4f46\u672c\u55b5\u6703\u529b\u5716\u7c21\u55ae\u548c\u6e05\u6670\u7684\u8a3b\u91cb\uff0c\u4e0d\u6703\u4f7f\u7528golang\u61c9\u8a72\u4e5f\u80fd\u770b\u61c2)\u3002\u4e0b\u9762\u662f\u7cfb\u5217\u6587\u7ae0\u5167\u5bb9\u6982\u8ff0\uff1a<\/p>\n\n\n\n<ol class=\"wp-block-list\"><li>\u57fa\u790e\u4ecb\u7d39 \u5c31\u662f\u672c\u6587<\/li><li>fifo \u5206\u6790 \u5be6\u73fe<\/li><li>lfu \u5206\u6790 \u5be6\u73fe<\/li><li>lru \u5206\u6790 \u5be6\u73fe<\/li><li>lru-k \u5206\u6790 \u5be6\u73fe<\/li><\/ol>\n\n\n\n<p>\u6b64\u5916\u672c\u55b5\u6709\u7232 golang \u958b\u6e90\u4e00\u500b\u7de9\u5b58\u9805\u76ee\uff0c\u4e0a\u8ff0\u7b97\u6cd5\u90fd\u6709\u5be6\u73fe\uff0c\u5982\u679c\u4f60\u53ea\u662f\u60f3\u627e\u5230\u4e00\u500b\u958b\u6e90 golang \u5eab\u4f7f\u7528\uff0c\u53ef\u4ee5\u8003\u616e <a rel=\"noreferrer noopener\" href=\"https:\/\/github.com\/powerpuffpenguin\/gcache\" target=\"_blank\">https:\/\/github.com\/powerpuffpenguin\/gcache<\/a><\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u7de9\u5b58\u5b58\u5132\u7684\u6578\u64da\u7d50\u69cb<\/h2>\n\n\n\n<p>\u901a\u5e38\u7de9\u5b58\u5c31\u662f\u5c07\u8981\u8b80\u53d6\u7684\u6578\u64da\u9810\u5148\u5b58\u5132\u5230\u5167\u5b58\uff0c\u901a\u5e38\u7531\u4e00\u500b key \u548c value \u7d44\u6210\uff0c\u6bd4\u5982\u6578\u64da\u5eab\u4e2d\u6709\u500b\u7528\u6236id\u72321\u5176\u540d\u7a31\u7232 anita\uff0c\u611b\u597d\u662f music\u3002\u6bcf\u6b21\u5f9e\u6578\u64da\u5eab\u4e2d\u53d6\u6578\u64da\u5f88\u6162\uff0c\u6211\u5011\u5c31\u53ef\u4ee5\u7232\u5979\u5275\u5efa\u4e00\u689d\u7de9\u5b58\uff0c\u7de9\u5b58\u7684 key \u5c31\u662f id\uff0c\u800c\u540d\u7a31\u548c\u611b\u597d\u5c31\u662f value\u3002<\/p>\n\n\n\n<p>\u7576\u64c1\u6709\u4e86\u9019\u689d\u7de9\u5b58\u4e4b\u5f8c\uff0c\u4e0b\u6b21\u67e5\u8a62\u6211\u5011\u5c31\u53ef\u4ee5\u5148\u6bd4\u5c0d\u7de9\u5b58\u4e2d\u6709\u6c92\u6709key\u72321\u7684\u6578\u64da\uff0c\u5982\u679c\u6709\u9019\u689d\u6578\u64da\u5c31\u76f4\u63a5\u5f9e\u7de9\u5b58\u4e2d\u7372\u53d6\u6578\u64da\u800c\u4e0d\u7528\u67e5\u8a62\u6578\u64da\u5eab\u3002<\/p>\n\n\n\n<p>\u56e0\u7232\u5728\u7372\u53d6\u7de9\u5b58\u6578\u64da\u6642\u50b3\u5165 key \u8fd4\u56de value \u6240\u4ee5\u7de9\u5b58\u5b58\u5132\u7d50\u69cb\u5c31\u9700\u8981\u8003\u616e\u4f7f\u7528\u5118\u91cf\u80fd\u5920\u5feb\u901f\u67e5\u8a62\u7684\u6578\u64da\u7d50\u69cb\uff0c\u9019\u6a23\u6578\u7d44\u548c\u93c8\u8868\u5c31\u76f4\u63a5\u88ab\u6dd8\u6c70\u4e86\uff0c\u56e0\u7232\u5982\u679c\u7528\u9019\u5169\u7a2e\u7d50\u69cb\u5c31\u9700\u8981\u628a key \u548c \u6240\u6709\u5df2\u7de9\u5b58\u7684key \u5c0d\u6bd4\u624d\u80fd\u8fd4\u56de\u5c0d\u61c9\u7684 value\u3002\u901a\u5e38\u4f7f\u7528\u7684\u6578\u64da\u7d50\u69cb\u662f Map&lt;Key,Value&gt;\u3002Map \u53ef\u4ee5\u4f7f\u7528\u4e8c\u53c9\u6392\u5e8f\u6a39\u6216\u8005\u662f hashtable \u4e3b\u8981\u770b\u4f60\u4f7f\u7528\u7684\u8a9e\u8a00\u90a3\u7a2e\u65b9\u4fbf\u6bd4\u5982 c++ std::map \u4f7f\u7528\u7684\u662f\u7d05\u9ed1\u6a39\uff0cgolang \u6a19\u6e96\u5eab\u7684 map \u662f hashtable\uff0c\u4f46\u901a\u5e38 hashtable \u6703\u6bd4 \u4e8c\u53c9\u6392\u5e8f\u6a39 \u63d0\u4f9b\u66f4\u9ad8\u7684\u67e5\u8a62\u6548\u7387\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u7de9\u5b58\u6dd8\u6c70<\/h2>\n\n\n\n<p>\u7de9\u5b58\u5b58\u5132\u7684\u6578\u64da\u7d50\u69cb\u901a\u5e38\u6c92\u6709\u5dee\u5225\uff0c\u5927\u90e8\u5206\u90fd\u662f\u76f4\u63a5\u4f7f\u7528\u7684 Map\uff0c\u4e0d\u540c\u7de9\u5b58\u7b97\u6cd5\u7684\u5dee\u5225\u5728\u65bc\u6dd8\u6c70\u7b97\u6cd5\u3002<\/p>\n\n\n\n<p>\u56e0\u7232\u7de9\u5b58\u662f\u7232\u4e86\u63d0\u5347\u6548\u7387\uff0c\u6240\u4ee5\u7de9\u5b58\u901a\u5e38\u662f\u5b58\u5132\u5728\u6bd4\u6578\u64da\u6e90\u6240\u5728\u4ecb\u8cea\u66f4\u6602\u8cb4\u7684\u5b58\u5132\u4ecb\u8cea\u4e2d\uff0c\u6bd4\u5982\u672c\u7cfb\u5217\u6587\u7ae0\u8a0e\u8ad6\u7684\u662f\u5c07\u7de9\u5b58\u5b58\u5132\u5230\u5167\u5b58(\u5982\u679c\u8981\u5b58\u5132\u5230\u5176\u5b83\u5730\u65b9\u53ef\u80fd\u9700\u8981\u8003\u616e\u6578\u64da\u7684\u5e8f\u5217\u5316\u53ea\u6703\u589e\u52a0\u6587\u7ae0\u8907\u96dc\u5ea6)\u3002<\/p>\n\n\n\n<p>\u56e0\u7232\u5b58\u5132\u4ecb\u8cea\u6602\u8cb4\u6240\u4ee5\u5bb9\u91cf\u6709\u9650\uff0c\u901a\u5e38\u7121\u6cd5\u628a\u6578\u64da\u6e90\u6574\u500b\u7de9\u5b58\u4e0b\u4f86\uff0c\u7576\u7de9\u5b58\u5230\u9054\u5b58\u5132\u4e0a\u9650\u4f46\u53c8\u6709\u65b0\u6578\u64da\u9700\u8981\u7de9\u5b58\u6642\uff0c\u5c31\u9700\u8981\u6dd8\u6c70\u4e00\u90e8\u5206\u7de9\u5b58\u4f86\u5b58\u65b0\u5167\u5bb9\uff0c\u5982\u4f55\u5118\u91cf\u6dd8\u6c70\u4e0d\u88ab\u9700\u8981\u7684\u6578\u64da\u800c\u5c07\u71b1\u9ede(\u7d93\u5e38\u9700\u8981\u67e5\u8a62\u7684\u6578\u64da)\u4fdd\u5b58\u5230\u7de9\u5b58\u4e2d\u662f\u5404\u7b97\u6cd5\u8981\u89e3\u6c7a\u7684\u554f\u984c\u548c\u5dee\u7570\uff0c\u4e26\u4e14\u4e5f\u662f\u7de9\u5b58\u7b97\u6cd5\u662f\u5426\u6709\u6548\u7684\u8861\u91cf\u6a19\u6e96\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u7de9\u5b58\u63a5\u53e3<\/h2>\n\n\n\n<p>\u672c\u6587\u6700\u5f8c\uff0c\u6211\u5011\u5b9a\u7fa9\u4e00\u500b golang \u7de9\u5b58\u63a5\u53e3\uff0c\u5f8c\u7e8c\u5c07\u570d\u7e5e\u5404\u500b\u7b97\u6cd5\u4f86\u5be6\u73fe\u9019\u500b\u63a5\u53e3\uff1a<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>type Cache interface {\n\tPut(key, value interface{})\n\tGet(key interface{}) (value interface{}, exists bool)\n\tDelete(key interface{})\n}<\/code><\/pre>\n\n\n\n<p>\u4e0a\u8ff0\u63a5\u53e3\u76f8\u7576\u7c21\u55ae\uff0c\u5f9e\u5176\u63a5\u53e3\u4f86\u770b\u4f7f\u7528\u4e5f\u76f8\u7576\u7c21\u55ae\uff0c\u57fa\u672c\u548c\u5404\u8a9e\u8a00\u6a19\u6e96\u5eab\u63d0\u4f9b\u7684 Map \u4f7f\u7528\u76f8\u5dee\u7121\u5e7e\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5e38\u7528\u7de9\u5b58\u7b97\u6cd5\u4ecb\u7d39 golang\u5be6\u73fe\u793a\u4f8b\u4ee3\u78bc fifo lru lfu lru-k 2q<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[11,14,2,13],"tags":[16,12,17,18,19,20],"class_list":["post-71","post","type-post","status-publish","format-standard","hentry","category-golang","category-re0-cache","category-code","category-algorithm","tag-fifo","tag-golang","tag-lfu","tag-lru","tag-lru-k","tag-lruk"],"blocksy_meta":{"styles_descriptor":{"styles":{"desktop":"","tablet":"","mobile":""},"google_fonts":[],"version":6}},"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/posts\/71","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/blog.king011.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=71"}],"version-history":[{"count":13,"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/posts\/71\/revisions"}],"predecessor-version":[{"id":87,"href":"https:\/\/blog.king011.com\/index.php?rest_route=\/wp\/v2\/posts\/71\/revisions\/87"}],"wp:attachment":[{"href":"https:\/\/blog.king011.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=71"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/blog.king011.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=71"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/blog.king011.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=71"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}