{"id":4768,"date":"2021-09-06T11:36:02","date_gmt":"2021-09-06T03:36:02","guid":{"rendered":"http:\/\/122.152.205.50\/wordpress\/?p=4768"},"modified":"2022-12-16T11:14:19","modified_gmt":"2022-12-16T03:14:19","slug":"%e6%8a%bd%e8%b1%a1%e9%98%9f%e5%88%97%e5%a4%84%e7%90%86%e5%b7%a5%e5%85%b7%e7%b1%bb","status":"publish","type":"post","link":"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768","title":{"rendered":"\u5229\u7528\u975e\u963b\u585e\u961f\u5217\u5b9e\u73b0\u7c7b\u4f3c\u963b\u585e\u7684\u6548\u679c"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_16 counter-hierarchy counter-decimal ez-toc-grey\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\">\u76ee\u5f55<\/p>\n<span class=\"ez-toc-title-toggle\"><a class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" style=\"display: none;\"><i class=\"ez-toc-glyphicon ez-toc-icon-toggle\"><\/i><\/a><\/span><\/div>\n<nav><ul class=\"ez-toc-list ez-toc-list-level-1\"><li class=\"ez-toc-page-1 ez-toc-heading-level-1\"><a class=\"ez-toc-link ez-toc-heading-1\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#%E6%BA%90%E7%A0%81\" title=\"\u6e90\u7801\">\u6e90\u7801<\/a><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-1\"><a class=\"ez-toc-link ez-toc-heading-2\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#%E7%94%A8%E6%B3%95\" title=\"\u7528\u6cd5\">\u7528\u6cd5<\/a><ul class=\"ez-toc-list-level-4\"><li class=\"ez-toc-heading-level-4\"><ul class=\"ez-toc-list-level-4\"><li class=\"ez-toc-heading-level-4\"><ul class=\"ez-toc-list-level-4\"><li class=\"ez-toc-heading-level-4\"><a class=\"ez-toc-link ez-toc-heading-3\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#1%E5%AE%9E%E7%8E%B0%E6%8A%BD%E8%B1%A1%E7%B1%BB\" title=\"1.\u5b9e\u73b0\u62bd\u8c61\u7c7b\">1.\u5b9e\u73b0\u62bd\u8c61\u7c7b<\/a><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-4\"><a class=\"ez-toc-link ez-toc-heading-4\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#2%E5%88%9D%E5%A7%8B%E5%8C%96%E5%AE%9E%E7%8E%B0%E7%9A%84%E5%B7%A5%E5%85%B7%E7%B1%BB\" title=\"2.\u521d\u59cb\u5316\u5b9e\u73b0\u7684\u5de5\u5177\u7c7b\">2.\u521d\u59cb\u5316\u5b9e\u73b0\u7684\u5de5\u5177\u7c7b<\/a><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-4\"><a class=\"ez-toc-link ez-toc-heading-5\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#3%E7%9B%91%E5%90%AC%E9%98%9F%E5%88%97%E5%85%83%E7%B4%A0%E4%BB%BB%E5%8A%A1%E8%A7%A6%E5%8F%91\" title=\"3.\u76d1\u542c\u961f\u5217\u5143\u7d20\u4efb\u52a1\u89e6\u53d1\">3.\u76d1\u542c\u961f\u5217\u5143\u7d20\u4efb\u52a1\u89e6\u53d1<\/a><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-4\"><a class=\"ez-toc-link ez-toc-heading-6\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#4%E6%89%8B%E5%8A%A8%E5%9C%B0%E8%A7%A6%E5%8F%91%E4%B8%8B%E4%B8%80%E4%B8%AA%E5%85%83%E7%B4%A0%E7%9A%84%E4%BB%BB%E5%8A%A1%E6%89%A7%E8%A1%8C\" title=\"4.\u624b\u52a8\u5730\u89e6\u53d1\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u6267\u884c\">4.\u624b\u52a8\u5730\u89e6\u53d1\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u6267\u884c<\/a><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-4\"><a class=\"ez-toc-link ez-toc-heading-7\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#5%E5%85%A5%E5%88%97\" title=\"5.\u5165\u5217\">5.\u5165\u5217<\/a><\/li><\/ul><\/li><\/ul><\/li><\/ul><\/li><li class=\"ez-toc-page-1 ez-toc-heading-level-1\"><a class=\"ez-toc-link ez-toc-heading-8\" href=\"http:\/\/xinyiworld.top\/wordpress_it\/?p=4768\/#%E5%B7%A5%E5%85%B7%E7%B1%BB%E7%9A%84%E8%AE%BE%E8%AE%A1%E5%88%9D%E8%A1%B7%E4%B8%8E%E4%BD%9C%E7%94%A8\" title=\"\u5de5\u5177\u7c7b\u7684\u8bbe\u8ba1\u521d\u8877\u4e0e\u4f5c\u7528\">\u5de5\u5177\u7c7b\u7684\u8bbe\u8ba1\u521d\u8877\u4e0e\u4f5c\u7528<\/a><\/li><\/ul><\/nav><\/div>\n<h1><span class=\"ez-toc-section\" id=\"%E6%BA%90%E7%A0%81\"><\/span>\u6e90\u7801<span class=\"ez-toc-section-end\"><\/span><\/h1>\n<pre><code class=\"language-java\">class AbsQueueTaskHelper&lt;T&gt; {\n    protected   final String TAG = this.getClass().getSimpleName();\n    \/**\n     * \u662f\u5426\u6709\u6b63\u5728\u6267\u884c\u7684\u4efb\u52a1\n     *\/\n    private boolean isTaskRunning = false;\n    private OnTaskActivateListener onTaskActivateListener;\n    \/**\n     * \u8bb0\u5f55\u5df2\u7ecf\u6267\u884c\u7684\u6b21\u6570\n     *\/\n    private int alreadyFinishCount = 0;\n    \/**\n     * \u8d77\u59cb\u65f6\u95f4\uff0c\u7528\u4e8e\u7edf\u8ba1\u4efb\u52a1\u8017\u65f6\u65f6\u95f4\u3002\n     *\/\n    private long startTime;\n    \/**\n     * \u961f\u5217\u4efb\u52a1\u662f\u5426\u7ed3\u675f\n     *\/\n    private boolean isFinish = true;\n    \/**\n     * \u8fd9\u91cc\u4f7f\u7528\u975e\u963b\u585e\u961f\u5217\n     *\/\n    private Queue&lt;T&gt; queue = new LinkedList&lt;&gt;();\n    private static AbsQueueTaskHelper instance = new AbsQueueTaskHelper();\n    protected AbsQueueTaskHelper(){\n        isTaskRunning = false;\n        this.alreadyFinishCount = 0;\n        this.isFinish = true;\n    }\n    public static AbsQueueTaskHelper getInstance(){\n        return instance;\n    }\n\n    public void init(){\n        isTaskRunning = false;\n        this.isFinish = false;\n        queue.clear();\n    }\n\n    \/**\n     * \u5c06\u6570\u636e\u52a0\u5165\u961f\u5217\n     * @param item\n     *\/\n    public void join(T item){\n        queue.offer(item);\n        activateTask();\n    }\n\n    \/**\n     * \u53d6\u961f\u5217\u6570\u636e\u6267\u884c\u4efb\u52a1\n     *\/\n    public void next(){\n        alreadyFinishCount++;\n        isTaskRunning = false;\n        activateTask();\n    }\n\n    \/**\n     * \u6fc0\u6d3b\u961f\u5217\u4efb\u52a1\n     *\/\n    private void activateTask(){\n        if(isTaskRunning == false){\n            if(queue.size() &gt; 0){\n                isFinish = false;\n                T item = queue.poll();\n                if(onTaskActivateListener != null){\n                    isTaskRunning = true;\n                    if(alreadyFinishCount == 0){\n                        startTime = System.currentTimeMillis();\n                    }\n                    onTaskActivateListener.onTaskActivate(item);\n                }\n            }else{\n                isFinish = true;\n            }\n        }else{\n\/\/          Log.d(TAG,&quot;try to activateTask but there is a task running now&quot;);\n        }\n    }\n\n    public void finish(){\n        this.isFinish = true;\n    }\n\n    \/**\n     * \u7528\u4e8e\u5ba2\u6237\u7aef\u8c03\u7528\u81ea\u5df1\u7684\u4e1a\u52a1\n     * @param onTaskActivateListener\n     *\/\n    public void setOnTaskActivateListener(\n            OnTaskActivateListener onTaskActivateListener) {\n        this.onTaskActivateListener = onTaskActivateListener;\n    }\n\n    \/**\n     * \u76d1\u542c\u6fc0\u6d3b\n     * @param &lt;T&gt;\n     *\/\n    public interface OnTaskActivateListener&lt;T&gt; {\n         void onTaskActivate(T item);\n    }\n\n    public int getAlreadyFinishCount() {\n        return alreadyFinishCount;\n    }\n\n    public long getUsedTimeMilliSeconds(){\n        return System.currentTimeMillis() - startTime;\n    }\n\n    public boolean isFinish() {\n        return isFinish;\n    }\n}<\/code><\/pre>\n<h1><span class=\"ez-toc-section\" id=\"%E7%94%A8%E6%B3%95\"><\/span>\u7528\u6cd5<span class=\"ez-toc-section-end\"><\/span><\/h1>\n<h4><span class=\"ez-toc-section\" id=\"1%E5%AE%9E%E7%8E%B0%E6%8A%BD%E8%B1%A1%E7%B1%BB\"><\/span>1.\u5b9e\u73b0\u62bd\u8c61\u7c7b<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<p>\u5b9e\u73b0AbsQueueTaskHelper\u7c7b\uff0c\u5b9a\u4e49\u961f\u5217\u5143\u7d20\u7684\u6cdb\u578b\u3002<\/p>\n<pre><code class=\"language-java\">class WriteLogQueueTaskHelper extends AbsQueueTaskHelper&lt;String&gt; {\n    private WriteLogQueueTaskHelper() {\n        super();\n    }\n}<\/code><\/pre>\n<h4><span class=\"ez-toc-section\" id=\"2%E5%88%9D%E5%A7%8B%E5%8C%96%E5%AE%9E%E7%8E%B0%E7%9A%84%E5%B7%A5%E5%85%B7%E7%B1%BB\"><\/span>2.\u521d\u59cb\u5316\u5b9e\u73b0\u7684\u5de5\u5177\u7c7b<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<pre><code class=\"language-java\">WriteLogQueueTaskHelper.getInstance().init();<\/code><\/pre>\n<h4><span class=\"ez-toc-section\" id=\"3%E7%9B%91%E5%90%AC%E9%98%9F%E5%88%97%E5%85%83%E7%B4%A0%E4%BB%BB%E5%8A%A1%E8%A7%A6%E5%8F%91\"><\/span>3.\u76d1\u542c\u961f\u5217\u5143\u7d20\u4efb\u52a1\u89e6\u53d1<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<p>\u76d1\u542c\u961f\u5217\u5143\u7d20\u4efb\u52a1\u89e6\u53d1\uff0c\u961f\u5217\u5143\u7d20\u5165\u5217\u7684\u65f6\u5019\uff0c\u5982\u679c\u6ca1\u6709\u6b63\u5728\u6267\u884c\u7684\u4efb\u52a1\u4f1a\u81ea\u52a8\u89e6\u53d1OnTaskActivateListener\u65b9\u6cd5\u3002<\/p>\n<pre><code class=\"language-java\">WriteLogQueueTaskHelper.getInstance().setOnTaskActivateListener(new AbsQueueTaskHelper.OnTaskActivateListener&lt;String&gt;() {\n            @Override\n            public void onTaskActivate(final String item) {\n                 \/\/\u4e00\u822c\u7684\u4e0b\u9762\u7684\u4ee3\u7801\u5e94\u8be5\u5728\u5b50\u7ebf\u7a0b\u4e2d\u6267\u884c\uff0c\u8fd9\u91cc\u6ca1\u6709\u5199\u3002\n                 \/\/1\u3001\u5bf9\u5165\u5217\u7684\u5143\u7d20item\u505a\u4e00\u4e9b\u64cd\u4f5c\n\n                 \/\/2\u3001\u624b\u52a8\u5730\u89e6\u53d1\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u6267\u884c\n                 WriteLogQueueTaskHelper.getInstance().next();\n            }\n        });<\/code><\/pre>\n<h4><span class=\"ez-toc-section\" id=\"4%E6%89%8B%E5%8A%A8%E5%9C%B0%E8%A7%A6%E5%8F%91%E4%B8%8B%E4%B8%80%E4%B8%AA%E5%85%83%E7%B4%A0%E7%9A%84%E4%BB%BB%E5%8A%A1%E6%89%A7%E8%A1%8C\"><\/span>4.\u624b\u52a8\u5730\u89e6\u53d1\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u6267\u884c<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<p>\u5728\u4e0a\u9762\u7684\u4ee3\u7801\u4e2d\u6709\u8fd9\u6837\u4e00\u884c\u4ee3\u7801\uff1a<\/p>\n<pre><code class=\"language-java\">WriteLogQueueTaskHelper.getInstance().next();<\/code><\/pre>\n<p>\u5728\u628a\u961f\u5217\u7684\u67d0\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u5904\u7406\u5b8c\u6bd5\u540e\uff0c\u624b\u52a8\u8c03\u7528\u4e00\u4e0b\u4e0a\u9762\u7684\u65b9\u6cd5\u4ee5\u89e6\u53d1\u961f\u5217\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684\u4efb\u52a1\u7684\u6267\u884c\u3002<\/p>\n<h4><span class=\"ez-toc-section\" id=\"5%E5%85%A5%E5%88%97\"><\/span>5.\u5165\u5217<span class=\"ez-toc-section-end\"><\/span><\/h4>\n<p>\u5728\u6570\u636e\u63a5\u6536\u7684\u5730\u65b9\uff0c\u5c06\u6570\u636e\u5165\u5217\u3002<\/p>\n<pre><code class=\"language-java\">WriteLogQueueTaskHelper.getInstance().join(stringBuilder.toString());<\/code><\/pre>\n<h1><span class=\"ez-toc-section\" id=\"%E5%B7%A5%E5%85%B7%E7%B1%BB%E7%9A%84%E8%AE%BE%E8%AE%A1%E5%88%9D%E8%A1%B7%E4%B8%8E%E4%BD%9C%E7%94%A8\"><\/span>\u5de5\u5177\u7c7b\u7684\u8bbe\u8ba1\u521d\u8877\u4e0e\u4f5c\u7528<span class=\"ez-toc-section-end\"><\/span><\/h1>\n<p>\u5728\u5317\u4eac\u5de5\u4f5c\u7684\u65f6\u5019\uff0c\u4e00\u4e2a\u9879\u76ee\u6709\u6bb5\u7a0b\u5e8f\u7684\u903b\u8f91\u662f\u8fd9\u6837\u7684\uff1a\u8bbe\u5907\u53d1\u6765\u4e00\u4e2a\u6307\u4ee4\uff0capp\u7aef\u5c31\u6267\u884c\u76f8\u76f8\u5e94\u7684\u4efb\u52a1\u3002\u6307\u4ee4A\u5bf9\u5e94\u4efb\u52a1A\uff0c\u6307\u4ee4B\u5bf9\u5e94\u4efb\u52a1B...\u6307\u4ee4N\u5bf9\u5e94\u4efb\u52a1N\u3002\u6b63\u5e38\u7684\u5904\u7406\u6d41\u7a0b\u5e94\u8be5\u662f<strong>\u6307\u4ee4A\u53d1\u9001\u8fc7\u6765\uff0c\u6267\u884c\u4efb\u52a1A\uff0c\u6267\u884c\u5b8c\u4efb\u52a1A\u4e4b\u540e\u518d\u6267\u884c\u4efb\u52a1B...\u6267\u884c\u5b8c\u4efb\u52a1N-1\u518d\u6267\u884c\u4efb\u52a1N<\/strong>\u3002\u7ecf\u8c03\u8bd5\u6211\u53d1\u73b0\u6211\u7684\u540c\u4e8b\u76f4\u63a5\u6307\u4ee4X\u53d1\u8fc7\u6765\u5c31\u6267\u884c\u4efb\u52a1X\uff0c\u4f46\u662f\u6267\u884c\u4efb\u52a1\u7684\u540c\u65f6\uff0c\u53ef\u80fd\u4e0b\u4e00\u4e2a\u6307\u4ee4\u5c31\u8fc7\u6765\uff0c\u5e76\u53d1\u7684\u6267\u884c\u591a\u4e2a\u4efb\u52a1\u8fd9\u6837\u5c31\u5bfc\u81f4\u4e86bug\u7684\u4ea7\u751f\u3002<\/p>\n<p>\u4e8e\u662f\u6211\u8bbe\u8ba1\u4e86\u8fd9\u6837\u7684\u4e00\u4e2a\u5de5\u5177\u7c7b\uff1a\u4fdd\u8bc1\u6307\u4ee4\u7684\u5904\u7406\u4f9d\u6b21\u8fdb\u884c\uff0c\u62ff\u5230\u6307\u4ee4A\u540e\u7b49\u4efb\u52a1A\u5904\u7406\u5b8c\u6bd5\uff0c\u518d\u53bb\u62ff\u6307\u4ee4B\u5904\u7406\u4efb\u52a1B...\u62ff\u5230\u6307\u4ee4N\u6267\u884c\u4efb\u52a1N\u3002<\/p>\n<p><strong>\u5de5\u5177\u7c7b\u7684\u5e94\u7528\u573a\u666f<\/strong>\uff1a<br \/>\n\u51e1\u662f\u6d89\u53ca\u5230\u7c7b\u4f3c\u4e8e\u961f\u5217\u3001\u4e25\u683c\u6709\u5e8f\u7684\u573a\u666f\uff0c\u90fd\u53ef\u4ee5\u4f7f\u7528\u6b64\u5de5\u5177\u7c7b\u3002\u5982\uff1a<br \/>\n1\uff09\u65e5\u5fd7\u6253\u5370<br \/>\n\u65e5\u5fd7\u6253\u5370\u53ef\u80fd\u65e0\u5904\u4e0d\u5728\uff0c\u4e0d\u5206\u7ebf\u7a0b\uff0c\u5f88\u5bb9\u6613\u540c\u65f6\u8bfb\u5199\u6587\u4ef6\uff0c\u9020\u6210\u5f02\u5e38\u3002\u53ef\u4ee5\u5c06\u9700\u8981\u6253\u5370\u7684\u65e5\u5fd7\u5165\u5217\uff0c\u7136\u540e\u53d6\u4e00\u6761\u65e5\u5fd7\u5199\u5165\u672c\u5730\u518d\u53d6\u4e0b\u4e00\u6761\u518d\u5199\u5165\u672c\u5730\uff0c\u4fdd\u8bc1\u6709\u6761\u4e0d\u7d0a\u3002<\/p>\n<button class=\"simplefavorite-button\" data-postid=\"4768\" data-siteid=\"1\" data-groupid=\"1\" data-favoritecount=\"0\" style=\"\">\u6536\u85cf <i class=\"sf-icon-star-empty\"><\/i><\/button>","protected":false},"excerpt":{"rendered":"<p>\u76ee\u5f55 \u6e90\u7801\u7528\u6cd51.\u5b9e\u73b0\u62bd\u8c61\u7c7b2.\u521d\u59cb\u5316\u5b9e\u73b0\u7684\u5de5\u5177\u7c7b3.\u76d1\u542c\u961f\u5217\u5143\u7d20\u4efb\u52a1\u89e6\u53d14.\u624b\u52a8\u5730\u89e6\u53d1\u4e0b\u4e00\u4e2a\u5143\u7d20\u7684 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[598],"tags":[],"_links":{"self":[{"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/posts\/4768"}],"collection":[{"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=4768"}],"version-history":[{"count":8,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/posts\/4768\/revisions"}],"predecessor-version":[{"id":7987,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=\/wp\/v2\/posts\/4768\/revisions\/7987"}],"wp:attachment":[{"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=4768"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=4768"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/xinyiworld.top\/wordpress_it\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=4768"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}