第1章編程語言虛擬機1
1.1編程語言的發(fā)展1
1.2編程語言虛擬機2
1.3開發(fā)環(huán)境5
第2章編譯流程6
2.1Python字節(jié)碼6
2.2詞法分析7
2.3文法分析10
2.4抽象語法樹13
2.4.1構建AST14
2.4.2遞歸程序的本質16
2.4.3訪問者模式21
2.4.4用Visitor重寫AST29
第3章二進制文件結構32
3.1pyc文件格式32
3.2加載CodeObject34
3.2.1準備工具36
3.2.2創(chuàng)建CodeObject41
3.3整理工程結構47
3.4執(zhí)行字節(jié)碼49
第4章實現控制流55
4.1分支結構55
4.1.1條件判斷56
4.1.2跳轉59
4.1.3True、False和None60
4.2循環(huán)結構62
4.2.1變量62
4.2.2循環(huán)內的跳轉67
第5章基本的數據類型75
5.1KlassOop二元結構75
5.2整數78
5.3字符串82
第6章函數和方法85
6.1函數85
6.1.1棧幀86
6.1.2創(chuàng)建FunctionObject89
6.1.3調用方法92
6.2變量和參數96
6.2.1LEGB規(guī)則96
6.2.2函數的參數104
6.2.3參數默認值107
6.3Native函數111
6.4方法115
第7章列表和字典122
7.1列表122
7.1.1列表的定義122
7.1.2操作列表126
7.2字典154
7.2.1字典的定義154
7.2.2操作字典157
7.3增強函數功能165
7.3.1靈活多變的函數參數165
7.3.2閉包和函數修飾器172
7.4總結179
第8章類和對象180
8.1類型對象180
8.1.1TypeObject180
8.1.2object185
8.1.3通過類型創(chuàng)建對象189
8.2自定義類型191
8.3創(chuàng)建對象196
8.4操作符重載206
8.5繼承215
第9章垃圾回收223
9.1自動內存管理223
9.1.1概念定義223
9.1.2引用計數224
9.1.3圖的知識226
9.1.4Tracing GC231
9.2復制回收234
9.2.1算法描述234
9.2.2算法實現235
9.2.3建堆237
9.2.4在堆中創(chuàng)建對象243
9.2.5垃圾回收247
第10章模塊和庫261
10.1import語句261
10.1.1ModuleObject262
10.1.2加載模塊264
10.1.3from子句266
10.2builtin模塊268
10.3加載動態(tài)庫271
10.3.1定義接口27
10.3.2實現math module277
第11章迭代281
11.1異常281
11.1.1finally子句281
11.1.2break和continue287
11.1.3Exception291
11.2自定義迭代器類306
11.3Generator309
11.3.1yield語句309
11.3.2Generator對象311
11.4總結317
附錄APython2字節(jié)碼表318
附錄B高級算法321
B.1字符串查找321
B.2排序算法325
B.2.1快速排序325
B.2.2選擇排序328
B.2.3堆排序329