UNIX系統編程: 通信、并發與線程( 簡體 字) | |
作者:師蓉 | 類別:1. -> 作業系統 -> UNIX |
出版社:電子工業出版社 | 3dWoo書號: 49037 詢問書籍請說出此書號! 有庫存 NT售價: 990 元 |
出版日:5/1/2018 | |
頁數:896 | |
光碟數:0 | |
站長推薦: | |
印刷:黑白印刷 | 語系: ( 簡體 字 ) |
ISBN:9787121340352 | 加入購物車 │加到我的最愛 (請先登入會員) |
(簡體書上所述之下載連結耗時費功, 恕不適用在台灣, 若讀者需要請自行嘗試, 恕不保證, 繁體書的下載亦請直接連絡出版社) | |
第一部分 基礎知識
第1章 技術對程序的影響 3 1.1?術語的變化 3 1.2?時間和速度 5 1.3?多道程序設計和分時 6 1.4?應用層的并發 8 1.4.1?中斷 8 1.4.2?信號 9 1.4.3?輸入和輸出 10 1.4.4?進程、線程和資源共享 10 1.4.5?具有共享內存的多個處理器 11 1.4.6?網絡作為計算機 11 1.5?安全和容錯 12 1.6?非法入侵造成的緩沖區溢出 13 1.6.1?緩沖區溢出的后果 14 1.6.2?緩沖區溢出和安全 16 1.7?UNIX標準 17 1.8?延伸閱讀 19 第2章 程序、線程和進程 21 2.1?程序是如何成為進程的 21 2.2?線程和執行線程 22 2.3?程序映象的布局 23 2.4?庫函數調用 26 2.5?函數返回值和錯誤 29 2.6?參數數組 31 2.6.1?用makeargv函數創建一個數組 32 2.6.2?makeargv函數的實現 34 2.7?線程安全函數 38 2.8?靜態變量的使用 40 2.9?靜態對象的結構 42 2.10?進程環境 48 2.11?進程終止 51 2.12?練習:一個env實用程序 54 2.13?練習:消息日志 55 2.14?延伸閱讀 57 第3章 UNIX中的進程 58 3.1?進程標識符 58 3.2?進程狀態 60 3.3?UNIX 進程創建和fork函數 63 3.4?wait函數 70 狀態值 76 3.5?exec函數 77 3.6?后臺進程和守護進程 83 3.7?臨界區 86 3.8?練習:進程鏈 87 3.9?練習:進程扇 88 3.10?延伸閱讀 89 第4章 UNIX I/O 90 4.1?設備術語 90 4.2?讀/寫 91 4.3?打開和關閉文件 102 4.4?select函數 107 4.5?poll函數 116 4.6?文件表示 119 4.6.1?文件描述符 119 4.6.2?文件指針和緩沖 122 4.6.3?文件描述符的繼承 124 4.7?過濾器和重定向 128 4.8?文件控制 132 4.9?練習:原子日志 135 原子日志庫 139 4.10?練習:cat實用程序 141 4.11?延伸閱讀 143 第5章 文件和目錄 144 5.1?UNIX文件系統導航 144 5.1.1?當前工作目錄 145 5.1.2?搜索路徑 150 5.2?目錄訪問 151 5.2.1?訪問文件狀態信息 153 5.2.2?確定文件的類型 156 5.3?UNIX文件系統實現 157 5.3.1?UNIX文件實現 158 5.3.2?目錄實現 161 5.4?硬鏈接和符號鏈接 161 5.4.1?創建或刪除一個鏈接 162 5.4.2?創建和刪除符號鏈接 167 5.5?練習:which命令 172 5.6?練習:郵件通知程序 173 5.7?練習:新聞通知程序 176 5.8?練習:遍歷目錄 177 5.9?延伸閱讀 179 第6章 UNIX特殊文件 180 6.1?管道 180 6.2?流水線 184 6.3?FIFO 189 6.4?管道與客戶機-服務器模型 193 6.5?終端控制 200 規范和非規范的輸入處理 208 6.6?音頻設備 212 6.7?練習:音頻 218 6.8?練習:屏障 220 6.9?練習:stty命令 221 6.10?練習:重提客戶機-服務器 222 6.11?延伸閱讀 222 第7章 項目:令牌環 224 7.1?環形拓撲 224 7.2?環的形成 226 7.3?環的探討 232 7.4?簡單通信 234 7.5?用令牌環實現互斥 235 7.6?用投票實現互斥 237 7.7?匿名環中的領導者選舉 238 7.8?用于通信的令牌環 240 7.9?流水線預處理機 242 7.10?并行環算法 244 7.10.1?圖像過濾 244 7.10.2?矩陣乘法 247 7.11?彈性環 248 7.12?延伸閱讀 249 第二部分?異步事件 第8章 信號 253 8.1?信號的基本概念 253 8.2?信號的產生 254 8.3?對信號掩碼和信號集進行操作 259 8.4?捕獲和忽略信號—sigaction 266 8.5?等待信號—pause、sigsuspend和sigwait 272 8.5.1?pause函數 272 8.5.2?sigsuspend函數 274 8.5.3?sigwait函數 282 8.6?處理信號:錯誤和異步信號安全 283 8.7?用siglongjmp和sigsetjmp進行程序控制 286 8.8?使用異步I/O編程 288 8.9?練習:轉儲統計 300 8.10?練習:同時處理慢速設備 301 8.11?延伸閱讀 301 第9章 時間和定時器 303 9.1?POSIX時間 303 9.1.1?用從Epoch開始的秒數表示時間 304 9.1.2?顯示日期和時間 305 9.1.3?使用struct timeval表示時間 308 9.1.4?使用實時時鐘 311 9.1.5?耗時和處理器時間的對比 313 9.2?睡眠函數 316 9.3?POSIX:XSI間隔定時器 319 9.4?實時信號 323 9.5?POSIX:TMR間隔定時器 328 9.6?定時器漂移、溢出和絕對時間 333 9.7?延伸閱讀 344 第10章 項目:虛擬定時器 345 10.1?項目概述 345 10.2?簡單的定時器 348 10.3?對5個定時器中的一個進行設置 351 10.3.1?virtualtimers對象 351 10.3.2?hardwaretimer對象 353 10.3.3?主程序實現 354 10.3.4?用show譜寫定時器代碼 355 10.4?使用多個定時器 361 10.4.1?設置多個定時器 364 10.4.2?用多個定時器進行測試 365 10.5?多定時器的健壯實現 369 10.6?POSIX:TMR定時器的實現 371 10.7?一個小型的cron工具mycron 372 10.8?延伸閱讀 372 第11章 項目:破解shell 373 11.1?構建一個簡單的shell 373 11.2?重定向 378 11.3?流水線 382 11.4?前臺的信號處理 385 11.5?進程組、會話和控制終端 391 11.5.1?進程組 391 11.5.2?會話 393 11.6?ush中的后臺進程 396 11.7?作業控制 403 11.8?ush的作業控制 407 11.8.1?一個作業列表對象 407 11.8.2?ush中的作業列表 409 11.8.3?ush中的作業控制 409 11.8.4?等待流水線時的進程行為 410 11.9?延伸閱讀 411 第三部分?并?發 第12章 POSIX線程 415 12.1?監視文件描述符的方法 415 12.2?使用線程監視多個文件描述符 417 12.3?線程管理 420 12.3.1?用ID引用線程 421 12.3.2?創建一個線程 422 12.3.3?分離和連接 423 12.3.4?退出和取消 426 12.3.5?向線程傳遞參數并返回值 429 12.4?線程安全 438 12.5?用戶級線程 VS 內核級線程 439 12.6?線程屬性 442 12.6.1?線程狀態 443 12.6.2?線程棧 444 12.6.3?線程調度 446 12.7?練習:并行文件復制 450 12.8?延伸閱讀 451 第13章?線程同步 452 13.1?POSIX同步函數 452 13.2?互斥鎖 453 13.2.1?創建并初始化一個互斥量 454 13.2.2?銷毀一個互斥量 455 13.2.3?鎖定和解鎖互斥量 456 13.2.4?保護不安全的庫函數 458 13.2.5?同步標志和全局值 459 13.2.6?讓數據結構成為線程安全的 465 13.3?最多一次和至少一次的執行 467 13.4?條件變量 471 13.4.1?條件變量的創建和銷毀 473 13.4.2?等待并通知條件變量 475 13.5?信號處理和線程 478 13.5.1?將信號定向到一個特定的線程中 479 13.5.2?為線程屏蔽信號 480 13.5.3?信號處理的專用線程 480 13.6?讀者和寫者 484 13.7?strerror_r實現 489 13.8?死鎖和其他討厭的問題 491 13.9?練習:多個屏障 492 13.10?延伸閱讀 492 第14章?臨界區和信號量 493 14.1?臨界區的處理 493 14.2?信號量 496 14.3?POSIX:SEM匿名信號量 499 14.4?POSIX:SEM信號量操作 501 14.5?POSIX:SEM命名信號量 508 14.5.1?創建并打開命名信號量 509 14.5.2?關閉信號量并刪除其鏈接 512 14.6?練習:許可管理器 514 14.6.1?license對象 515 14.6.2?runsim主程序 515 14.6.3?對許可管理器的擴展 516 14.7?延伸閱讀 516 第15章?POSIX IPC 517 15.1?POSIX:XSI進程間通信 517 15.1.1?標識并訪問IPC對象 518 15.1.2?在shell中訪問POSIX:XSI IPC資源 519 15.2?POSIX:XSI信號量集 520 15.2.1?信號量的創建 521 15.2.2?信號量的控制 523 15.2.3?POSIX信號量集操作 525 15.3?POSIX:XSI共享內存 532 15.3.1?訪問共享內存段 532 15.3.2?共享內存段的連接和分離 533 15.3.3?控制共享內存 534 15.3.4?共享內存示例 535 15.4?POSIX:XSI消息隊列 541 訪問消息隊列 542 15.5?練習:POSIX匿名信號量 549 15.6?練習:POSIX命名信號量 550 15.7?練習:用共享內存實現管道 551 15.8?練習:用消息隊列實現管道 554 15.9?延伸閱讀 554 第16章?項目:生產者-消費者同步 555 16.1?生產者-消費者問題 555 16.2?受互斥鎖保護的有界緩沖區 557 16.3?使用信號量的緩沖區實現 560 16.4?一個簡單的生產者-消費者問題簡介 566 16.5?使用條件變量的有界緩沖區 570 16.6?帶有完成條件的緩沖區 571 16.7?并行文件復制 580 16.7.1?并行文件復制的生產者 580 16.7.2?并行文件復制的消費者 581 16.7.3?并行文件復制的main程序 582 16.7.4?并行文件復制的增強 582 16.8?線程化打印服務器 583 16.8.1?請求緩沖區 584 16.8.2?生產者線程 585 16.8.3?消費者線程 586 16.8.4?打印服務器 586 16.8.5?其他增強功能 586 16.9?延伸閱讀 587 第17章?項目:非完全并行虛擬機 588 17.1?PVM的歷史、術語和結構 588 17.2?非完全并行虛擬機 591 17.3?NTPVM項目概述 593 17.3.1?NEWTASK分組 596 17.3.2?DATA分組 596 17.3.3?DONE分組 597 17.4?調度程序的I/O和測試 598 17.4.1?用多個窗口測試 604 17.4.2?用遠程日志測試 605 17.5?沒有輸入的單任務 607 17.6?順序任務 608 17.6.1?輸入線程 609 17.6.2?輸出線程 610 17.7?并發任務 611 17.8?分組通信、廣播和屏障 611 17.9?終止和信號 612 17.10?有序的消息傳遞 613 17.11?延伸閱讀 613 第四部分?通?信 第18章?面向連接的通信 617 18.1?客戶機-服務器模型 617 18.2?通信信道 618 18.3?面向連接的服務器策略 622 18.4?通用因特網通信接口(UICI) 625 18.4.1?處理錯誤 627 18.4.2?讀和寫 627 18.5?不同服務器策略的UICI實現 628 18.6?UICI客戶機 631 18.7?UICI的套接字實現 637 18.7.1?socket函數 638 18.7.2?bind函數 639 18.7.3?listen函數 641 18.7.4?u_open函數的實現 642 18.7.5?accept函數 643 18.7.6?u_accept函數的實現 645 18.7.7?connect函數 646 18.7.8?u_connect函數的實現 647 18.8?主機名和IP地址 649 18.9?線程安全的UICI 658 18.10?練習:ping服務器 661 18.11?練習:音頻的傳輸 662 18.12?延伸閱讀 664 第19章?項目:WWW重定向 665 19.1?萬維網 665 19.2?統一資源定位符(URL) 666 19.3?HTTP入門 668 19.3.1?客戶端請求 669 19.3.2?服務器響應 669 19.3.3?HTTP消息交換 670 19.4?Web通信模式 673 19.4.1?隧道 673 19.4.2?代理 674 19.4.3?高速緩存和透明性 676 19.4.4?網關 678 19.5?單連接的通過型監控 679 19.6?隧道服務器的實現 682 19.7?用于測試的服務器驅動程序 682 19.8?HTTP頭解析 684 19.9?簡單的代理服務器 686 19.10?代理監視器 688 19.11?代理高速緩存 691 19.12?門戶網站的網關 692 19.13?用于負載平衡的網關 692 19.14?事后的調查分析 693 19.14.1?線程和計時錯誤 693 19.14.2?未捕獲的錯誤和錯誤的退出 694 19.14.3?書寫風格和表示 695 19.14.4?糟糕的測試和結果表示 696 19.14.5?編程錯誤和不好的風格 697 19.15?延伸閱讀 698 第20章?無連接通信和多播 699 20.1?無連接通信簡介 699 20.2?無連接通信的簡化接口 701 20.2.1?主機名和u_buf_t結構 703 20.2.2?UICI UDP的返回錯誤 703 20.2.3?UDP緩沖區大小和UICI UDP 703 20.3?簡單-請求協議 704 20.4?請求-應答協議 710 20.5?有超時和重試的請求-應答 716 20.6?請求-應答-確認協議 722 20.7?UICI UDP的實現 723 20.7.1?u_openudp函數的實現 723 20.7.2?sendto函數 725 20.7.3?u_sendto和 u_sendtohost函數的實現 726 20.7.4?recvfrom函數 727 20.7.5?u_recvfrom和u_recvfromtimed函數的實現 728 20.7.6?主機名和u_buf_t 730 20.8?UDP和TCP的比較 732 20.9?多播 733 20.9.1?多播尋址 733 20.9.2?u_join函數的實現 735 20.9.3?u_leave函數的實現 736 20.10?練習:UDP端口服務器 737 20.11?練習:無狀態文件服務器 738 遠程文件服務 739 20.12?延伸閱讀 740 第21章?項目:互聯網廣播 741 21.1?項目概述 741 21.2?音頻設備模擬 744 21.3?具有一個節目和一個接收者的UDP實現 744 21.3.1?簡單實現 744 21.3.2?接收者的終止 747 21.3.3?接收者緩沖來處理網絡延遲 748 21.3.4?接收者緩沖來處理亂序傳遞 751 21.4?具有多個節目和接收者的UDP實現 754 21.4.1?多個節目和單個接收者 754 21.4.2?多個節目和多個接收者 755 21.5?音頻廣播的UDP實現 756 21.6?無線電廣播的多播實現 758 21.7?TCP實現的差異 758 21.7.1?單個節目和單個接收者的TCP實現 759 21.7.2?多個節目和單個接收者的TCP實現 760 21.7.3?無線電廣播的TCP實現 761 21.8?通過瀏覽器接收流式音頻 764 21.8.1?使用瀏覽器助手應用程序 764 21.8.2?在你的Web服務器中設置一種新的mime類型 765 21.8.3?設置你的瀏覽器來處理新的mime類型 766 21.8.4?創建Web頁面 766 21.8.5?使用預定義的mime類型 767 21.9?延伸閱讀 767 第22章?項目:服務器性能 769 22.1?服務器性能成本 769 22.2?服務器架構 770 22.3?項目概述 774 22.4?單客戶端驅動程序 775 22.4.1?處理一個連接 775 22.4.2?對響應進行編程 776 22.4.3?收集統計信息 777 22.4.4?測試客戶端 777 22.5?多客戶端驅動程序 778 另一種多客戶端設計 781 22.6?實現每個請求一個線程和每個請求一個進程 781 22.7?線程工作者池策略 782 22.8?使用有界緩沖區的多線程工作者池 782 22.9?進程工作者池 783 22.10?磁盤I/O的影響 783 22.11?性能研究 787 22.11.1?基線測量 787 22.11.2?波動性的根源 788 22.11.3?測量錯誤 789 22.11.4?同步 792 22.11.5?普通的錯誤 793 22.11.6?要測量什么 794 22.11.7?數據分析和表示 796 22.12?報告撰寫 797 22.12.1?引言 797 22.12.2?設計、實現和測試 798 22.12.3?實驗 798 22.12.4?結果和分析 799 22.12.5?結論 799 22.12.6?參考文獻 799 22.13?延伸閱讀 800 附錄A?UNIX基礎 801 附錄B?重啟庫 819 附錄C?UICI實現 829 附錄D?日志函數 846 附錄E?POSIX擴展 864 參考文獻 867 本書是基于新UNIX標準的完備參考書,對UNIX編程要點進行清晰易懂的介紹,從說明系統調用的短小代碼段開始,逐漸過渡到用于技能提升的實際項目。作者深入探討通信、并發和線程問題,對復雜概念(如信號和并發)進行全面解讀,覆蓋文件、信號、信號量、POSIX線程和客戶機-服務器通信等內容;提供大量實例、練習,以及針對性項目及其參考答案。全書第一部分介紹UNIX基礎知識,包括文件、進程和特殊文件等;第二部分介紹信號和定時器;第三部分介紹信號量和進程同步;第四部分介紹通信話題。本書適合作為高等院校計算機專業的教材,也可供軟件開發人員參考使用。
本書是1995年由Prentice Hall出版的Practical UNIX Programming: A Guide to Communication, Concurrency and Multithreading一書的第2版。為了更好地傳達本書的內容,我們將書名修改為“UNIX系統編程:通信、并發與線程”。與上一版相比,我們不僅改變了書名,還對很多內容進行了修改。
互聯網已經成為計算和社會領域的一個主導方面。我們的私人信息聯網了;我們的軟件經常會受到攻擊。因此,編寫正確的代碼顯得尤為重要。在這一版中,我們嘗試盡量生成能夠正確處理錯誤和特殊情況的代碼。我們意識到,只是聲稱處理了所有的錯誤,但在給出的代碼中卻省略錯誤處理是沒有效果的。不幸的是,錯誤處理讓代碼變得更復雜。我們付出了很多努力,以便讓代碼顯得清晰一些。 本書對上一版的另一個重要改進是采用了單一的UNIX規范,我們將其稱為POSIX。我們再也不需要決定使用哪個廠商的庫函數了——現在有了正式的版本。我們已經盡了最大努力來遵循這個標準。 練習和項目讓本書變得與眾不同。實際上,本書是從作為美國國家科學基金會(National Science Foundation Grant)一部分的項目手冊發展而來的。在完成這個項目的初期開發后,我們逐漸認識到:完成這個項目所需的材料分散在不同的地方——這些材料通常可以在提供了大量細節、但幾乎沒有概念陳述的參考書中找到。因此,本書逐漸成為一本基于最新UNIX標準的完整參考書。 本書分為4部分,每部分都包含主題章節和項目章節。主題章節以循序漸進的方式涵蓋了指定的內容,并以“ 試試看”和“看看會發生什么”的形式包含了很多示例和練習。主題章節都以一個或者多個練習小節結束。本書還為進程管理、并發和通信的很多基本概念提供了很多編程練習。這些編程練習與傳統科學課程中的實驗作用相同。只有通過實踐才能真正理解書中的概念。這些練習由易到難,很多練習只需要不到100行代碼就能實現。 項目章節通過開發一個規模較大的應用程序來整合幾個主題章節的資料。這些項目包含兩個層面。除說明編程思想外,這些項目還引導讀者理解與應用程序相關的高級主題。這些項目都是分階段設計的,大多數完整的實現都只需要幾百行代碼。由于不需要編寫大量代碼,因此,讀者可以將注意力集中在對概念的理解而不是代碼調試上。為了簡化編程,我們提供了可用于網絡通信和輸出日志記錄的庫。對專業的程序員來說,主題章節結尾部分的練習提供了對概念的基本介紹。通常,使用本書的教師可以從中挑選幾個練習和一個項目章節讓學生在一學期的課程中實現。每個項目都有多種變化,因此,這些項目可以在多個學期里反復使用。 讀者可以用不同的方式閱讀本書。第一部分的主題章節是閱讀本書其他部分的基礎。在閱讀完第一部分的主題章節后,讀者可以按照任何順序閱讀第二部分至第四部分的內容,但后續章節結尾部分關于交互的討論(例如,線程如何與信號交互)除外。 我們假定讀者是優秀的C程序員,但不一定是UNIX C的程序員。讀者應該熟悉C語言編程和基本的數據結構。對于剛剛接觸UNIX的讀者來說,附錄A中給出了程序開發的必備知識。 本書包含標準函數的概要。我們在概要的右下角列出了指定函數的相關標準。 本書的內容是有限的。我們歡迎讀者提出意見和建議,電子郵件地址為authors@usp.cs.utsa.edu。雖然我們已經盡最大努力保證本書沒有錯誤,但如果你是第一個向我們指出某個錯誤的人,那么我們會在本書的配套網站上對你表示誠摯的感謝。我們在Web站點http://usp.cs.utsa.edu/usp上提供了本書的相關信息。從這個Web站點上可以下載本書中包含的所有代碼。 |