C++入門經(jīng)典-(第10版) 版權信息
- ISBN:9787302486763
- 條形碼:9787302486763 ; 978-7-302-48676-3
- 裝幀:一般膠版紙
- 冊數(shù):暫無
- 重量:暫無
- 所屬分類:>>
C++入門經(jīng)典-(第10版) 本書特色
作為C 入門經(jīng)典教材,《C 入門經(jīng)典(第10版)》結合作者多年的教學經(jīng)驗,清楚梳理出一個有利于教與學的結構體系,從各章開頭的內(nèi)容總覽,到隨處可見的自測題、小結框、編程提示和編程陷阱,再到章末的小結、習題、編程練習和編程項目,由淺入深,從簡到繁,可以幫助初學者漸入佳境,逐步理解并掌握重要的編程概念。
《C 入門經(jīng)典(第10版)》共18章,8個附錄。在講解C 基礎知識之后,循序漸進地引導讀者深入函數(shù)、I/O流、類、控制流程、命名空間、數(shù)組、字符串、指針和動態(tài)數(shù)組、遞歸、模板、指針和鏈表、派生類、異常以及標準模板庫。本書前幾版被全國100多所高校選作C 程序設計課程的教材,很受師生歡迎。《C 入門經(jīng)典(第10版)》也適合自學,不同層次的知識點和測試練習,可以幫助讀者以自己的節(jié)奏進入美妙的C 編程世界。
C++入門經(jīng)典-(第10版) 內(nèi)容簡介
Walter Savitch教授的C 入門經(jīng)典,長銷十幾年
結構嚴謹、清晰,行文詼諧幽默,妙趣橫生
更多技巧提示,更多生動有趣的編程實例
近70個精彩視頻,410 自測題,230 編程項目
C++入門經(jīng)典-(第10版) 目錄
目 錄
第1章 計算機和C 編程入門 1
1.1 計算機系統(tǒng) 2
硬件 2
軟件 5
高級語言 6
編譯器 7
歷史回顧 9
1.2 編程和問題求解 9
算法 10
程序設計 11
面向對象編程 12
軟件生命周期 12
1.3
C 入門 13
C 語言的起源 13
一個C 示范程序 14
陷阱:在\n中錯誤地使用斜杠 17
編程提示:輸入和輸出語法 17
簡單C 程序的布局 17
陷阱:在include的文件名前錯誤地
添加一個空格 19
編譯和運行C 程序 19
陷阱:編譯C 11程序 19
編程提示:讓程序運行起來 20
1.4 測試和調(diào)試 22
各種程序錯誤 22
陷阱:錯誤地假定程序正確 23
小結 24
自測題答案 25
編程練習 26
編程項目 27
第2章 C 基礎知識 29
2.1 變量和賦值 30
變量 30
名稱:標識符 32
變量聲明 33
賦值語句 34
陷阱:未初始化的變量 35
編程提示:使用有意義的名稱 36
2.2 輸入和輸出 37
使用cout進行輸出 37
include預編譯指令和命名空間 38
轉義序列 39
編程提示:用\n或endl終止
每一個程序 40
格式化帶小數(shù)點的數(shù)字 41
用cin進行輸入 42
設計輸入和輸出 43
編程提示:I/O中的換行 43
2.3 數(shù)據(jù)類型和表達式 44
int類型和double類型 44
其他數(shù)值類型 45
C 11類型 46
char類型 47
bool類型 48
string類簡介 48
類型的兼容性 49
算術操作符和表達式 50
陷阱:除法中的整數(shù) 52
更多賦值語句 53
2.4 簡單控制流程 54
一個簡單的分支機制 54
陷阱:連續(xù)的不等式 58
陷阱:該用==的時候用了= 58
復合語句 59
簡單的循環(huán)機制 61
遞增操作符和遞減操作符 63
編程實例:信用卡余額 64
陷阱:無限循環(huán) 65
2.5 程序風格 67
縮進 67
注釋 67
為常量命名 69
小結 71
自測題答案 72
編程練習 75
編程項目 76
第3章 更多的控制流程 81
3.1 使用布爾表達式 82
布爾表達式求值 82
陷阱:將布爾表達式轉換成int值 85
枚舉類型(選讀) 87
3.2 多路分支 87
嵌套語句 88
編程提示:在嵌套語句中使用
花括號 88
多路if-else語句 90
編程實例:州收入稅 91
switch語句 94
陷阱:忘記在switch語句中添加
break 96
為菜單使用switch語句 97
代碼塊 98
陷阱:疏忽局部變量 100
3.3
C 循環(huán)語句詳解 101
while語句回顧 101
再論遞增操作符和遞減操作符 102
for語句 104
陷阱:for語句中多余的分號 108
應該使用哪種循環(huán) 108
陷阱:未初始化的變量和
無限循環(huán) 110
break語句 110
陷阱:嵌套循環(huán)中的break語句 111
3.4 設計循環(huán) 111
求和與求乘積的循環(huán) 112
終止循環(huán) 113
嵌套循環(huán) 115
調(diào)試循環(huán) 116
小結 119
自測題答案 120
編程練習 123
編程項目 124
第4章 過程抽象和返回值的函數(shù) 129
4.1 自頂向下設計 130
4.2 預定義函數(shù) 130
使用預定義函數(shù) 131
隨機數(shù)生成 134
強制類型轉換 135
強制類型轉換的古老形式 137
陷阱:整數(shù)除法丟棄了小數(shù)部分 137
4.3 程序員自定義函數(shù) 138
函數(shù)定義 138
返回布爾值的函數(shù) 142
另一種形式的函數(shù)聲明 142
陷阱:實參順序錯誤 143
函數(shù)定義語法小結 144
再論函數(shù)定義的位置 144
編程提示:在分支語句中使用
函數(shù)調(diào)用 145
4.4 過程抽象 146
黑盒的比喻 146
編程提示:選擇形參名稱 147
編程提示:嵌套循環(huán) 148
案例分析:購買比薩 150
編程提示:使用偽代碼 154
4.5 作用域和局部變量 155
函數(shù)如同小程序 155
編程實例:豌豆試驗田 157
全局常量和全局變量 157
傳值形參是局部變量 158
塊作用域 160
再論命名空間 161
編程實例:階乘函數(shù) 163
4.6 重載函數(shù)名稱 164
重載入門 164
編程實例:購買比薩(修訂版) 166
自動類型轉換 168
小結 170
自測題答案 171
編程練習 173
編程項目 174
第5章 用函數(shù)完成所有子任務 177
5.1
void函數(shù) 178
void函數(shù)的定義 178
編程實例溫度換算 180
void函數(shù)中的return語句 181
5.2 傳引用參數(shù) 182
初探傳引用調(diào)用 182
傳引用調(diào)用詳解 184
編程實例:swapValues函數(shù) 187
混合的參數(shù)列表 188
編程提示:應該使用哪種參數(shù) 189
陷阱:疏忽造成的局部變量 190
5.3 使用過程抽象 192
在函數(shù)中調(diào)用其他函數(shù) 192
前條件和后條件 193
案例分析:超市定價系統(tǒng) 194
5.4 測試和調(diào)試函數(shù) 198
存根和驅動程序 198
5.5 常規(guī)調(diào)試技術 201
不抱成見 201
檢查常見錯誤 202
定位錯誤 202
assert宏 203
小結 205
自測題答案 206
編程練習 208
編程項目 209
第6章 I/O流——對象和類入門 213
6.1 流和基本文件I/O 214
為什么要用文件來I/O 215
文件I/O 215
類與對象入門 218
編程提示:檢查文件是否成功
打開 219
文件I/O技術 222
追加到文件(選讀) 223
文件名作為輸入(選讀) 225
6.2 流I/O工具 227
用流函數(shù)格式化輸出 227
操縱元 230
流作為函數(shù)實參 232
編程提示:檢查文件尾 233
命名空間的問題 234
編程實例:整理文件格式 235
6.3 字符I/O 236
get和put成員函數(shù) 236
putback成員函數(shù)(選讀) 239
編程實例:檢查輸入 239
陷阱:輸入中不期而遇的'\n' 241
編程實例:另一個newLine函數(shù) 242
函數(shù)的默認實參(選讀) 243
eof成員函數(shù) 246
編程實例:編輯文本文件 247
預定義字符函數(shù) 249
陷阱:toupper和tolower返回值 250
小結 252
自測題答案 253
編程練習 257
編程項目 258
第7章 數(shù)組 263
7.1 數(shù)組入門 264
聲明和引用數(shù)組 264
編程提示:為數(shù)組使用for循環(huán) 266
陷阱:數(shù)組索引總是從零開始 266
編程提示:為數(shù)組長度使用已定義
常量 266
數(shù)組在內(nèi)存中的表示 267
陷阱:數(shù)組索引越界 268
初始化數(shù)組 269
編程提示:C 11基于范圍的
for語句 270
7.2 函數(shù)中的數(shù)組 272
索引變量作為函數(shù)參數(shù) 272
整個數(shù)組作為函數(shù)參數(shù) 274
const參數(shù)修飾符 276
陷阱:const參數(shù)修飾符的使用
不一致 277
返回數(shù)組的函數(shù) 278
案例分析:產(chǎn)量圖 278
7.3 數(shù)組編程 287
部分填充數(shù)組 287
編程提示:不要吝嗇形參 289
編程實例:搜索數(shù)組 290
編程實例:數(shù)組排序 291
編程實例:冒泡排序 294
7.4 多維數(shù)組 297
多維數(shù)組基礎 297
多維數(shù)組參數(shù) 298
編程實例:二維打分程序 299
陷阱:在數(shù)組索引之間使用逗號 302
小結 303
自測題答案 304
編程練習 306
編程項目 307
第8章 字符串和向量 315
8.1 字符串的數(shù)組類型 316
C字符串值和C字符串變量 317
陷阱:為C字符串使用=和== 319
中的其他函數(shù) 321
陷阱:使用strcpy復制C字符串
越界 322
C字符串輸入和輸出 324
C字符串到數(shù)值的轉換和
可靠輸入 326
8.2 標準string類 330
標準類string簡介 330
string類的I/O 332
編程提示:getline的其他版本 334
陷阱:混合使用cin>>變量;和
getline 335
用string類進行字符串處理 336
編程實例:回文測試 338
string對象和C字符串之間的轉換 341
字符串和數(shù)字之間的轉換 342
8.3 向量 342
向量基礎知識 342
陷阱:使用方括號時超出向量
長度 345
編程提示:向量賦值具有良好
行為 345
效率問題 345
小結 347
自測題答案 348
編程練習 349
編程項目 350
第9章 指針和動態(tài)數(shù)組 355
9.1 指針 356
指針變量 357
基本內(nèi)存管理 362
陷阱:虛懸指針 362
靜態(tài)變量和自動變量 362
編程提示:定義指針類型 363
9.2 動態(tài)數(shù)組 364
數(shù)組變量和指針變量 365
創(chuàng)建和使用動態(tài)數(shù)組 366
指針運算(選讀) 370
多維動態(tài)數(shù)組(選讀) 371
小結 373
自測題答案 374
編程練習 374
編程項目 375
第10章 定義類 379
10.1
結構 380
用于異種數(shù)據(jù)的結構 380
陷阱:結構定義中忘記添加分號 383
結構作為函數(shù)參數(shù) 384
編程提示:使用層次化結構 384
對結構進行初始化 386
10.2
類 388
定義類和成員函數(shù) 388
公共成員和私有成員 391
編程提示:將所有成員變量
設為私有 396
編程提示:定義取值函數(shù)和
賦值函數(shù) 397
編程提示:將賦值操作符用于
對象 398
編程實例:BankAccount類
(版本1) 398
總結類的一些特征 402
用于初始化的構造函數(shù) 403
編程提示:總是包括默認構造
函數(shù) 408
陷阱:無參構造函數(shù) 409
C 11的成員初始化器和構造
函數(shù)委托 410
10.3
抽象數(shù)據(jù)類型 411
用于生成抽象數(shù)據(jù)類型的類 412
編程實例:類的另一種實現(xiàn) 414
10.4
繼承 418
派生類 418
定義派生類 419
小結 423
自測題答案 424
編程練習 428
編程項目 428
第11章 類中的友元函數(shù)、
重載操作符和數(shù)組 433
11.1
友元函數(shù) 434
編程實例:一個相等性函數(shù) 434
友元函數(shù) 436
編程提示:定義取值函數(shù)和
友元函數(shù) 438
編程提示:同時使用成員函數(shù)和
非成員函數(shù) 439
編程實例:Money類(版本1) 439
實現(xiàn)digitToInt(選讀) 443
陷阱:數(shù)字常量中的前置零 444
const參數(shù)修飾符 445
陷阱:修飾符const的用法不一致 447
11.2
重載操作符 449
重載操作符 449
用于自動類型轉換的構造函數(shù) 452
重載一元操作符 453
重載>>和
11.3
數(shù)組和類 460
類數(shù)組 460
數(shù)組作為類成員 463
編程實例:用于部分填充
數(shù)組的類 463
11.4
類和動態(tài)數(shù)組 465
編程實例:字符串變量類 466
析構函數(shù) 468
陷阱:指針作為傳值參數(shù) 469
拷貝構造函數(shù) 471
重載賦值操作符 474
小結 477
自測題答案 478
編程練習 484
編程項目 484
第12章 獨立編譯和命名空間 491
12.1
獨立編譯 492
ADT回顧 492
案例分析:獨立編譯的
DigitalTime類 493
使用#ifndef 500
編程提示:定義其他庫 502
12.2
命名空間 503
命名空間和using預編譯指令 503
創(chuàng)建命名空間 504
限定名稱 506
命名空間的微妙之處(選讀) 507
無名命名空間 508
陷阱:混淆全局命名空間和
無名命名空間 512
小結 513
自測題答案 514
編程練習 515
編程項目 516
第13章 指針和鏈表 517
13.1
節(jié)點和鏈表 518
節(jié)點 519
nullptr 521
鏈表 522
在表頭插入節(jié)點 523
陷阱:丟失節(jié)點 525
搜索鏈表 526
指針作為迭代器 528
在列表中插入和刪除節(jié)點 528
陷阱:為動態(tài)數(shù)據(jù)結構使用賦值
操作符 531
鏈表的變體 531
類構成的鏈表 533
13.2
棧和隊列 536
棧 536
編程實例:棧類 536
隊列 539
編程實例:隊列類 540
小結 544
自測題答案 545
編程練習 546
編程項目 547
第14章 遞歸 553
14.1
面向任務的遞歸函數(shù) 554
案例分析:垂直數(shù)字 555
深入遞歸 559
陷阱:無窮遞歸 560
用于遞歸的棧 562
陷阱:棧溢出 563
遞歸與迭代 563
14.2
面向值的遞歸函數(shù) 564
要返回值的遞歸函數(shù)的常規(guī)形式 564
編程實例:另一個求乘方函數(shù) 564
14.3
遞歸思想 567
遞歸設計技術 567
案例分析:二叉搜索
(遞歸思想示例) 569
編程實例:遞歸成員函數(shù) 574
小結 577
自測題答案 578
編程練習 581
編程項目 581
第15章 繼承 585
15.1
繼承基礎 586
派生類 588
派生類中的構造函數(shù) 593
陷阱:使用來自基類的私有
成員變量 595
陷阱:私有成員函數(shù)不會繼承 596
protected限定符 596
重定義成員函數(shù) 598
重定義與重載的比較 600
訪問重定義的基函數(shù) 601
15.2
繼承細節(jié) 602
不繼承的函數(shù) 602
派生類中的賦值操作符和
拷貝構造函數(shù) 602
派生類中的析構函數(shù) 603
15.3
多態(tài)性 604
晚期綁定 604
C 虛函數(shù) 605
虛函數(shù)和擴展類型兼容性 609
陷阱:不使用虛成員函數(shù) 612
陷阱:試圖對虛成員函數(shù)定義
不齊全的類進行編譯 612
編程提示:使析構函數(shù)成為
虛函數(shù) 613
小結 615
自測題答案 616
編程練習 619
編程項目 620
第16章 異常處理 627
16.1
異常處理基礎 628
異常處理的簡單例子 629
定義自己的異常類 635
多個throw塊和catch塊 636
陷阱:首先捕捉較具體的異常 638
編程提示:異常類可能很簡單 638
在函數(shù)中拋出異常 639
異常規(guī)范 640
陷阱:派生類中的異常規(guī)范 641
16.2
用于異常處理的編程技術 642
拋出異常的時機 642
陷阱:未捕捉的異常 643
陷阱:嵌套try-catch塊 643
陷阱:濫用異常 644
異常類層次結構 644
測試可用內(nèi)存 644
重新拋出異常 645
小結 646
自測題答案 647
編程練習 647
編程項目 649
第17章 模板 651
17.1
用于算法抽象的模板 652
函數(shù)模板 653
陷阱:編譯器的復雜性 656
編程實例:泛型排序函數(shù) 657
編程提示:如何定義模板 660
陷阱:為不恰當?shù)念愋褪褂媚0? 660
17.2
用于數(shù)據(jù)抽象的模板 660
類模板的語法 660
編程實例:數(shù)組類 663
小結 668
自測題答案 669
編程練習 671
編程項目 671
第18章 標準模板庫 675
18.1
迭代器 676
using聲明 677
迭代器基礎 677
編程提示:使用auto簡化變量
聲明 681
陷阱:編譯器問題 681
迭代器的種類 682
常量和可變迭代器 684
逆向迭代器 685
其他種類的迭代器 687
18.2
容器 687
順序容器 687
陷阱:迭代器和刪除元素 690
編程提示:容器中的類型定義 691
容器配接器stack和queue 691
關聯(lián)容器set和map 693
編程提示:為容器使用初始化、
基于范圍的for和auto 698
效率問題 699
18.3
泛型算法 699
運行時間和大O表示法 700
容器訪問運行時間 703
不修改容器的算法 703
會修改容器的算法 706
set算法 707
排序算法 708
18.4
不斷進化的C 708
std::array 709
正則表達式 710
線程 713
智能指針 717
小結 722
自測題答案 723
編程練習 724
編程項目 724
附錄A C 關鍵字 729
附錄B 操作符的優(yōu)先級 730
附錄C ASCII字符集 731
附錄D 部分庫函數(shù) 732
附錄E 內(nèi)聯(lián)函數(shù) 736
附錄F 重載數(shù)組索引方括號 737
附錄G this指針 738
附錄H 將操作符重載為成員操作符 740
展開全部
C++入門經(jīng)典-(第10版) 作者簡介
Walter Savitch 加州大學圣迭戈分校榮譽退休教授。擁有加州大學伯克利分校博士學位,曾擔任加州大學圣迭戈分校計算機科學系教授和認知科學跨學科博士項目主任。他在復雜性理論和并行計算模型方面具有卓越貢獻,其研究領域包括形式語言理論和計算語言學等。
周靖 微軟最有價值專家(MVP),資深譯者。涉獵廣泛,具有深厚的技術功底和良好的文學素養(yǎng)。早期癡迷于硬件,曾多年擔任《微型計算機》雜志特約作者。繼而潛心鉆研程序設計,并在這方面積累了豐富的經(jīng)驗。此后專職從事計算機圖書的翻譯。其翻譯風格嚴謹、準確、樸實、流暢,深受讀者好評。代表譯著有《C 入門經(jīng)典》、《Visual C#從入門到精通》、《CLR via C》系列版本。