C++程序設計語言(第4部分:標准庫)(原書第4版)

C++程序設計語言(第4部分:標准庫)(原書第4版)
定價:534
NT $ 465
 

內容簡介

是C++領域最經典的參考書,介紹了C++11的各項新特性和新功能。全書共分四部分。第一部分(第1~5章)是引言,包括C++的背景知識,C++語言及其標准庫的簡要介紹;第二部分(第6~15章)介紹C++的內置類型和基本特性,以及如何用它們構造程序;第三部分(第16~29章)介紹C++的抽象機制及如何用這些機制編寫面向對象程序和泛型程序;第四部分(第30~44章)概述標准庫並討論一些兼容性問題。由於篇幅問題,原書中文版分兩冊出版,分別對應原書的第一至三部分和第四部分。這一冊為第四部分。
 

目錄

The C++ Programming Language, Fourth Edition
出版者的話
譯者序
前言
第3版前言
第2版前言
第1版前言

第四部分 標准庫

第30章 標准庫概覽 2
30.1 引言 2
30.1.1 標准庫設施 2
30.1.2 設計約束 4
30.1.3 描述風格 4
30.2 頭文件 5
30.3 語言支持 9
30.3.1 initializer_list支持 9
30.3.2 范圍for支持 10
30.4 錯誤處理 10
30.4.1 異常 10
30.4.2 斷言 14
30.4.3 system_error 15
30.5 建議 23

第31章 STL容器 24
31.1 引言 24
31.2 容器概覽 24
31.2.1 容器表示 27
31.2.2 對元素的要求 28
31.3 操作概覽 30
31.3.1 成員類型 32
31.3.2 構造函數、析構函數和賦值操作 33
31.3.3 大小和容量 34
31.3.4 迭代器 35
31.3.5 元素訪問 36
31.3.6 棧操作 36
31.3.7 列表操作 37
31.3.8 其他操作 38
31.4 容器 38
31.4.1 vector 38
31.4.2 鏈表 42
31.4.3 關聯容器 44
31.5 容器適配器 53
31.5.1 stack 54
31.5.2 queue 55
31.5.3 priority_queue 56
31.6 建議 57

第32章 STL算法 59
32.1 引言 59
32.2 算法 59
32.2.1 序列 60
32.3 策略實參 61
32.3.1 復雜性 62
32.4 不修改序列的算法 63
32.4.1 for_each() 63
32.4.2 序列謂詞 63
32.4.3 count() 63
32.4.4 find() 64
32.4.5 equal()和mismatch() 64
32.4.6 search() 65
32.5 修改序列的算法 66
32.5.1 copy() 66
32.5.2 unique() 67
32.5.3 remove()和replace() 68
32.5.4 rotate()、random_shuffle()和partition() 69
32.5.5 排列 70
32.5.6 fill() 70
32.5.7 swap() 71
32.6 排序和搜索 71
32.6.1 二分搜索 74
32.6.2 merge() 75
32.6.3 集合算法 75
32.6.4 堆 76
32.6.5 lexicographical_compare() 77
32.7 最大值和最小值 78
32.8 建議 79

第33章 STL迭代器 80
33.1 引言 80
33.1.1 迭代器模型 80
33.1.2 迭代器類別 81
33.1.3 迭代器萃取 82
33.1.4 迭代器操作 85
33.2 迭代器適配器 85
33.2.1 反向迭代器 86
33.2.2 插入迭代器 88
33.2.3 移動迭代器 89
33.3 范圍訪問函數 89
33.4 函數對象 90
33.5 函數適配器 91
33.5.1 bind() 92
33.5.2 mem_fn() 93
33.5.3 function 93
33.6 建議 95

第34章 內存和資源 96
34.1 引言 96
34.2 「擬容器」 96
34.2.1 array 97
34.2.2 bitset 99
34.2.3 vector<bool> 103
34.2.4 元組 104
34.3 資源管理指針 107
34.3.1 unique_ptr 108
34.3.2 shared_ptr 111
34.3.3 weak_ptr 113
34.4 分配器 115
34.4.1 默認分配器 116
34.4.2 分配器萃取 118
34.4.3 指針萃取 119
34.4.4 限域的分配器 119
34.5 垃圾收集接口 121
34.6 未初始化內存 123
34.6.1 臨時緩沖區 123
34.6.2 raw_storage_iterator 124
34.7 建議 125

第35章 工具 126
35.1 引言 126
35.2 時間 126
35.2.1 duration 127
35.2.2 time_point 129
35.2.3 時鍾 131
35.2.4 時間萃取 132
35.3 編譯時有理數運算 132
35.4 類型函數 134
35.4.1 類型萃取 134
35.4.2 類型生成器 138
35.5 其他工具 142
35.5.1 move()和forward() 142
35.5.2 swap() 143
35.5.3 關系運算符 143
35.5.4 比較和哈希type_info 144
35.6 建議 145

