This commit is contained in:
chai2010
2015-12-21 12:55:18 +08:00
parent 1d7534e3c3
commit 7ec2f7cdc1
152 changed files with 54426 additions and 8958 deletions

View File

@@ -48,7 +48,7 @@
<body>
<div class="book" data-level="11.5" data-chapter-title="剖析" data-filepath="ch11/ch11-05.md" data-basepath=".." data-revision="Wed Dec 16 2015 10:54:29 GMT+0800 (中国标准时间)">
<div class="book" data-level="11.5" data-chapter-title="剖析" data-filepath="ch11/ch11-05.md" data-basepath=".." data-revision="Mon Dec 21 2015 12:51:02 GMT+0800 (中国标准时间)">
<div class="book-summary">
@@ -146,7 +146,7 @@
<b>0.5.</b>
</a>
@@ -212,7 +212,7 @@
<b>1.3.</b>
査找重的行
査找重的行
</a>
@@ -227,7 +227,7 @@
<b>1.4.</b>
GIF動
GIF動
</a>
@@ -257,7 +257,7 @@
<b>1.6.</b>
穫取多個URL
穫取多個URL
</a>
@@ -479,7 +479,7 @@
<b>3.3.</b>
</a>
@@ -494,7 +494,7 @@
<b>3.4.</b>
爾型
爾型
</a>
@@ -544,7 +544,7 @@
<b>4.</b>
復閤數據類型
複合數據類型
</a>
@@ -857,7 +857,7 @@
<b>6.2.</b>
基於指對象的方法
基於指對象的方法
</a>
@@ -887,7 +887,7 @@
<b>6.4.</b>
方法值和方法達式
方法值和方法達式
</a>
@@ -953,7 +953,7 @@
<b>7.1.</b>
接口是
接口是
</a>
@@ -1073,7 +1073,7 @@
<b>7.9.</b>
示例: 達式求值
示例: 達式求值
</a>
@@ -1103,7 +1103,7 @@
<b>7.11.</b>
基於類型斷言識錯誤類型
基於類型斷言識錯誤類型
</a>
@@ -1214,7 +1214,7 @@
<b>8.2.</b>
示例: 併的Clock服務
示例: 併的Clock服務
</a>
@@ -1229,7 +1229,7 @@
<b>8.3.</b>
示例: 併的Echo服務
示例: 併的Echo服務
</a>
@@ -1274,7 +1274,7 @@
<b>8.6.</b>
示例: 併的Web爬蟲
示例: 併的Web爬蟲
</a>
@@ -1289,7 +1289,7 @@
<b>8.7.</b>
基於select的多路
基於select的多路
</a>
@@ -1304,7 +1304,7 @@
<b>8.8.</b>
示例: 併的字典遍歷
示例: 併的字典遍歷
</a>
@@ -1319,7 +1319,7 @@
<b>8.9.</b>
的退齣
的退齣
</a>
@@ -1354,7 +1354,7 @@
<b>9.</b>
基於共享變量的併
基於共享變量的併
</a>
@@ -1415,7 +1415,7 @@
<b>9.4.</b>
內存
內存
</a>
@@ -1460,7 +1460,7 @@
<b>9.7.</b>
示例: 併的非阻塞緩存
示例: 併的非阻塞緩存
</a>
@@ -1475,7 +1475,7 @@
<b>9.8.</b>
Goroutines和
Goroutines和
</a>
@@ -1748,7 +1748,7 @@
<b>12.1.</b>
何需要反射?
何需要反射?
</a>
@@ -1793,7 +1793,7 @@
<b>12.4.</b>
示例: 編碼S達式
示例: 編碼S達式
</a>
@@ -1823,7 +1823,7 @@
<b>12.6.</b>
示例: 解碼S達式
示例: 解碼S達式
</a>
@@ -1975,50 +1975,14 @@
</li>
<li class="chapter " data-level="14" data-path="exercise/ex.html">
<a href="../exercise/ex.html">
<i class="fa fa-check"></i>
<b>14.</b>
習題解答
</a>
<ul class="articles">
<li class="chapter " data-level="14.1" data-path="exercise/ex-ch1.html">
<a href="../exercise/ex-ch1.html">
<i class="fa fa-check"></i>
<b>14.1.</b>
第一章 入門
</a>
</li>
</ul>
</li>
<li class="chapter " data-level="15" data-path="errata.html">
<li class="chapter " data-level="14" data-path="errata.html">
<a href="../errata.html">
<i class="fa fa-check"></i>
<b>15.</b>
<b>14.</b>
勘誤
</a>
@@ -2060,24 +2024,24 @@
<section class="normal" id="section-">
<h2 id="115-&#x5256;&#x6790;">11.5. &#x5256;&#x6790;</h2>
<p>&#x6E2C;&#x91CF;&#x57FA;&#x6E96;&#x5C0D;&#x65BC;&#x8861;&#x91CF;&#x7279;&#x5B9A;&#x64CD;&#x4F5C;&#x7684;&#x6027;&#x80FD;&#x662F;&#x6709;&#x5E6B;&#x52A9;&#x7684;, &#x4F46;&#x662F;, &#x5679;&#x6211;&#x5011;&#x8996;&#x5716;&#x8B93;&#x7A0B;&#x5E8F;&#x8DD1;&#x7684;&#x66F4;&#x5FEB;&#x7684;&#x6642;&#x5019;, &#x6211;&#x5011;&#x901A;&#x5E38;&#x4F75;&#x4E0D;&#x77E5;&#x9053;&#x5F9E;&#x54EA;&#x88E1;&#x958B;&#x59CB;&#x512A;&#x5316;. &#x6BCF;&#x500B;&#x78BC;&#x8FB2;&#x90FD;&#x61C9;&#x8A72;&#x77E5;&#x9053; Donald Knuth &#x5728;1974&#x5E74;&#x7684; &#x2018;&#x2018;Structured Programming with go to Statements&#x2019;&#x2019; &#x4E0A;&#x6240;&#x8AAC;&#x7684;&#x683C;&#x8A00;. &#x96D6;&#x7136;&#x7D93;&#x5E38;&#x88AB;&#x89E3;&#x8B80;&#x7232;&#x4E0D;&#x91CD;&#x8996;&#x6027;&#x80FD;&#x7684;&#x610F;&#x601D;, &#x4F46;&#x662F;&#x5F9E;&#x539F;&#x6587;&#x6211;&#x5011;&#x53EF;&#x4EE5;&#x770B;&#x5230;&#x4E0D;&#x8855;&#x7684;&#x542B;&#x7FA9;:</p>
<p>&#x6E2C;&#x91CF;&#x57FA;&#x6E96;&#x5C0D;&#x65BC;&#x8861;&#x91CF;&#x7279;&#x5B9A;&#x64CD;&#x4F5C;&#x7684;&#x6027;&#x80FD;&#x662F;&#x6709;&#x5E6B;&#x52A9;&#x7684;, &#x4F46;&#x662F;, &#x7576;&#x6211;&#x5011;&#x8996;&#x5716;&#x8B93;&#x7A0B;&#x5E8F;&#x8DD1;&#x7684;&#x66F4;&#x5FEB;&#x7684;&#x6642;&#x5019;, &#x6211;&#x5011;&#x901A;&#x5E38;&#x4F75;&#x4E0D;&#x77E5;&#x9053;&#x5F9E;&#x54EA;&#x91CC;&#x958B;&#x59CB;&#x512A;&#x5316;. &#x6BCF;&#x500B;&#x78BC;&#x8FB2;&#x90FD;&#x61C9;&#x8A72;&#x77E5;&#x9053; Donald Knuth &#x5728;1974&#x5E74;&#x7684; &#x2018;&#x2018;Structured Programming with go to Statements&#x2019;&#x2019; &#x4E0A;&#x6240;&#x8AAC;&#x7684;&#x683C;&#x8A00;. &#x96D6;&#x7136;&#x7D93;&#x5E38;&#x88AB;&#x89E3;&#x8B80;&#x7232;&#x4E0D;&#x91CD;&#x8996;&#x6027;&#x80FD;&#x7684;&#x610F;&#x601D;, &#x4F46;&#x662F;&#x5F9E;&#x539F;&#x6587;&#x6211;&#x5011;&#x53EF;&#x4EE5;&#x770B;&#x5230;&#x4E0D;&#x540C;&#x7684;&#x542B;&#x7FA9;:</p>
<blockquote>
<p>&#x6BEB;&#x7121;&#x7591;&#x554F;, &#x6548;&#x7387;&#x6703;&#x5C0E;&#x7DFB;&#x5404;&#x7A2E;&#x6FEB;&#x7528;. &#x7A0B;&#x5E8F;&#x54E1;&#x9700;&#x8981;&#x6D6A;&#x8CBB;&#x5927;&#x91CF;&#x7684;&#x6642;&#x9593;&#x601D;&#x8003;, &#x6216;&#x8005;&#x64D4;&#x5FC3;, &#x88AB;&#x90E8;&#x5206;&#x7A0B;&#x5E8F;&#x7684;&#x901F;&#x5EA6;&#x6240;&#x4E7E;&#x64FE;, &#x5BE6;&#x969B;&#x4E0A;&#x9019;&#x4E9B;&#x5690;&#x8A66;&#x63D0;&#x6607;&#x6548;&#x7387;&#x7684;&#x884C;&#x7232;&#x53EF;&#x80FD;&#x7523;&#x751F;&#x5F37;&#x70C8;&#x7684;&#x8CA0;&#x9EAB;&#x5F71;&#x97FF;, &#x7279;&#x5F46;&#x662F;&#x5679;&#x8ABF;&#x8A66;&#x548C;&#x7DAD;&#x8B77;&#x7684;&#x6642;&#x5019;. &#x6211;&#x5011;&#x4E0D;&#x61C9;&#x8A72;&#x904E;&#x5EA6;&#x7CFE;&#x7D50;&#x65BC;&#x7D30;&#x7BC0;&#x7684;&#x512A;&#x5316;, &#x61C9;&#x8A72;&#x8AAC;&#x7D04;97%&#x7684;&#x5834;&#x666F;: &#x904E;&#x65E9;&#x7684;&#x512A;&#x5316;&#x662F;&#x842C;&#x60E1;&#x4E4B;&#x6E90;.</p>
<p>&#x6211;&#x5011;&#x5679;&#x7136;&#x4E0D;&#x61C9;&#x8A72;&#x653E;&#x68C4;&#x90A3;&#x95DC;&#x9375;&#x7684;3%&#x7684;&#x6A5F;&#x6703;. &#x4E00;&#x500B;&#x597D;&#x7684;&#x7A0B;&#x5E8F;&#x54E1;&#x4E0D;&#x6703;&#x56E0;&#x7232;&#x9019;&#x500B;&#x7406;&#x7531;&#x800C;&#x6EFF;&#x8DB3;, &#x4ED6;&#x5011;&#x6703;&#x660E;&#x667A;&#x5730;&#x89C0;&#x5BDF;&#x548C;&#x8B58;&#x5F46;&#x54EA;&#x4E9B;&#x662F;&#x95DC;&#x9375;&#x7684;&#x4EE3;&#x78BC;; &#x4F46;&#x662F;&#x96BB;&#x6709;&#x5728;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x5DF2;&#x7D93;&#x88AB;&#x78BA;&#x8A8D;&#x7684;&#x524D;&#x63D0;&#x4E0B;&#x7E94;&#x6703;&#x9032;&#x884C;&#x512A;&#x5316;. &#x5C0D;&#x65BC;&#x5224;&#x65B7;&#x54EA;&#x4E9B;&#x90E8;&#x5206;&#x662F;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x662F;&#x7D93;&#x5E38;&#x5BB9;&#x6613;&#x72AF;&#x7D93;&#x9A57;&#x6027;&#x932F;&#x8AA4;&#x7684;&#x5730;&#x65B9;, &#x56E0;&#x6B64;&#x7A0B;&#x5E8F;&#x54E1;&#x666E;&#x901A;&#x4F7F;&#x7528;&#x7684;&#x6E2C;&#x91CF;&#x5DE5;&#x5177;, &#x4F7F;&#x5F97;&#x4ED6;&#x5011;&#x7684;&#x76F4;&#x89BA;&#x5F88;&#x4E0D;&#x9760;&#x8B5C;.</p>
<p>&#x6BEB;&#x7121;&#x7591;&#x554F;, &#x6548;&#x7387;&#x6703;&#x5C0E;&#x81F4;&#x5404;&#x7A2E;&#x6FEB;&#x7528;. &#x7A0B;&#x5E8F;&#x54E1;&#x9700;&#x8981;&#x6D6A;&#x8CBB;&#x5927;&#x91CF;&#x7684;&#x6642;&#x9593;&#x601D;&#x8003;, &#x6216;&#x8005;&#x64D4;&#x5FC3;, &#x88AB;&#x90E8;&#x5206;&#x7A0B;&#x5E8F;&#x7684;&#x901F;&#x5EA6;&#x6240;&#x69A6;&#x64FE;, &#x5BE6;&#x969B;&#x4E0A;&#x9019;&#x4E9B;&#x5690;&#x8A66;&#x63D0;&#x965E;&#x6548;&#x7387;&#x7684;&#x884C;&#x7232;&#x53EF;&#x80FD;&#x7523;&#x751F;&#x5F37;&#x70C8;&#x7684;&#x8CA0;&#x9762;&#x5F71;&#x97FF;, &#x7279;&#x522B;&#x662F;&#x7576;&#x8ABF;&#x8A66;&#x548C;&#x7DAD;&#x8B77;&#x7684;&#x6642;&#x5019;. &#x6211;&#x5011;&#x4E0D;&#x61C9;&#x8A72;&#x904E;&#x5EA6;&#x7CFE;&#x7D50;&#x65BC;&#x7D30;&#x7BC0;&#x7684;&#x512A;&#x5316;, &#x61C9;&#x8A72;&#x8AAC;&#x7D04;97%&#x7684;&#x5834;&#x666F;: &#x904E;&#x65E9;&#x7684;&#x512A;&#x5316;&#x662F;&#x842C;&#x60E1;&#x4E4B;&#x6E90;.</p>
<p>&#x6211;&#x5011;&#x7576;&#x7136;&#x4E0D;&#x61C9;&#x8A72;&#x653E;&#x68C4;&#x90A3;&#x95DC;&#x9375;&#x7684;3%&#x7684;&#x6A5F;&#x6703;. &#x4E00;&#x500B;&#x597D;&#x7684;&#x7A0B;&#x5E8F;&#x54E1;&#x4E0D;&#x6703;&#x56E0;&#x7232;&#x9019;&#x500B;&#x7406;&#x7531;&#x800C;&#x6EFF;&#x8DB3;, &#x4ED6;&#x5011;&#x6703;&#x660E;&#x667A;&#x5730;&#x89C0;&#x5BDF;&#x548C;&#x8B58;&#x522B;&#x54EA;&#x4E9B;&#x662F;&#x95DC;&#x9375;&#x7684;&#x4EE3;&#x78BC;; &#x4F46;&#x662F;&#x96BB;&#x6709;&#x5728;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x5DF2;&#x7D93;&#x88AB;&#x78BA;&#x8A8D;&#x7684;&#x524D;&#x63D0;&#x4E0B;&#x7E94;&#x6703;&#x9032;&#x884C;&#x512A;&#x5316;. &#x5C0D;&#x65BC;&#x5224;&#x65B7;&#x54EA;&#x4E9B;&#x90E8;&#x5206;&#x662F;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x662F;&#x7D93;&#x5E38;&#x5BB9;&#x6613;&#x72AF;&#x7D93;&#x9A57;&#x6027;&#x932F;&#x8AA4;&#x7684;&#x5730;&#x65B9;, &#x56E0;&#x6B64;&#x7A0B;&#x5E8F;&#x54E1;&#x666E;&#x901A;&#x4F7F;&#x7528;&#x7684;&#x6E2C;&#x91CF;&#x5DE5;&#x5177;, &#x4F7F;&#x5F97;&#x4ED6;&#x5011;&#x7684;&#x76F4;&#x89BA;&#x5F88;&#x4E0D;&#x9760;&#x8B5C;.</p>
</blockquote>
<p>&#x5679;&#x6211;&#x5011;&#x60F3;&#x4ED4;&#x7D30;&#x89C0;&#x5BDF;&#x6211;&#x5011;&#x7A0B;&#x5E8F;&#x7684;&#x904B;&#x884C;&#x901F;&#x5EA6;&#x7684;&#x6642;&#x5019;, &#x6700;&#x597D;&#x7684;&#x6280;&#x8853;&#x662F;&#x5982;&#x4F55;&#x8B58;&#x5F46;&#x95DC;&#x9375;&#x4EE3;&#x78BC;. &#x81EA;&#x52D5;&#x5316;&#x7684;&#x5256;&#x6790;&#x6280;&#x8853;&#x662F;&#x57FA;&#x65BC;&#x7A0B;&#x5E8F;&#x57F7;&#x884C;&#x671F;&#x9593;&#x4E00;&#x4E9B;&#x62BD;&#x6A23;&#x6578;&#x64DA;, &#x7136;&#x5F8C;&#x63A8;&#x65B7;&#x5F8C;&#x9EAB;&#x7684;&#x57F7;&#x884C;&#x72C0;&#x614B;; &#x6700;&#x7D42;&#x7523;&#x751F;&#x4E00;&#x500B;&#x904B;&#x884C;&#x6642;&#x9593;&#x7684;&#x7D71;&#x8A08;&#x6578;&#x64DA;&#x6587;&#x4EF6;.</p>
<p>Go&#x8A9E;&#x8A00;&#x652F;&#x6301;&#x591A;&#x7A2E;&#x985E;&#x578B;&#x7684;&#x5256;&#x6790;&#x6027;&#x80FD;&#x5206;&#x6790;, &#x6BCF;&#x4E00;&#x7A2E;&#x95DC;&#x8A3B;&#x4E0D;&#x8855;&#x7684;&#x65B9;&#x9EAB;, &#x4F46;&#x5B83;&#x5011;&#x90FD;&#x6D89;&#x53CA;&#x5230;&#x6BCF;&#x500B;&#x5BC0;&#x6A23;&#x8A18;&#x5F54;&#x7684;&#x611F;&#x8208;&#x8DA3;&#x7684;&#x4E00;&#x7E6B;&#x5217;&#x4E8B;&#x4EF6;&#x6D88;&#x606F;, &#x6BCF;&#x500B;&#x4E8B;&#x4EF6;&#x90FD;&#x5305;&#x542B;&#x51FD;&#x6578;&#x8ABF;&#x7528;&#x6642;&#x51FD;&#x6578;&#x8ABF;&#x7528;&#x5806;&#x68E7;&#x7684;&#x4FE1;&#x606F;. &#x5167;&#x5EFA;&#x7684; <code>go test</code> &#x5DE5;&#x5177;&#x5C0D;&#x5E7E;&#x7A2E;&#x5206;&#x6790;&#x65B9;&#x5F0F;&#x90FD;&#x63D0;&#x4F9B;&#x4E86;&#x652F;&#x6301;.</p>
<p>CPU&#x5206;&#x6790;&#x6587;&#x4EF6;&#x6A19;&#x8B58;&#x4E86;&#x51FD;&#x6578;&#x57F7;&#x884C;&#x6642;&#x6240;&#x9700;&#x8981;&#x7684;CPU&#x6642;&#x9593;. &#x5679;&#x524D;&#x904B;&#x884C;&#x7684;&#x7E6B;&#x7D71;&#x7DDA;&#x7A0B;&#x5728;&#x6BCF;&#x9694;&#x5E7E;&#x6BEB;&#x79D2;&#x90FD;&#x6703;&#x9047;&#x5230;&#x64CD;&#x4F5C;&#x7E6B;&#x7D71;&#x7684;&#x4E2D;&#x65B7;&#x4E8B;&#x4EF6;, &#x6BCF;&#x6B21;&#x4E2D;&#x65B7;&#x6642;&#x90FD;&#x6703;&#x8A18;&#x5F54;&#x4E00;&#x500B;&#x5206;&#x6790;&#x6587;&#x4EF6;&#x7136;&#x5F8C;&#x6062;&#x5FA9;&#x6B63;&#x5E38;&#x7684;&#x904B;&#x884C;.</p>
<p>&#x5806;&#x5206;&#x6790;&#x5247;&#x8A18;&#x5F54;&#x4E86;&#x7A0B;&#x5E8F;&#x7684;&#x5167;&#x5B58;&#x4F7F;&#x7528;&#x60C5;&#x6CC1;. &#x6BCF;&#x500B;&#x5167;&#x5B58;&#x5206;&#x914D;&#x64CD;&#x4F5C;&#x90FD;&#x6703;&#x89F8;&#x767C;&#x5167;&#x90E8;&#x5E73;&#x5747;&#x5167;&#x5B58;&#x5206;&#x914D;&#x4F8B;&#x7A0B;, &#x6BCF;&#x500B; 512KB &#x7684;&#x5167;&#x5B58;&#x7533;&#x8ACB;&#x90FD;&#x6703;&#x89F8;&#x767C;&#x4E00;&#x500B;&#x4E8B;&#x4EF6;.</p>
<p>&#x963B;&#x585E;&#x5206;&#x6790;&#x5247;&#x8A18;&#x5F54;&#x4E86;goroutine&#x6700;&#x5927;&#x7684;&#x963B;&#x585E;&#x64CD;&#x4F5C;, &#x4F8B;&#x5982;&#x7E6B;&#x7D71;&#x8ABF;&#x7528;, &#x7BA1;&#x9053;&#x767C;&#x9001;&#x548C;&#x63A5;&#x6536;, &#x9084;&#x6709;&#x7A6B;&#x53D6;&#x9396;&#x7B49;. &#x5206;&#x6790;&#x5EAB;&#x6703;&#x8A18;&#x5F54;&#x6BCF;&#x500B;goroutine&#x88AB;&#x963B;&#x585E;&#x6642;&#x7684;&#x76F8;&#x95DC;&#x64CD;&#x4F5C;.</p>
<p>&#x5728;&#x6E2C;&#x8A66;&#x74B0;&#x5883;&#x4E0B;&#x96BB;&#x9700;&#x8981;&#x4E00;&#x500B;&#x6A19;&#x8A8C;&#x8518;&#x6578;&#x5C31;&#x53EF;&#x4EE5;&#x751F;&#x6210;&#x5404;&#x7A2E;&#x5206;&#x6790;&#x6587;&#x4EF6;. &#x5679;&#x4E00;&#x6B21;&#x4F7F;&#x7528;&#x591A;&#x500B;&#x6A19;&#x8A8C;&#x8518;&#x6578;&#x6642;&#x9700;&#x8981;&#x5679;&#x5FC3;, &#x56E0;&#x7232;&#x5206;&#x6790;&#x64CD;&#x4F5C;&#x672C;&#x8EAB;&#x4E5F;&#x53EF;&#x80FD;&#x6703;&#x5F71;&#x50CF;&#x7A0B;&#x5E8F;&#x7684;&#x904B;&#x884C;.</p>
<p>&#x7576;&#x6211;&#x5011;&#x60F3;&#x4ED4;&#x7D30;&#x89C0;&#x5BDF;&#x6211;&#x5011;&#x7A0B;&#x5E8F;&#x7684;&#x904B;&#x884C;&#x901F;&#x5EA6;&#x7684;&#x6642;&#x5019;, &#x6700;&#x597D;&#x7684;&#x6280;&#x8853;&#x662F;&#x5982;&#x4F55;&#x8B58;&#x522B;&#x95DC;&#x9375;&#x4EE3;&#x78BC;. &#x81EA;&#x52D5;&#x5316;&#x7684;&#x5256;&#x6790;&#x6280;&#x8853;&#x662F;&#x57FA;&#x65BC;&#x7A0B;&#x5E8F;&#x57F7;&#x884C;&#x671F;&#x9593;&#x4E00;&#x4E9B;&#x62BD;&#x6A23;&#x6578;&#x64DA;, &#x7136;&#x5F8C;&#x63A8;&#x65B7;&#x5F8C;&#x9762;&#x7684;&#x57F7;&#x884C;&#x72C0;&#x614B;; &#x6700;&#x7D42;&#x7523;&#x751F;&#x4E00;&#x500B;&#x904B;&#x884C;&#x6642;&#x9593;&#x7684;&#x7D71;&#x8A08;&#x6578;&#x64DA;&#x6587;&#x4EF6;.</p>
<p>Go&#x8A9E;&#x8A00;&#x652F;&#x6301;&#x591A;&#x7A2E;&#x985E;&#x578B;&#x7684;&#x5256;&#x6790;&#x6027;&#x80FD;&#x5206;&#x6790;, &#x6BCF;&#x4E00;&#x7A2E;&#x95DC;&#x8A3B;&#x4E0D;&#x540C;&#x7684;&#x65B9;&#x9762;, &#x4F46;&#x5B83;&#x5011;&#x90FD;&#x6D89;&#x53CA;&#x5230;&#x6BCF;&#x500B;&#x91C7;&#x6A23;&#x8A18;&#x9332;&#x7684;&#x611F;&#x8208;&#x8DA3;&#x7684;&#x4E00;&#x7E6B;&#x5217;&#x4E8B;&#x4EF6;&#x6D88;&#x606F;, &#x6BCF;&#x500B;&#x4E8B;&#x4EF6;&#x90FD;&#x5305;&#x542B;&#x51FD;&#x6578;&#x8ABF;&#x7528;&#x6642;&#x51FD;&#x6578;&#x8ABF;&#x7528;&#x5806;&#x68E7;&#x7684;&#x4FE1;&#x606F;. &#x5167;&#x5EFA;&#x7684; <code>go test</code> &#x5DE5;&#x5177;&#x5C0D;&#x5E7E;&#x7A2E;&#x5206;&#x6790;&#x65B9;&#x5F0F;&#x90FD;&#x63D0;&#x4F9B;&#x4E86;&#x652F;&#x6301;.</p>
<p>CPU&#x5206;&#x6790;&#x6587;&#x4EF6;&#x6A19;&#x8B58;&#x4E86;&#x51FD;&#x6578;&#x57F7;&#x884C;&#x6642;&#x6240;&#x9700;&#x8981;&#x7684;CPU&#x6642;&#x9593;. &#x7576;&#x524D;&#x904B;&#x884C;&#x7684;&#x7E6B;&#x7D71;&#x7DDA;&#x7A0B;&#x5728;&#x6BCF;&#x9694;&#x5E7E;&#x6BEB;&#x79D2;&#x90FD;&#x6703;&#x9047;&#x5230;&#x64CD;&#x4F5C;&#x7E6B;&#x7D71;&#x7684;&#x4E2D;&#x65B7;&#x4E8B;&#x4EF6;, &#x6BCF;&#x6B21;&#x4E2D;&#x65B7;&#x6642;&#x90FD;&#x6703;&#x8A18;&#x9332;&#x4E00;&#x500B;&#x5206;&#x6790;&#x6587;&#x4EF6;&#x7136;&#x5F8C;&#x6062;&#x8907;&#x6B63;&#x5E38;&#x7684;&#x904B;&#x884C;.</p>
<p>&#x5806;&#x5206;&#x6790;&#x5247;&#x8A18;&#x9332;&#x4E86;&#x7A0B;&#x5E8F;&#x7684;&#x5167;&#x5B58;&#x4F7F;&#x7528;&#x60C5;&#x6CC1;. &#x6BCF;&#x500B;&#x5167;&#x5B58;&#x5206;&#x914D;&#x64CD;&#x4F5C;&#x90FD;&#x6703;&#x89F8;&#x767C;&#x5167;&#x90E8;&#x5E73;&#x5747;&#x5167;&#x5B58;&#x5206;&#x914D;&#x4F8B;&#x7A0B;, &#x6BCF;&#x500B; 512KB &#x7684;&#x5167;&#x5B58;&#x7533;&#x8ACB;&#x90FD;&#x6703;&#x89F8;&#x767C;&#x4E00;&#x500B;&#x4E8B;&#x4EF6;.</p>
<p>&#x963B;&#x585E;&#x5206;&#x6790;&#x5247;&#x8A18;&#x9332;&#x4E86;goroutine&#x6700;&#x5927;&#x7684;&#x963B;&#x585E;&#x64CD;&#x4F5C;, &#x4F8B;&#x5982;&#x7E6B;&#x7D71;&#x8ABF;&#x7528;, &#x7BA1;&#x9053;&#x767C;&#x9001;&#x548C;&#x63A5;&#x6536;, &#x9084;&#x6709;&#x7A6B;&#x53D6;&#x9396;&#x7B49;. &#x5206;&#x6790;&#x5EAB;&#x6703;&#x8A18;&#x9332;&#x6BCF;&#x500B;goroutine&#x88AB;&#x963B;&#x585E;&#x6642;&#x7684;&#x76F8;&#x95DC;&#x64CD;&#x4F5C;.</p>
<p>&#x5728;&#x6E2C;&#x8A66;&#x74B0;&#x5883;&#x4E0B;&#x96BB;&#x9700;&#x8981;&#x4E00;&#x500B;&#x6A19;&#x8A8C;&#x53C3;&#x6578;&#x5C31;&#x53EF;&#x4EE5;&#x751F;&#x6210;&#x5404;&#x7A2E;&#x5206;&#x6790;&#x6587;&#x4EF6;. &#x7576;&#x4E00;&#x6B21;&#x4F7F;&#x7528;&#x591A;&#x500B;&#x6A19;&#x8A8C;&#x53C3;&#x6578;&#x6642;&#x9700;&#x8981;&#x7576;&#x5FC3;, &#x56E0;&#x7232;&#x5206;&#x6790;&#x64CD;&#x4F5C;&#x672C;&#x8EAB;&#x4E5F;&#x53EF;&#x80FD;&#x6703;&#x5F71;&#x50CF;&#x7A0B;&#x5E8F;&#x7684;&#x904B;&#x884C;.</p>
<pre><code>$ go test -cpuprofile=cpu.out
$ go test -blockprofile=block.out
$ go test -memprofile=mem.out
</code></pre><p>&#x5C0D;&#x65BC;&#x4E00;&#x4E9B;&#x975E;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;&#x4E5F;&#x5F88;&#x5BB9;&#x6613;&#x652F;&#x6301;&#x5206;&#x6790;&#x7684;&#x7279;&#x6027;, &#x5177;&#x9AD4;&#x7684;&#x5BE6;&#x73FE;&#x65B9;&#x5F0F;&#x548C;&#x7A0B;&#x5E8F;&#x662F;&#x77ED;&#x6642;&#x9593;&#x904B;&#x884C;&#x7684;&#x5C0F;&#x5DE5;&#x5177;&#x9084;&#x662F;&#x9577;&#x6642;&#x9593;&#x904B;&#x884C;&#x7684;&#x670D;&#x52D9;&#x6703;&#x6709;&#x5F88;&#x5927;&#x4E0D;&#x8855;, &#x56E0;&#x6B64;Go&#x7684;runtim&#x904B;&#x884C;&#x6642;&#x5305;&#x63D0;&#x4F9B;&#x4E86;&#x7A0B;&#x5E8F;&#x904B;&#x884C;&#x6642;&#x63A7;&#x88FD;&#x5206;&#x6790;&#x7279;&#x6027;&#x7684;&#x63A5;&#x53E3;.</p>
<p>&#x4E00;&#x65E6;&#x6211;&#x5011;&#x5DF2;&#x7D93;&#x6536;&#x96C6;&#x5230;&#x4E86;&#x7528;&#x65BC;&#x5206;&#x6790;&#x7684;&#x5BC0;&#x6A23;&#x6578;&#x64DA;, &#x6211;&#x5011;&#x5C31;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; pprof &#x64DA;&#x4F86;&#x5206;&#x6790;&#x9019;&#x4E9B;&#x6578;&#x64DA;. &#x9019;&#x662F;Go&#x5DE5;&#x5177;&#x7BB1;&#x81EA;&#x5E36;&#x7684;&#x4E00;&#x500B;&#x5DE5;&#x5177;, &#x4F46;&#x4F75;&#x4E0D;&#x662F;&#x4E00;&#x500B;&#x65E5;&#x5E38;&#x5DE5;&#x5177;, &#x5B83;&#x5C0D;&#x61C9; <code>go tool pprof</code> &#x547D;&#x4EE4;. &#x8A72;&#x547D;&#x4EE4;&#x6709;&#x8A31;&#x591A;&#x7279;&#x6027;&#x548C;&#x9078;&#x9805;, &#x4F46;&#x662F;&#x6700;&#x91CD;&#x8981;&#x7684;&#x6709;&#x5169;&#x500B;, &#x5C31;&#x662F;&#x751F;&#x6210;&#x9019;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x7684;&#x53EF;&#x57F7;&#x884C;&#x7A0B;&#x5E8F;&#x548C;&#x5C0D;&#x65BC;&#x7684;&#x5206;&#x6790;&#x65E5;&#x8A8C;&#x6587;&#x4EF6;.</p>
<p>&#x7232;&#x4E86;&#x63D0;&#x9AD8;&#x5206;&#x6790;&#x6548;&#x7387;&#x548C;&#x6E1B;&#x5C11;&#x7A7A;&#x9593;, &#x5206;&#x6790;&#x65E5;&#x8A8C;&#x672C;&#x8EAB;&#x4F75;&#x4E0D;&#x5305;&#x542B;&#x51FD;&#x6578;&#x7684;&#x540D;&#x5B57;; &#x5B83;&#x96BB;&#x5305;&#x542B;&#x51FD;&#x6578;&#x5C0D;&#x61C9;&#x7684;&#x5730;&#x5740;. &#x4E5F;&#x5C31;&#x662F;&#x8AAC;pprof&#x9700;&#x8981;&#x548C;&#x5206;&#x6790;&#x65E5;&#x8A8C;&#x5C0D;&#x65BC;&#x7684;&#x53EF;&#x57F7;&#x884C;&#x7A0B;&#x5E8F;. &#x96D6;&#x7136; <code>go test</code> &#x547D;&#x4EE4;&#x901A;&#x5E38;&#x6703;&#x4E1F;&#x68C4;&#x81E8;&#x6642;&#x7528;&#x7684;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;, &#x4F46;&#x662F;&#x5728;&#x5553;&#x7528;&#x5206;&#x6790;&#x7684;&#x6642;&#x5019;&#x6703;&#x5C07;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;&#x4FDD;&#x5B58;&#x7232; foo.test &#x6587;&#x4EF6;, &#x5176;&#x4E2D; foo &#x90E8;&#x5206;&#x5C0D;&#x65BC;&#x6E2C;&#x8A66;&#x5305;&#x7684;&#x540D;&#x5B57;.</p>
<p>&#x4E0B;&#x9EAB;&#x7684;&#x547D;&#x4EE4;&#x6F14;&#x793A;&#x4E86;&#x5982;&#x4F55;&#x751F;&#x6210;&#x4E00;&#x500B;CPU&#x5206;&#x6790;&#x6587;&#x4EF6;. &#x6211;&#x5011;&#x9078;&#x64C7; <code>net/http</code> &#x5305;&#x7684;&#x4E00;&#x500B;&#x57FA;&#x6E96;&#x6E2C;&#x8A66;. &#x901A;&#x5E38;&#x662F;&#x57FA;&#x65BC;&#x4E00;&#x500B;&#x5DF2;&#x7D93;&#x78BA;&#x5B9A;&#x4E86;&#x662F;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x7684;&#x90E8;&#x5206;&#x9032;&#x884C;&#x57FA;&#x6E96;&#x6E2C;&#x8A66;. &#x57FA;&#x6E96;&#x6E2C;&#x8A66;&#x6703;&#x9ED8;&#x8A8D;&#x5305;&#x542B;&#x55AE;&#x5143;&#x6E2C;&#x8A66;, &#x9019;&#x88E1;&#x6211;&#x5011;&#x7528; -run=NONE &#x7981;&#x6B62;&#x55AE;&#x5143;&#x6E2C;&#x8A66;.</p>
</code></pre><p>&#x5C0D;&#x65BC;&#x4E00;&#x4E9B;&#x975E;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;&#x4E5F;&#x5F88;&#x5BB9;&#x6613;&#x652F;&#x6301;&#x5206;&#x6790;&#x7684;&#x7279;&#x6027;, &#x5177;&#x9AD4;&#x7684;&#x5BE6;&#x73FE;&#x65B9;&#x5F0F;&#x548C;&#x7A0B;&#x5E8F;&#x662F;&#x77ED;&#x6642;&#x9593;&#x904B;&#x884C;&#x7684;&#x5C0F;&#x5DE5;&#x5177;&#x9084;&#x662F;&#x9577;&#x6642;&#x9593;&#x904B;&#x884C;&#x7684;&#x670D;&#x52D9;&#x6703;&#x6709;&#x5F88;&#x5927;&#x4E0D;&#x540C;, &#x56E0;&#x6B64;Go&#x7684;runtim&#x904B;&#x884C;&#x6642;&#x5305;&#x63D0;&#x4F9B;&#x4E86;&#x7A0B;&#x5E8F;&#x904B;&#x884C;&#x6642;&#x63A7;&#x88FD;&#x5206;&#x6790;&#x7279;&#x6027;&#x7684;&#x63A5;&#x53E3;.</p>
<p>&#x4E00;&#x65E6;&#x6211;&#x5011;&#x5DF2;&#x7D93;&#x6536;&#x96C6;&#x5230;&#x4E86;&#x7528;&#x65BC;&#x5206;&#x6790;&#x7684;&#x91C7;&#x6A23;&#x6578;&#x64DA;, &#x6211;&#x5011;&#x5C31;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; pprof &#x64DA;&#x4F86;&#x5206;&#x6790;&#x9019;&#x4E9B;&#x6578;&#x64DA;. &#x9019;&#x662F;Go&#x5DE5;&#x5177;&#x7BB1;&#x81EA;&#x5E36;&#x7684;&#x4E00;&#x500B;&#x5DE5;&#x5177;, &#x4F46;&#x4F75;&#x4E0D;&#x662F;&#x4E00;&#x500B;&#x65E5;&#x5E38;&#x5DE5;&#x5177;, &#x5B83;&#x5C0D;&#x61C9; <code>go tool pprof</code> &#x547D;&#x4EE4;. &#x8A72;&#x547D;&#x4EE4;&#x6709;&#x8A31;&#x591A;&#x7279;&#x6027;&#x548C;&#x9078;&#x9805;, &#x4F46;&#x662F;&#x6700;&#x91CD;&#x8981;&#x7684;&#x6709;&#x5169;&#x500B;, &#x5C31;&#x662F;&#x751F;&#x6210;&#x9019;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x7684;&#x53EF;&#x57F7;&#x884C;&#x7A0B;&#x5E8F;&#x548C;&#x5C0D;&#x65BC;&#x7684;&#x5206;&#x6790;&#x65E5;&#x8A8C;&#x6587;&#x4EF6;.</p>
<p>&#x7232;&#x4E86;&#x63D0;&#x9AD8;&#x5206;&#x6790;&#x6548;&#x7387;&#x548C;&#x6E1B;&#x5C11;&#x7A7A;&#x9593;, &#x5206;&#x6790;&#x65E5;&#x8A8C;&#x672C;&#x8EAB;&#x4F75;&#x4E0D;&#x5305;&#x542B;&#x51FD;&#x6578;&#x7684;&#x540D;&#x5B57;; &#x5B83;&#x96BB;&#x5305;&#x542B;&#x51FD;&#x6578;&#x5C0D;&#x61C9;&#x7684;&#x5730;&#x5740;. &#x4E5F;&#x5C31;&#x662F;&#x8AAC;pprof&#x9700;&#x8981;&#x548C;&#x5206;&#x6790;&#x65E5;&#x8A8C;&#x5C0D;&#x65BC;&#x7684;&#x53EF;&#x57F7;&#x884C;&#x7A0B;&#x5E8F;. &#x96D6;&#x7136; <code>go test</code> &#x547D;&#x4EE4;&#x901A;&#x5E38;&#x6703;&#x4E1F;&#x68C4;&#x81E8;&#x6642;&#x7528;&#x7684;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;, &#x4F46;&#x662F;&#x5728;&#x555F;&#x7528;&#x5206;&#x6790;&#x7684;&#x6642;&#x5019;&#x6703;&#x5C07;&#x6E2C;&#x8A66;&#x7A0B;&#x5E8F;&#x4FDD;&#x5B58;&#x7232; foo.test &#x6587;&#x4EF6;, &#x5176;&#x4E2D; foo &#x90E8;&#x5206;&#x5C0D;&#x65BC;&#x6E2C;&#x8A66;&#x5305;&#x7684;&#x540D;&#x5B57;.</p>
<p>&#x4E0B;&#x9762;&#x7684;&#x547D;&#x4EE4;&#x6F14;&#x793A;&#x4E86;&#x5982;&#x4F55;&#x751F;&#x6210;&#x4E00;&#x500B;CPU&#x5206;&#x6790;&#x6587;&#x4EF6;. &#x6211;&#x5011;&#x9078;&#x64C7; <code>net/http</code> &#x5305;&#x7684;&#x4E00;&#x500B;&#x57FA;&#x6E96;&#x6E2C;&#x8A66;. &#x901A;&#x5E38;&#x662F;&#x57FA;&#x65BC;&#x4E00;&#x500B;&#x5DF2;&#x7D93;&#x78BA;&#x5B9A;&#x4E86;&#x662F;&#x95DC;&#x9375;&#x4EE3;&#x78BC;&#x7684;&#x90E8;&#x5206;&#x9032;&#x884C;&#x57FA;&#x6E96;&#x6E2C;&#x8A66;. &#x57FA;&#x6E96;&#x6E2C;&#x8A66;&#x6703;&#x9ED8;&#x8A8D;&#x5305;&#x542B;&#x55AE;&#x5143;&#x6E2C;&#x8A66;, &#x9019;&#x91CC;&#x6211;&#x5011;&#x7528; -run=NONE &#x7981;&#x6B62;&#x55AE;&#x5143;&#x6E2C;&#x8A66;.</p>
<pre><code>$ go test -run=NONE -bench=ClientServerParallelTLS64 \
-cpuprofile=cpu.log net/http
PASS
@@ -2100,9 +2064,9 @@ Showing top 10 nodes out of 166 (cum &gt;= 60ms)
60ms 1.67% 68.80% 190ms 5.29% math/big.nat.montgomery
50ms 1.39% 70.19% 50ms 1.39% crypto/elliptic.p256ReduceCarry
50ms 1.39% 71.59% 60ms 1.67% crypto/elliptic.p256Sum
</code></pre><p>&#x8518;&#x6578; <code>-text</code> &#x6A19;&#x8A8C;&#x8518;&#x6578;&#x7528;&#x65BC;&#x6307;&#x5B9A;&#x8F38;&#x9F63;&#x683C;&#x5F0F;, &#x5728;&#x9019;&#x88E1;&#x6BCF;&#x884C;&#x662F;&#x4E00;&#x500B;&#x51FD;&#x6578;, &#x6839;&#x64DA;&#x4F7F;&#x7528;CPU&#x7684;&#x6642;&#x9593;&#x4F86;&#x6392;&#x5E8F;. &#x5176;&#x4E2D; <code>-nodecount=10</code> &#x6A19;&#x8A8C;&#x8518;&#x6578;&#x9650;&#x88FD;&#x4E86;&#x96BB;&#x8F38;&#x9F63;&#x524D;10&#x884C;&#x7684;&#x7D50;&#x679C;. &#x5C0D;&#x65BC;&#x56B4;&#x91CD;&#x7684;&#x6027;&#x80FD;&#x554F;&#x984C;, &#x9019;&#x500B;&#x6587;&#x672C;&#x683C;&#x5F0F;&#x57FA;&#x672C;&#x53EF;&#x4EE5;&#x5E6B;&#x52A9;&#x67FB;&#x660E;&#x539F;&#x56E0;&#x4E86;.</p>
<p>&#x9019;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x544A;&#x8A34;&#x6211;&#x5011;, HTTPS&#x57FA;&#x6E96;&#x6E2C;&#x8A66;&#x4E2D; <code>crypto/elliptic.p256ReduceDegree</code> &#x51FD;&#x6578;&#x4F54;&#x7528;&#x4E86;&#x5C07;&#x8FD1;&#x4E00;&#x822C;&#x7684;CPU&#x8CC7;&#x6E90;. &#x76F8;&#x6BD4;&#x4E4B;&#x4E0B;, &#x5982;&#x679C;&#x4E00;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x4E2D;&#x4E3B;&#x8981;&#x662F;runtime&#x5305;&#x7684;&#x5167;&#x5B58;&#x5206;&#x914D;&#x7684;&#x51FD;&#x6578;, &#x90A3;&#x9EBD;&#x6E1B;&#x5C11;&#x5167;&#x5B58;&#x6D88;&#x8017;&#x53EF;&#x80FD;&#x662F;&#x4E00;&#x500B;&#x503C;&#x5F97;&#x5690;&#x8A66;&#x7684;&#x512A;&#x5316;&#x7B56;&#x7565;.</p>
<p>&#x5C0D;&#x65BC;&#x4E00;&#x4E9B;&#x66F4;&#x5FAE;&#x5999;&#x7684;&#x554F;&#x984C;, &#x4F60;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x4F7F;&#x7528; pprof &#x7684;&#x5716;&#x5F62;&#x986F;&#x793A;&#x529F;&#x80FD;. &#x9019;&#x500B;&#x9700;&#x8981;&#x5B89;&#x88DD; GraphViz &#x5DE5;&#x5177;, &#x53EF;&#x4EE5;&#x5F9E; www.graphviz.org &#x4E0B;&#x8F09;. &#x8518;&#x6578; <code>-web</code> &#x7528;&#x65BC;&#x751F;&#x6210;&#x4E00;&#x500B;&#x6709;&#x66CF;&#x5716;&#x6587;&#x4EF6;, &#x5305;&#x542B;CPU&#x7684;&#x4F7F;&#x7528;&#x548C;&#x6700;&#x7279;&#x9EDE;&#x7684;&#x51FD;&#x6578;&#x7B49;&#x4FE1;&#x606F;.</p>
</code></pre><p>&#x53C3;&#x6578; <code>-text</code> &#x6A19;&#x8A8C;&#x53C3;&#x6578;&#x7528;&#x65BC;&#x6307;&#x5B9A;&#x8F38;&#x9F63;&#x683C;&#x5F0F;, &#x5728;&#x9019;&#x91CC;&#x6BCF;&#x884C;&#x662F;&#x4E00;&#x500B;&#x51FD;&#x6578;, &#x6839;&#x64DA;&#x4F7F;&#x7528;CPU&#x7684;&#x6642;&#x9593;&#x4F86;&#x6392;&#x5E8F;. &#x5176;&#x4E2D; <code>-nodecount=10</code> &#x6A19;&#x8A8C;&#x53C3;&#x6578;&#x9650;&#x88FD;&#x4E86;&#x96BB;&#x8F38;&#x9F63;&#x524D;10&#x884C;&#x7684;&#x7D50;&#x679C;. &#x5C0D;&#x65BC;&#x56B4;&#x91CD;&#x7684;&#x6027;&#x80FD;&#x554F;&#x984C;, &#x9019;&#x500B;&#x6587;&#x672C;&#x683C;&#x5F0F;&#x57FA;&#x672C;&#x53EF;&#x4EE5;&#x5E6B;&#x52A9;&#x67FB;&#x660E;&#x539F;&#x56E0;&#x4E86;.</p>
<p>&#x9019;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x544A;&#x8A34;&#x6211;&#x5011;, HTTPS&#x57FA;&#x6E96;&#x6E2C;&#x8A66;&#x4E2D; <code>crypto/elliptic.p256ReduceDegree</code> &#x51FD;&#x6578;&#x5360;&#x7528;&#x4E86;&#x5C07;&#x8FD1;&#x4E00;&#x822C;&#x7684;CPU&#x8CC7;&#x6E90;. &#x76F8;&#x6BD4;&#x4E4B;&#x4E0B;, &#x5982;&#x679C;&#x4E00;&#x500B;&#x6982;&#x8981;&#x6587;&#x4EF6;&#x4E2D;&#x4E3B;&#x8981;&#x662F;runtime&#x5305;&#x7684;&#x5167;&#x5B58;&#x5206;&#x914D;&#x7684;&#x51FD;&#x6578;, &#x90A3;&#x9EBD;&#x6E1B;&#x5C11;&#x5167;&#x5B58;&#x6D88;&#x8017;&#x53EF;&#x80FD;&#x662F;&#x4E00;&#x500B;&#x503C;&#x5F97;&#x5690;&#x8A66;&#x7684;&#x512A;&#x5316;&#x7B56;&#x7565;.</p>
<p>&#x5C0D;&#x65BC;&#x4E00;&#x4E9B;&#x66F4;&#x5FAE;&#x5999;&#x7684;&#x554F;&#x984C;, &#x4F60;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x4F7F;&#x7528; pprof &#x7684;&#x5716;&#x5F62;&#x986F;&#x793A;&#x529F;&#x80FD;. &#x9019;&#x500B;&#x9700;&#x8981;&#x5B89;&#x88DD; GraphViz &#x5DE5;&#x5177;, &#x53EF;&#x4EE5;&#x5F9E; www.graphviz.org &#x4E0B;&#x8F09;. &#x53C3;&#x6578; <code>-web</code> &#x7528;&#x65BC;&#x751F;&#x6210;&#x4E00;&#x500B;&#x6709;&#x5411;&#x5716;&#x6587;&#x4EF6;, &#x5305;&#x542B;CPU&#x7684;&#x4F7F;&#x7528;&#x548C;&#x6700;&#x7279;&#x9EDE;&#x7684;&#x51FD;&#x6578;&#x7B49;&#x4FE1;&#x606F;.</p>
<p>&#x9019;&#x4E00;&#x7BC0;&#x6211;&#x5011;&#x96BB;&#x662F;&#x7C21;&#x55AE;&#x770B;&#x4E86;&#x4E0B;Go&#x8A9E;&#x8A00;&#x7684;&#x5206;&#x6790;&#x64DA;&#x5DE5;&#x5177;. &#x5982;&#x679C;&#x60F3;&#x4E86;&#x89E3;&#x66F4;&#x591A;, &#x53EF;&#x4EE5;&#x95B2;&#x8B80; Go&#x5B98;&#x65B9;&#x535A;&#x5BA2;&#x7684; &#x2018;&#x2018;Pro&#xFB01;ling Go Programs&#x2019;&#x2019; &#x4E00;&#x6587;.</p>