⑴ c語言中,再對文件的操作模式中,a和a+、w和w+、r和r+有什麼區別
- r 打開只讀文件,該文件必須存在。r+ 打開可讀寫的文件,該文件必須存在。 
- w 打開只寫文件,若文件存在則文件長度清為0,即該文件內容會消失。若文件不存在則建立該文件。w+ 打開可讀寫文件,若文件存在則文件長度清為零,即該文件內容會消失。若文件不存在則建立該文件。 
- a 以附加的方式打開只寫文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾,即文件原先的內容會被保留。a+ 以附加方式打開可讀寫的文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾後,即文件原先的內容會被保留。 
⑵ C語言文件中,「rb」和「r」有什麼區別
一、作用不同
1、rb:代表二進制文件,用來讀寫二進制文件。
2、r:代表文本文件,用來讀寫文本文件。
二、特點不同
1、rb:文件編碼是變長的,靈活利用率要高,而解碼要難一些,不同的二進制文件解碼方式是不同的。
2、r:是一種典型的順序文件,其文件的邏輯結構又屬於流式文件。

三、優劣不同
1、rb:二進制文件比較節約空間,這兩者儲存字元型數據時並沒有差別。但是在儲存數字,特別是實型數字時,二進制更節省空間。
2、r:文本文件存在於計算機系統中,通常在文本文件最後一行放置文件結束標志。文本文件的編碼基於字元定長,解碼相對要容易一些。
⑶ fopen中的"r"和"rt"("w"和"wt")有沒有區別
fopen中的」r「和」rt「,」w「和」wt「有區別的。
」r「是打開文件用於只讀,一般預設狀態下是二進制格式。
」rt「是打開文件以文本格式讀。
」w「是打開文件用戶寫入,一般預設時以二進制格式寫入。
」wt「是打開文件以文本格式寫入。
⑷ C語言代碼的頭文件與源文件有什麼區別
- 頭文件和源文件在本質上沒有任何區別。 只不過一般:後綴為 .h 的文件是頭文件,內含函數聲明、宏定義、結構體定義等內容。後綴為 .c 的文件是源文件,內含函數實現,變數定義等內容。而且是什麼後綴也沒有關系,只不過編譯器會默認對某些後綴的文件採取某些動作。這樣分開寫成兩個文件是一個良好的編程風格。 
- 簡單的說其實要理解C文件與頭文件(即.h)有什麼不同之處,首先需要弄明白編譯器的工作過程,一般說來編譯器會做以下幾個過程: 
①預處理階段
②詞法與語法分析階段
③ 編譯階段,首先編譯成純匯編語句,再將之匯編成跟CPU相關的二進制碼,生成各 個目標文件 (.obj文件)
④連接階段,將各個目標文件中的各段代碼進行絕對地址定位,生成跟特定平台相關 的可執行文件,當然,最後還可以用obj生成純二進制碼,也就是去掉了文件格 式信 息。(生成.exe文件)
3.比方說 在aaa.h里定義了一個函數的聲明,然後在aaa.h的同一個目錄下建立aaa.c , aaa.c里定義了這個函數的實現,然後是在main函數所在.c文件里#include這個aaa.h 然後我就可以使用這個函數了。 main在運行時就會找到這個定義了這個函數的aaa.c文件。這是因為:main函數為標准C/C++的程序入口,編譯器會先找到該函數所在的文件。假定編譯程序編譯myproj.c(其中含main())時,發現它include了mylib.h(其中聲明了函數void test()),那麼此時編譯器將按照事先設定的路徑(Include路徑列表及代碼文件所在的路徑)查找與之同名的實現文件(擴展名為.cpp或.c,此例中為mylib.c),如果找到該文件,並在其中找到該函數(此例中為void test())的實現代碼,則繼續編譯;如果在指定目錄找不到實現文件,或者在該文件及後續的各include文件中未找到實現代碼,則返回一個編譯錯誤.其實include的過程完全可以「看成」是一個文件拼接的過程,將聲明和實現分別寫在頭文件及C文件中,或者將二者同時寫在頭文件中,理論上沒有本質的區別。以上是所謂動態方式。對於靜態方式,基本所有的C/C++編譯器都支持一種鏈接方式被稱為Static Link,即所謂靜態鏈接。在這種方式下,我們所要做的,就是寫出包含函數,類等等聲明的頭文件(a.h,b.h,...),以及他們對應的實現文件(a.cpp,b.cpp,...),編譯程序會將其編譯為靜態的庫文件(a.lib,b.lib,...)。在隨後的代碼重用過程中,我們只需要提供相應的頭文件(.h)和相應的庫文件(.lib),就可以使用過去的代碼了。相對動態方式而言,靜態方式的好處是實現代碼的隱蔽性,即C++中提倡的「介面對外,實現代碼不可見」。有利於庫文件的轉發.
⑸ C語言里的.h和.c文件有什麼區別呢
.h
文件叫頭文件,
和你說的.C文件算是一樣的都是程序吧,
.H文件是人家給寫的的能執行一定函數的文件,你可以在自己寫的.c文件裡面調用他。叫頭文件。
⑹ c語言中的模塊和文件有什麼區別
模塊是概念上的意思, 一般將實現該模塊的文件放在一起
文件只是實現模塊的函數的集合
⑺ C語言中文本文件 和 二進制文件 流的區別(
文本文件 和 二進制文件(不是包括流)的聯系與區別:文本文件是直接在系統上顯示為文本的文件,但在儲存時,是以位元組(二進制的8位)形式保存的。如果普通的二進制文件使用系統顯示為文本文件,通常是看不懂的亂碼文本,當中的原由是文本文件是按照編碼規則編碼的二進制文件,而沒有編碼的二進制文件顯示文本文件肯定是亂碼的。
⑻ 有誰能給我講一下C語言文件操作rt和rt+的區別,看一下這個程序
- r 讀取, t 文本文件,+ 可更新文件內容 
- mode 
- C string containing a file access mode. It can be: - "r" read:Open file for input operations. The file must exist. - "w" write:Create an empty file for output operations. If a file with the same name already exists, its contents are discarded and the file is treated as a new empty file. - "a" append:Open file for output at the end of a file. Output operations always write data at the end of the file, expanding it. Repositioning operations (fseek,fsetpos,rewind) are ignored. The file is created if it does not exist. - "r+" read/update:Open a file for update (both for input and output). The file must exist. - "w+" write/update:Create an empty file and open it for update (both for input and output). If a file with the same name already exists its contents are discarded and the file is treated as a new empty file. - "a+" append/update:Open a file for update (both for input and output) with all output operations writing data at the end of the file. Repositioning operations (fseek,fsetpos,rewind) affects the next input operations, but output operations move the position back to the end of file. The file is created if it does not exist. - With themodespecifiers above the file is open as atext file. In order to open a file as abinary file, a"b"character has to be included in themodestring. This additional"b"character can either be appended at the end of the string (thus making the following compound modes: "rb", "wb", "ab", "r+b", "w+b", "a+b") or be inserted between the letter and the"+"sign for the mixed modes ("rb+", "wb+", "ab+"). 
 The new C standard (C2011, which is not part of C++) adds a new standard subspecifier ("x"), that can be appended to any"w"specifier (to form"wx","wbx","w+x"or"w+bx"/"wb+x"). This subspecifier forces the function to fail if the file exists, instead of overwriting it.
 If additional characters follow the sequence, the behavior depends on the library implementation: some implementations may ignore additional characters so that for example an additional"t"(sometimes used to explicitly state atext file) is accepted.
 On some library implementations, opening or creating a text file with update mode may treat the stream instead as a binary file.
- Text filesare files containing sequences of lines of text. Depending on the environment where the application runs, some special character conversion may occur in input/output operations intext modeto adapt them to a system-specific text file format. Although on some environments no conversions occur and bothtext filesandbinary filesare treated the same way, using the appropriate mode improves portability.
- For files open for update (those which include a"+"sign), on which both input and output operations are allowed, the stream shall be flushed (fflush) or repositioned (fseek,fsetpos,rewind) before a reading operation that follows a writing operation. The stream shall be repositioned (fseek,fsetpos,rewind) before a writing operation that follows a reading operation (whenever that operation did not reach the end-of-file).
⑼ C語言中文件部分a+和r+有什麼區別書上寫的都是為了讀寫打開一個文本文件
a+ 是讀寫,寫的方式是追加,不刪除原來的內容。
r+ 是讀寫,從文件頭開始寫,會覆蓋原來的內容。
⑽ C語言文件r和rt區別
\r是回車符,\n是換行符
計算機還沒有出現之前,有一種叫做電傳打字機(teletype
model
33)的玩意,每秒鍾可以打10個字元。但是它有一個問題,就是打完一行換行的時候,要用去0.2秒,正好可以打兩個字元。要是在這0.2秒裡面,又有新的字元傳過來,那麼這個字元將丟失。
於是,研製人員想了個辦法解決這個問題,就是在每行後面加兩個表示結束的字元。一個叫做「回車」,告訴打字機把列印頭定位在左邊界;另一個叫做「換行」,告訴打字機把紙向下移一行。
這就是「換行」和「回車」的來歷,從它們的英語名字上也可以看出一二。
後來,計算機發明了,這兩個概念也就被般到了計算機上。那時,存儲器很貴,一些科學家認為在每行結尾加兩個字元太浪費了,加一個就可以。於是,就出現了分歧。unix
系統里,每行結尾只有「」,即「\n」;windows系統裡面,每行結尾是「」,即「
\r\n」;mac系統里,每行結尾是「」。一個直接後果是,unix/mac系統下的文件在windows里打開的話,所有文字會變成一行;而windows里的文件在unix/mac下打開的話,在每行的結尾可能會多出一個^m符號。