第36章 字符串 146
36.1 引言 146
36.2 字符分類 146
36.2.1 分類函數 146
36.2.2 字符萃取 147
36.3 字符串 148
36.3.1 string與C風格字符串 149
36.3.2 構造函數 151
36.3.3 基本操作 152
36.3.4 字符串I/O 153
36.3.5 數值轉換 154
36.3.6 類STL操作 155
36.3.7 find系列函數 157
36.3.8 子串 158
36.4 建議 159

第37章 正則表達式 160
37.1 正則表達式 160
37.1.1 正則表達式符號表示 161
37.2 regex 165
37.2.1 匹配結果 166
37.2.2 格式化 169
37.3 正則表達式函數 170
37.3.1 regex_match() 170
37.3.2 regex_search() 171
37.3.3 regex_replace() 172
37.4 正則表達式迭代器 173
37.4.1 regex_iterator 173
37.4.2 regex_token_iterator 175
37.5 regex_traits 176
37.6 建議 177

第38章 I/O流 178
38.1 引言 178
38.2 I/O流層次 180
38.2.1 文件流 180
38.2.2 字符串流 182
38.3 錯誤處理 183
38.4 I/O操作 184
38.4.1 輸入操作 185
38.4.2 輸出操作 187
38.4.3 操縱符 189
38.4.4 流狀態 190
38.4.5 格式化 194
38.5 流迭代器 200
38.6 緩沖 201
38.6.1 輸出流和緩沖區 204
38.6.2 輸入流和緩沖區 205
38.6.3 緩沖區迭代器 205
38.7 建議 207

第39章 區域設置 209
39.1 處理文化差異 209
39.2 類locale 211
39.2.1 命名locale 213
39.2.2 比較string 216
39.3 類facet 217
39.3.1 訪問locale中的facet 218
39.3.2 一個簡單的用戶自定義facet 218
39.3.3 locale和facet的使用 221
39.4 標准facet 221
39.4.1 string比較 223
39.4.2 數值格式化 226
39.4.3 貨幣格式化 231
39.4.4 日期和時間格式化 235
39.4.5 字符分類 238
39.4.6 字符編碼轉換 241
39.4.7 消息 244
39.5 便利接口 248
39.5.1 字符分類 248
39.5.2 字符轉換 248
39.5.3 字符串轉換 249
39.5.4 緩沖區轉換 250
39.6 建議 250

第40章 數值計算 252
40.1 引言 252
40.2 數值限制 252
40.2.1 數值限制宏 255
40.3 標准數學函數 255
40.4 復數complex 257
40.5 數值數組:valarray 258
40.5.1 構造函數和賦值操作 258
40.5.2 下標操作 260
40.5.3 運算 261
40.5.4 切片 263
40.5.5 slice_array 265
40.5.6 推廣切片 265
40.6 推廣數值算法 267
40.6.1 accumulate() 267
40.6.2 inner_product() 268
40.6.3 partial_sum()和adjacent_difference() 269
40.6.4 iota() 270
40.7 隨機數 270
40.7.1 引擎 272
40.7.2 隨機設備 274
40.7.3 分布 274
40.7.4 C風格隨機數 277
40.8 建議 278

第41章 並發 279
41.1 引言 279
41.2 內存模型 280
41.2.1 內存位置 281
41.2.2 指令重排 282
41.2.3 內存序 282
41.2.4 數據競爭 283
41.3 原子性 285
41.3.1 atomic類型 287
41.3.2 標志和柵欄 291
41.4 volatile 292
41.5 建議 292

第42章 線程和任務 293
42.1 引言 293
42.2 線程 293
42.2.1 身份 294
42.2.2 構造 295
42.2.3 析構 296
42.2.4 join() 297
42.2.5 detach() 298
42.2.6 名字空間this_thread 299
42.2.7 殺死thread 300
42.2.8 thread_local數據 300
42.3 避免數據競爭 302
42.3.1 互斥量 302
42.3.2 多重鎖 309
42.3.3 call_once() 311
42.3.4 條件變量 311
42.4 基於任務的並發 315
42.4.1 future和promise 316
42.4.2 promise 317
42.4.3 packaged_task 318
42.4.4 future 320
42.4.5 shared_future 323
42.4.6 async() 323
42.4.7 一個並行find()示例 325
42.5 建議 328

第43章 C標准庫 330
43.1 引言 330
43.2 文件 330
43.3 printf()系列函數 331
43.4 C風格字符串 334
43.5 內存 335
43.6 日期和時間 336
43.7 雜項 339
43.8 建議 340

第44章 兼容性 341
44.1 引言 341
44.2 C++11擴展 341
44.2.1 語言特性 341
44.2.2 標准庫組件 343
44.2.3 棄用特性 344
44.2.4 應對舊版本C++實現 344
44.3 C/C++兼容性 345
44.3.1 C和C++是兄弟 345
44.3.2 「靜默」差異 346
44.3.3 不兼容C++的C代碼 347
44.3.4 不兼容C的C++代碼 350
44.4 建議 351
網路書店 類別 折扣 價格
  1. 新書
    87
    $465