[www.ed2k.online]下載基地為您提供軟件、遊戲、圖書、教育等各種資源的ED2K電驢共享下載和MAGNET磁力鏈接下載。
設為首頁
加入收藏
首頁 圖書資源 軟件資源 游戲資源 教育資源 其他資源
 電驢下載基地 >> 图书资源 >> 計算機與網絡 >> 《你必須知道的495個C語言問題 高清PDF中文版》(C Programming FAQs)((美)薩米特)掃描版[PDF]
《你必須知道的495個C語言問題 高清PDF中文版》(C Programming FAQs)((美)薩米特)掃描版[PDF]
下載分級 图书资源
資源類別 計算機與網絡
發布時間 2017/7/10
大       小 -
《你必須知道的495個C語言問題 高清PDF中文版》(C Programming FAQs)((美)薩米特)掃描版[PDF] 簡介: 中文名 : 你必須知道的495個C語言問題 高清PDF中文版 原名 : C Programming FAQs 作者 : (美)薩米特 譯者 : 孫雲 朱群英 資源格式 : PDF 版本 : 掃描版 出版社 : 人民郵電出版社 書號 : 9787115194329 發行時間 : 2009年02月01日 地區 : 大陸 語言 : 簡體中文 簡介 :   24小時不間斷
電驢資源下載/磁力鏈接資源下載:
全選
"《你必須知道的495個C語言問題 高清PDF中文版》(C Programming FAQs)((美)薩米特)掃描版[PDF]"介紹
中文名: 你必須知道的495個C語言問題 高清PDF中文版
原名: C Programming FAQs
作者: (美)薩米特
譯者: 孫雲
朱群英
資源格式: PDF
版本: 掃描版
出版社: 人民郵電出版社
書號: 9787115194329
發行時間: 2009年02月01日
地區: 大陸
語言: 簡體中文
簡介:
 
24小時不間斷供源!
如Foxit Reader不能閱讀,請使用Adobe Reader/Acrobat閱讀!

內容簡介
  本書以問答的形式組織內容,討論了學習或使用C語言的過程中經常遇到的一些問題。書中列出了C用戶經常問的400多個經典問題,涵蓋了初始化、數組、指針、字符串、內存分配、庫函數、C預處理器等各個方面的主題,並分別給出了解答,而且結合代碼示例闡明要點。
  本書結構清晰,講解透徹,是各高校相關專業C語言課程很好的教學參考書,也是各層次C程序員的優秀實踐指南。

軟考官方指定教材及同步輔導書下載 | 軟考歷年真是解析與答案
軟考視頻 | 考試機構 | 考試時間安排
Java一覽無余:Java視頻教程 | Java SE | Java EE
.Net技術精品資料下載匯總:ASP.NET篇
.Net技術精品資料下載匯總:C#語言篇
.Net技術精品資料下載匯總:VB.NET篇
撼世出擊:C/C++編程語言學習資料盡收眼底 電子書+視頻教程
Visual C++(VC/MFC)學習電子書及開發工具下載
Perl/CGI腳本語言編程學習資源下載地址大全
Python語言編程學習資料(電子書+視頻教程)下載匯總
最新最全Ruby、Ruby on Rails精品電子書等學習資料下載
數據庫管理系統(DBMS)精品學習資源匯總:MySQL篇 | SQL Server篇 | Oracle篇
平面設計優秀資源學習下載 | Flash優秀資源學習下載 | 3D動畫優秀資源學習下載
最強HTML/xHTML、CSS精品學習資料下載匯總
最新JavaScript、Ajax典藏級學習資料下載分類匯總
網絡最強PHP開發工具+電子書+視頻教程等資料下載匯總
UML學習電子資下載匯總 軟件設計與開發人員必備
經典LinuxCBT視頻教程系列 Linux快速學習視頻教程一帖通
天羅地網:精品Linux學習資料大收集(電子書+視頻教程) Linux參考資源大系
Linux系統管理員必備參考資料下載匯總
Linux shell、內核及系統編程精品資料下載匯總
UNIX操作系統精品學習資料分類總匯
FreeBSD/OpenBSD/NetBSD精品學習資源索引 含書籍+視頻
Solaris/OpenSolaris電子書、視頻等精華資料下載索引
作者簡介
Steve Summit,著名的C語言專家。Usenet C FAQ的創始人和維護者,有近30年的C編程經驗。畢業於麻省理工學院。他曾在華盛頓大學教授C語言課程多年。除本書外,他還與人合著了C Unleashed一書。
編輯推薦
全球C語言程序員集體智慧的結晶
  Amazon全五星圖書
  權威解答495個最常遇到的C語言問題
  C是一門簡潔精妙的語言,掌握基本語法容易,真正能夠自如運用,就不那麼簡單了。你難免會遇到各種各樣的問題,有些可能讓你百思不得其解,甚至翻遍圖書館,也找不到問題的答案。
  《你必須知道的495個C語言問題》的出版填補了這一空白。書中內容是世界各地的C語言用戶多年來在新聞組comp.1ang.c中討論的成果。作者在網絡版CFAQ列表的基礎上進行了大幅度的擴充和豐富,結合代碼示例,權威而且詳細深入地解答了實際學習和工作中最常遇到的495個C語言問題,涵蓋了初始化、數組、指針、字符串、內存分配、庫函數、C預處理器等各個方面的主題。許多知識點的闡述都是其他資料中所沒有的,彌足珍貴。
  涵蓋C99標准
  “本書是Summit以及C FAQ在線列表的許多參與者多年心血的結晶,是C語言界最為珍貴的財富之一。我向所有C語言程序員推薦本書。”.
      ——Francis Glassborow,著名C/C++專家,ACCU(C/C++用戶協會)前主席
  “本書清晰地闡明了Kernighan與Ritchie的The C Programming Language一書中許多簡略的地方,而且精彩地總結了C語言編程實踐,強烈推薦!”
      ——Yechiel M.Kimchi,以色列理工學院

目錄:
第1章 聲明和初始化
基本類型
1.1 我該如何決定使用哪種整數類型?
1.2 為什麼不精確定義標准類型的大小?
1.3 因為C語言沒有精確定義類型的大小,所以我一般都用typedef定義int16和int32。然後根據實際的機器環境把它們定義為int、short、long等類型。這樣看來,所有的問題都解決了,是嗎?
1.4 新的64位機上的64位類型是什麼樣的?
指針聲明
1.5 這樣的聲明有什麼問題?char *p1, p2; 我在使用p2的時候報錯了。
1.6 我想聲明一個指針,並為它分配一些空間,但卻不行。這樣的代碼有什麼問題?char *p; *p=malloc(10);
聲明風格
1.7 怎樣聲明和定義全局變量和函數最好?
1.8 如何在C中實現不透明(抽象)數據類型?
1.9 如何生成“半全局變量”,就是那種只能被部分源文件中的部分函數訪問的變量?
存儲類型
1.10 同一個靜態(static)函數或變量的所有聲明都必須包含static存儲類型嗎?
1.11 extern在函數聲明中是什麼意思?
1.12 關鍵字auto到底有什麼用途?
類型定義(typedef)
1.13 對於用戶定義類型,typedef 和#define有什麼區別?
1.14 我似乎不能成功定義一個鏈表。我試過typedef struct{char *item; NODEPTR next;}* NODEPTR; 但是編譯器報了錯誤信息。難道在C語言中結構不能包含指向自己的指針嗎?
1.15 如何定義一對相互引用的結構?
1.16 Struct{ } x1;和typedef struct{ } x2; 這兩個聲明有什麼區別?
1.17 “typedef int(*funcptr)();”是什麼意思?
const 限定詞
1.18 我有這樣一組聲明:typedef char *charp; const charp p; 為什麼是p而不是它指向的字符為const?
1.19 為什麼不能像下面這樣在初始式和數組維度值中使用const值?const int n=5; int a[n];
1.20 const char *p、char const *p和char *const p有什麼區別?
復雜的聲明
1.21 怎樣建立和理解非常復雜的聲明?例如定義一個包含N個指向返回指向字符的指針的函數的指針的數組?
1.22 如何聲明返回指向同類型函數的指針的函數?我在設計一個狀態機,用函數表示每種狀態,每個函數都會返回一個指向下一個狀態的函數的指針。可我找不到任何方法來聲明這樣的函數——感覺我需要一個返回指針的函數,返回的指針指向的又是返回指針的函數,如此往復,以至無窮。
數組大小
1.23 能否聲明和傳入數組大小一致的局部數組,或者由其他參數指定大小的參數數組?
1.24 我在一個文件中定義了一個extern數組,然後在另一個文件中使用,為什麼sizeof取不到數組的大小?
聲明問題
1.25 函數只定義了一次,調用了一次,但編譯器提示非法重聲明了。
1.26 main的正確定義是什麼?void main正確嗎?
1.27 我的編譯器總在報函數原型不匹配的錯誤,可我覺得沒什麼問題。這是為什麼?
1.28 文件中的第一個聲明就報出奇怪的語法錯誤,可我看沒什麼問題。這是為什麼?
1.29 為什麼我的編譯器不允許我定義大數組,如double array[256][256]?
命名空間
1.30 如何判斷哪些標識符可以使用,哪些被保留了?
初始化
1.31 對於沒有顯式初始化的變量的初始值可以作怎樣的假定?如果一個全局變量初始值為“零”,它可否作為空指針或浮點零?
1.32 下面的代碼為什麼不能編譯? intf(){char a[]="Hello, world!";}
1.33 下面的初始化有什麼問題?編譯器提示“invalid initializers ”或其他信息。char *p=malloc(10);
1.34 char a[]= "string literal";和char *p="string literal"; 初始化有什麼區別?當我向p 賦值的時候,我的程序崩潰了。
1.35 char a{[3]}= "abc"; 是否合法?
1.36 我總算弄清楚函數指針的聲明方法了,但怎樣才能初始化呢?
1.37 能夠初始化聯合嗎?
第2章 結構、聯合和枚舉
結構聲明
2.1 struct x1{ };和typedef struct{ }x2; 有什麼不同?
2.2 這樣的代碼為什麼不對?struct x{ }; x thestruct;
2.3 結構可以包含指向自己的指針嗎?
2.4 在C語言中用什麼方法實現抽象數據類型最好?
2.5 在C語言中是否有模擬繼承等面向對象程序設計特性的好方法?
2.6 為什麼聲明extern f(struct x *p); 給我報了一個晦澀難懂的警告信息?
2.7 我遇到這樣聲明結構的代碼:struct name {int namelen; char namestr[1];};然後又使用一些內存分配技巧使namestr數組用起來好像有多個元素,namelen記錄了元素個數。它是怎樣工作的?這樣是合法的和可移植的嗎?
2.8 我聽說結構可以賦給變量也可以對函數傳入和傳出。為什麼K&R1卻明確說明不能這樣做?
2.9 為什麼不能用內建的==和!=操作符比較結構?
2.10 結構傳遞和返回是如何實現的?
2.11 如何向接受結構參數的函數傳入常量值?怎樣創建無名的中間的常量結構值?
2.12 怎樣從/向數據文件讀/寫結構?
結構填充
2.13 為什麼我的編譯器在結構中留下了空洞?這導致空間浪費而且無法與外部數據文件進行“二進制”讀寫。能否關掉填充,或者控制結構域的對齊方式?
2.14 為什麼sizeof返回的值大於結構大小的期望值,是不是尾部有填充?
2.15 如何確定域在結構中的字節偏移量?
2.16 怎樣在運行時用名字訪問結構中的域?
2.17 C語言中有和Pascal的with等價的語句嗎?
2.18 既然數組名可以用作數組的基地址,為什麼對結構不能這樣?
2.19 程序運行正確,但退出時卻“core dump ”(核心轉儲)了,怎麼回事?
聯合
2.20 結構和聯合有什麼區別?
2.21 有辦法初始化聯合嗎?
2.22 有沒有一種自動方法來跟蹤聯合的哪個域在使用?
枚舉
2.23 枚舉和一組預處理的#define有什麼不同?
2.24 枚舉可移植嗎?
2.25 有什麼顯示枚舉值符號的容易方法嗎?
位域
2.26 一些結構聲明中的這些冒號和數字是什麼意思?
2.27 為什麼人們那麼喜歡用顯式的掩碼和位操作而不直接聲明位域?
第3章 表達式
求值順序
3.1 為什麼這樣的代碼不行?a= i++;
3.2 使用我的編譯器,下面的代碼int i= 7; printf("%d\n", i++ * i++); 打印出49。不管按什麼順序計算,難道不該是56嗎?
3.3 對於代碼int i=3; i=i++; 不同編譯器給出不同的i值,有的為3,有的為4,哪個是正確的?
3.4 有這樣一個巧妙的表達式:a^= b^= a^= b; 它不需要臨時變量就可以交換a和b的值。
3.5 可否用顯式括號來強制執行我所需要的計算順序並控制相關的副作用?就算括號不行,操作符優先級是否能夠控制計算順序呢?
3.6 可是&&和||操作符呢?我看到過類似while((c = getchar()) != EOF && c != '\n')的代碼
3.7 是否可以安全地認為,一旦&&和||左邊的表達式已經決定了整個表達式的結果,則右邊的表達式不會被求值?
3.8 為什麼表達式printf("%d %d", f1(), f2()); 先調用了f2?我覺得逗號表達式應該確保從左到右的求值順序。
3.9 怎樣才能理解復雜表達式並避免寫出未定義的表達式?“序列點”是什麼?
3.10 在a = i++;中,如果不關心a[]的哪一個分量會被寫入,這段代碼就沒有問題,i也的確會增加1,對嗎?
3.11 人們總是說i=i++的行為是未定義的。可我剛剛在一個ANSI編譯器上嘗試過,其結果正如我所期望的。
3.12 我不想學習那些復雜的規則,怎樣才能避免這些未定義的求值順序問題呢?
其他的表達式問題
3.13 ++i和i++有什麼區別?
3.14 如果我不使用表達式的值,那我應該用i++還是++i來做自增呢?
3.15 我要檢查一個數是不是在另外兩個數之間,為什麼if(a b c)不行?
3.16 為什麼如下的代碼不對?int a=1000, b=1000; long int c=a * b;
3.17 為什麼下面的代碼總是給出0?double degC, degF; degC= 5.0 / 9 * (degF - 32);
3.18 需要根據條件把一個復雜的表達式賦給兩個變量中的一個。可以用下面這樣的代碼嗎?((condition) ? a : = complicated_expression;
3.19 我有些代碼包含這樣的表達式。a ? b=c : d 有些編譯器可以接受,有些卻不能。為什麼?
保護規則
3.20 “semantics of‘’change in ANSI C”的警告是什麼意思?
3.21 “無符號保護”和“值保護”規則的區別在哪裡?
第4章 指針
基本的指針應用
4.1 指針到底有什麼好處?
4.2 我想聲明一個指針並為它分配一些空間,但卻不行。這些代碼有什麼問題呢?char *p; *p =malloc(10);
4.3 *p++自增p還是p所指向的變量?
指針操作
4.4 我用指針操作int數組的時候遇到了麻煩。
4.5 我有一個char *型指針碰巧指向一些int型變量,我想跳過它們。為什麼((int *)p)++; 這樣的代碼不行?
4.6 為什麼不能對void *指針進行算術操作?
4.7 我有些解析外部結構的代碼,但是它卻崩潰了,顯示出了“unaligned access”(未對齊的訪問)的信息。這是什麼意思?
作為函數參數的指針
4.8 我有個函數,它應該接受並初始化一個指針:void f(int *ip){ static int dummy = 5; ip = &dummy;}但是當我如下調用時:int *ip; f(ip); 調用者的指針沒有任何變化。
4.9 能否用void ** 通用指針作為參數,使函數模擬按引用傳遞參數? 48
4.10 我有一個函數extern intf(int *); ,它接受指向int型的指針。我怎樣用引用方式傳入一個常數?調用f(&5);似乎不行。
4.11 C語言可以“按引用傳參”嗎?
其他指針問題
4.12 我看到了用指針調用函數的不同語法形式。到底怎麼回事?
4.13 通用指針類型是什麼?當我把函數指針賦向void *類型的時候,編譯通不過。
4.14 怎樣在整型和指針之間進行轉換?能否暫時把整數放入指針變量中,或者相反?
4.15 我怎樣把一個int變量轉換為char *型?我試了類型轉換,但是不行。
第5章 空指針
空指針和空指針常量
5.1 臭名昭著的空指針到底是什麼?
5.2 怎樣在程序裡獲得一個空指針?
5.3 用縮寫的指針比較“if(p)”檢查空指針是否有效?如果空指針的內部表達不是0會怎樣?
NULL 宏
5.4 NULL是什麼,它是怎麼定義的?
5.5 在使用非零位模式作為空指針的內部表示的機器上,NULL 是如何定義的?
5.6 如果NULL定義成#define NULL((char *)0) ,不就可以向函數傳入不加轉換的NULL 了嗎?
5.7 我的編譯器提供的頭文件中定義的NULL為0L。為什麼?
5.8 NULL可以合法地用作函數指針嗎?
5.9 如果NULL和0作為空指針常量是等價的,那我到底該用哪一個呢?
5.10 但是如果NULL的值改變了,比如在使用非零內部空指針的機器上,用NULL(而不是0)
不是更好嗎?
5.11 我曾經使用過一個編譯器,不使用NULL就不能編譯。
5.12 我用預處理宏#define Nullptr(type)(type *)0幫助創建正確類型的空指針。
回顧
5.13 這有點奇怪:NULL可以確保是0,但空(null)指針卻不一定?
5.14 為什麼有那麼多關於空指針的疑惑?為什麼這些問題如此頻繁地出現?
5.15 有沒有什麼簡單點兒的辦法理解所有這些與空指針有關的東西呢?
5.16 考慮到有關空指針的所有這些困惑,要求它們的內部表示都必須為0不是更簡單嗎?
5.17 說真的,真有機器用非零空指針嗎,或者不同類型用不同的表示?
地址0上到底有什麼?
5.18 運行時的整數值0轉換為指針以後一定是空指針嗎?
5.19 如何訪問位於機器地址0處的中斷向量?如果我將指針值設為0,編譯器可能會自動將它轉換為非零的空指針內部表示。
5.20 運行時的“null pointer assignment”錯誤是什麼意思?應該怎樣捕捉它?
第6章 數組和指針
數組和指針的基本關系
6.1 我在一個源文件中定義了char a[6],在另一個源文件中聲明了extern char *a。為什麼不行?
6.2 可是我聽說char a[]和char *a是等價的。是這樣的嗎?
6.3 那麼,在C語言中“指針和數組等價”到底是什麼意思?
6.4 既然它們這麼不同,那為什麼作為函數形參的數組和指針聲明可以互換呢?
數組不能被賦值
6.5 為什麼不能這樣向數組賦值?extern char *getpass(); char str[10]; str=getpass("Enter password:");
6.6 既然不能向數組賦值,那這段代碼為什麼可以呢?int f(char str[]){ if(str[0] == '\0') str="none";}
6.7 如果你不能給它賦值,那麼數組如何能成為左值呢?
回顧
6.8 現實地講,數組和指針的區別是什麼?
6.9 有人跟我講,數組不過是常指針。這樣講准確嗎?
6.10 我還是很困惑。到底指針是一種數組,還是數組是一種指針?
6.11 我看到一些“搞笑”的代碼,包含5["abcdef"]這樣的“表達式”。這為什麼是合法的C語言表達式呢?
數組的指針
6.12 既然數組引用會退化為指針,如果array是數組,那麼array和&array又有什麼區別呢?
6.13 如何聲明一個數組的指針?
動態數組分配
6.14 如何在運行時設定數組的大小?怎樣才能避免固定大小的數組?
6.15 我如何聲明大小和傳入的數組一樣的局部數組?
6.16 如何動態分配多維數組?
6.17 有個很好的竅門,如果我這樣寫:int realarray[10]; int *array = &realarray[-1]; 我就可以把“array”當作下標從1 開始的數組。
函數和多維數組
6.18 當我向一個接受指針的指針的函數傳入二維數組的時候,編譯器報錯了。
6.19 我怎樣編寫接受編譯時寬度未知的二維數組的函數?
6.20 我怎樣在函數參數傳遞時混用靜態和動態多維數組?
數組的大小
6.21 當數組是函數的參數時,為什麼sizeof不能正確報告數組的大小?
6.22 如何在一個文件中判斷聲明為extern的數組的大小(例如,數組定義和大小在另一個文件中)?sizeof操作符似乎不行。
6.23 sizeof返回的大小是以字節計算的,怎樣才能判斷數組中有多少個元素呢?
第7章 內存分配
第8章 字符和字符串
第9章 布爾表達式和變量
第10章 C預處理器
第11章 ANSI/ISO標准C
第12章 標准輸入輸出庫
第13章 庫函數
第14章 浮點運算
第15章 可變參數列表
第16 章 奇怪的問題
第17章 風格
第18章 工具和資源
第19章 系統依賴
第20章 雜項
術語表
參考文獻 
相關資源:

免責聲明:本網站內容收集於互聯網,本站不承擔任何由於內容的合法性及健康性所引起的爭議和法律責任。如果侵犯了你的權益,請通知我們,我們會及時刪除相關內容,謝謝合作! 聯系信箱:[email protected]

Copyright © 電驢下載基地 All Rights Reserved