導航:首頁 > 源碼編譯 > c加加編譯器怎麼返回刪除的文件

c加加編譯器怎麼返回刪除的文件

發布時間:2022-09-25 09:24:56

① window內自帶的C語言編譯器怎麼用

1。turbo c 比較實用的編譯器
按f10,用方向鍵選擇最左邊file,點回車鍵出現下拉菜單,選擇第一個,把裡面的內容全刪瞭然後輸入x:\(x為源文件所在盤),找到源文件,回車鍵打開。
然後再按f10,選擇run或單擊r運行,或者直接按f9編譯,編譯後的文件在turbo c 所在文件夾的 out put文件夾裡面。
2。visual c++事實上這不只是單純的編譯器,應該說是開發環境,但包含有編譯功能,直接滑鼠操作就可以了。

② C語言中如何刪除某個文本文件

在c語言中,調用文本文件有兩種情況:
1
在代碼中直接使用該文件。
這種情況,本質上是把文本文件當做頭文件來使用,而文本文件中的數據當做代碼的一部分。
比如
#include "a.txt"這時,需要保證a.txt中是合法的c語言格式。
2
在運行中調用文本文件。
可以使用c語言的文件操作函數,使用file
*fp
=
fopen("a.txt",
"r");打開文件。
然後用fscanf,
fgets,
fread,fgetc等函數進行讀取。
最終使用結束後,需要調用fclose函數關閉文件。

③ 在vc 裡面編寫了一個C語言程序,不小心刪掉了怎麼恢復

只要保存的文件都會以XXX.c存在工程的目錄下面,如果是關了可以到創建工程的目錄里找,
如果刪除了,也會跑到電腦的回收站裡面,可以去恢復,
如果回收站也清空了,就有點麻煩,不過有高人也有可能找回來,

④ c語言編譯器如何運行

編譯共分為四個階段:預處理階段、編譯階段、匯編階段、鏈接階段。

1、預處理階段:

主要工作是將頭文件插入到所寫的代碼中,生成擴展名為「.i」的文件替換原來的擴展名為「.c」的文件,但是原來的文件仍然保留,只是執行過程中的實際文件發生了改變。(這里所說的替換並不是指原來的文件被刪除)

2、匯編階段:

插入匯編語言程序,將代碼翻譯成匯編語言。編譯器首先要檢查代碼的規范性、是否有語法錯誤等,以確定代碼的實際要做的工作,在檢查無誤後,編譯器把代碼翻譯成匯編語言,同時將擴展名為「.i」的文件翻譯成擴展名為「.s」的文件。

3、編譯階段:

將匯編語言翻譯成機器語言指令,並將指令打包封存成可重定位目標程序的格式,將擴展名為「.s」的文件翻譯成擴展名為「.o」的二進制文件。

4、鏈接階段:

在示例代碼中,改代碼文件調用了標准庫中printf函數。而printf函數的實際存儲位置是一個單獨編譯的目標文件(編譯的結果也是擴展名為「.o」的文件),所以此時主函數調用的時候,需要將該文件(即printf函數所在的編譯文件)與hello world文件整合到一起,此時鏈接器就可以大顯神通了,將兩個文件合並後生成一個可執行目標文件。

⑤ c語言程序如何找回main.c文件

C語文程序中必須有main()函數。

C的設計原則是把函數作為程序的構成模塊。main()函數稱之為主函數,一個C程序總是從main()函數開始執行的。

一、main()函數的形式
在最新的 C99 標准中,只有以下兩種定義方式是正確的:

int main( void ) /* 無參數形式 */
{
...
return 0;
}

int main( int argc, char *argv[] ) /* 帶參數形式 */

{
...
return 0;
}
int指明了main()函數的返回類型,函數名後面的圓括弧一般包含傳遞給函數的信息。void表示沒有給函數傳遞參數。關於帶參數的形式,我們等會討論。

瀏覽老版本的C代碼,將會發現程序常常以main()這種形式開始。C90標准允許這種形式,但是C99標准不允許。因此即使你當前的編譯器允許,也不要這么寫。

你還可能看到過另一種形式。
void main()

有些編譯器允許這種形式,但是還沒有任何標准考慮接受它。C++ 之父 Bjarne Stroustrup 在他的主頁上的 FAQ 中明確地表示:void main( ) 的定義從來就不存在於 C++ 或者 C 。所以,編譯器不必接受這種形式,並且很多編譯器也不允許這么寫。
堅持使用標準的意義在於:當你把程序從一個編譯器移到另一個編譯器時,照樣能正常運行。

二、main()函數的返回值
從前面我們知道main()函數的返回值類型是int型的,而程序最後的 return 0; 正與之遙相呼應,0就是main()函數的返回值。那麼這個0返回到那裡呢?返回給操作系統,表示程序正常退出。因為return語句通常寫在程序的最後,不管返回什麼值,只要到達這一步,說明程序已經運行完畢。而return的作用不僅在於返回一個值,還在於結束函數。

現在我們來做一個小試驗來觀察main()函數的返回值。編寫如下代碼並編譯運行:
//a.c
#include "stdio.h"
int main(void)
{
printf("I love you.");
return 0;
}
將這個文件保存為a.c,編譯運行後會生成一個a.exe文件。現在打開命令提示符,在命令行里運行剛才編譯好的可執行文件,然後輸入 echo %ERRORLEVEL% ,回車,就可以看到程序返回 一個0 。如果把 return 0; 改為 return 99; ,那麼很顯然,再次執行上述步驟以後你可以看到程序返回99。要是你這樣寫 return 99.99; 那還是返回99,因為99.99被傳給操作系統之前,被強制類型轉換成整數類型了。

現在,我們把a.c改回原來的代碼,然後再編寫另一個程序b.c:
//b.c

#include "stdio.h"
int main(void)
{
printf("I』m too.");
return 0;
}
編譯運行後打開命令提示符,在命令行里輸入a&&b 回車,這樣你就可以看到《人鬼情未了》裡面經典的愛情對白:
I love you.

I』m too.

&& 的含義是:如果 && 前面的程序正常退出,則繼續執行 && 後面的程序,否則不執行。所以,要是把a.c裡面的 return 0; 刪除或者改為 return 99; ,那麼你只能看到 I love you. 。也就是說,程序b.c就不執行了。現在,大家該明白 return 0; 的作用了吧。

三、main()函數的參數
C編譯器允許main()函數沒有參數,或者有兩個參數(有些實現允許更多的參數,但這只是對標準的擴展)。這兩個參數,一個是int類型,一個是字元串類型。第一個參數是命令行中的字元串數。按照慣例(但不是必須的),這個int參數被稱為argc(argument count)。大家或許現在才明白這個形參為什麼要取這么個奇怪的名字吧,呵呵!至於英文的意思,自己查字典吧。第二個參數是一個指向字元串的指針數組。命令行中的每個字元串被存儲到內存中,並且分配一個指針指向它。按照慣例,這個指針數組被稱為argv(argument value)。系統使用空格把各個字元串格開。一般情況下,把程序本身的名字賦值給argv[0],接著,把最後的第一個字元串賦給argv[1],等等。

現在我們來看一個例子:

//c.c

#include "stdio.h"
int main(int argc, char *argv[])
{
int count;
printf("The command line has %d arguments:
", argc - 1);
for(count = 1; count < argc; count++)
printf("%d: %s
", count, argv[count]);
return 0;
}
編譯運行,在命令行輸入c I love you 回車,下面是從命令行運行該程序的結果:

The command line has 3 arguments:

1:I

2:love

3:you

從本例可以看出,程序從命令行中接受到4個字元串(包括程序名),並將它們存放在字元串數組中,其對應關系:

argv[0] ------> c(程序名)

argv[1] ------> I

argv[2] ------> love

argv[3] ------> you

至於argc的值,也即是參數的個數,程序在運行時會自動統計,不必我們操心。

這個例子中,每個字元串都時一個單詞(字母),那既然是字元串,要把一句話當作參數賦給程序該怎麼辦?你可以在命令行里這樣輸入 c "I love you." "I』m too."。程序運行結果:

The command line has 2 arguments:

1:I love you.

2:I』m too.

其對應關系:

argv[0] ------> c(程序名)

argv[1] ------> I love you.

argv[2] ------> I』m too.

要注意的是,你在命令行的輸入都將作為字元串形式存儲於內存中。也就是說,如果你輸入一個數字,那麼要輸出這個數字,你應該用%s格式而非%d或者其他。

再來看一個例子:

//d.c
#include "stdio.h"
int main(int argc, char *argv[])
{
FILE *fp;
fp = fopen(argv[1], "w");
fputs("I love you.", fp);
fclose(fp);
return 0;
}

⑥ 我的c編譯器里保存的文件太多了,怎樣刪除(刪除一些。obj exe文件和一些原來寫錯了的文件)

現在還有這個軟體編譯嗎?暈怎麼不要VC++6.0呢
找到保存的路徑 去直接刪除不久OK了

⑦ C語言如何從文件中選中一項進行刪除後將剩餘項全部保存進原文件

1打開文件

2讀取每一行

3如果已經是最後一行 則轉到7步驟退出 否則執行第4步驟

4匹配名字

5如果匹配不陳功 重復第2步驟

6匹配成功,刪除這一行或者在這一行寫空數據替換,並將結構嚴謹的其他欄位所在的行也刪除或者用空數據替換掉

7退出

⑧ 如何用C語言創建和刪除文件

一、創建文件:

在C語言中創建文件,使用fopen函數,同時指定為只寫即可。

參考代碼如下:

/*
函數功能:創建文件名為s的文件。
返回值:
-1參數錯誤
0創建成功
1文件已存在
2創建失敗
*/
intcreate_file(char*s)
{
FILE*fp;
if(s==NULL||s[0]=='')return-1;//參數為空,即錯誤參數。
fp=fopen(s,"r");//以只讀方式打開
if(fp)//打開成功,表示文件已經存在。
{
fclose(fp);//關閉文件
return1;//返迴文件已存在。
}
fp=fopen(s,"w");//以只寫方式創建文件。
if(fp==NULL)
return2;//創建失敗。
fclose(fp);//關閉文件。
return0;//創建成功。
}

二、刪除文件:

在C語言中,有專門的刪除文件函數remove。

1、頭文件:stdio.h

2、聲明:int remove(const char* filename);

3、功能:刪除文件名為filename的文件。

4、返回值:刪除成功,返回0.否則返回-1.

5、示例代碼:

#include<stdio.h>
intmain()
{
chars[100];
intret;
scanf("%s",s);//輸入文件名。
ret=remove(s);//刪除文件
if(ret==0)//根據結果給出相應提示
printf("刪除文件成功 ");
else
printf("刪除文件失敗 ");
return0;
}

⑨ c++怎麼實現查找一個文件,並刪除找到的文件

你好 通常有兩種方式:
1.使用文件指針(文件標識符)。

您可以參考資料:
http://blog.csdn.net/zhu777/archive/2007/11/03/1865314.aspx

2.使用文件讀取類:(建議使用效率略低,使用簡單)

在C++中,有一個stream這個類,所有的I/O都以這個「流」類為基礎的,包括我們要認識的文件I/O,stream這個類有兩個重要的運算符:
1、插入器(<<)
向流輸出數據。比如說系統有一個默認的標准輸出流(cout),一般情況下就是指的顯示器,所以,cout<<"Write Stdout"<<'n';就表示把字元串"Write Stdout"和換行字元('n')輸出到標准輸出流。
2、析取器(>>)
從流中輸入數據。比如說系統有一個默認的標准輸入流(cin),一般情況下就是指的鍵盤,所以,cin>>x;就表示從標准輸入流中讀取一個指定類型(即變數x的類型)的數據。
在C++中,對文件的操作是通過stream的子類fstream(file stream)來實現的,所以,要用這種方式操作文件,就必須加入頭文件fstream.h。下面就把此類的文件操作過程一一道來。
一、打開文件
在fstream類中,有一個成員函數open(),就是用來打開文件的,其原型是:
void open(const char* filename,int mode,int access);
參數:
filename: 要打開的文件名
mode: 要打開文件的方式
access: 打開文件的屬性
打開文件的方式在類ios(是所有流式I/O類的基類)中定義,常用的值如下:
ios::app: 以追加的方式打開文件
ios::ate: 文件打開後定位到文件尾,ios:app就包含有此屬性
ios::binary: 以二進制方式打開文件,預設的方式是文本方式。兩種方式的區別見前文
ios::in: 文件以輸入方式打開
ios::out: 文件以輸出方式打開
ios::nocreate: 不建立文件,所以文件不存在時打開失敗
ios::noreplace:不覆蓋文件,所以打開文件時如果文件存在失敗
ios::trunc: 如果文件存在,把文件長度設為0
可以用「或」把以上屬性連接起來,如ios::out|ios::binary
// 註:現在C++標准庫不支持nocreate和noreplace,以前的舊版本可以用.
打開文件的屬性取值是:
0:普通文件,打開訪問
1:只讀文件
2:隱含文件
4:系統文件
可以用「或」或者「+」把以上屬性連接起來 ,如3或1|2就是以只讀和隱含屬性打開文件。
例如:以二進制輸入方式打開文件c:config.sys
fstream file1;
file1.open("c:config.sys",ios::binary|ios::in,0);
如果open函數只有文件名一個參數,則是以讀/寫普通文件打開,即:
file1.open("c:config.sys");<=>file1.open("c:config.sys",ios::in|ios::out,0);
另外,fstream還有和open()一樣的構造函數,對於上例,在定義的時候就可以打開文件了:
fstream file1("c:config.sys");
特別提出的是,fstream有兩個子類:ifstream(input file stream)和ofstream(outpu file stream),ifstream默認以輸入方式打開文件,而ofstream默認以輸出方式打開文件。
ifstream file2("c:pdos.def");//以輸入方式打開文件
ofstream file3("c:x.123");//以輸出方式打開文件
所以,在實際應用中,根據需要的不同,選擇不同的類來定義:如果想以輸入方式打開,就用ifstream來定義;如果想以輸出方式打開,就用ofstream來定義;如果想以輸入/輸出方式來打開,就用fstream來定義。
二、關閉文件
打開的文件使用完成後一定要關閉,fstream提供了成員函數close()來完成此操作,如:file1.close();就把file1相連的文件關閉。
三、讀寫文件
讀寫文件分為文本文件和二進制文件的讀取,對於文本文件的讀取比較簡單,用插入器和析取器就可以了;而對於二進制的讀取就要復雜些,下要就詳細的介紹這兩種方式
1、文本文件的讀寫
文本文件的讀寫很簡單:用插入器(<<)向文件輸出;用析取器(>>)從文件輸入。假設file1是以輸入方式打開,file2以輸出打開。示例如下:
file2<<"I Love You";//向文件寫入字元串"I Love You"
int i;
file1>>i;//從文件輸入一個整數值。
這種方式還有一種簡單的格式化能力,比如可以指定輸出為16進制等等,具體的格式有以下一些
操縱符 功能 輸入/輸出
dec 格式化為十進制數值數據 輸入和輸出
endl 輸出一個換行符並刷新此流 輸出
ends 輸出一個空字元 輸出
hex 格式化為十六進制數值數據 輸入和輸出
oct 格式化為八進制數值數據 輸入和輸出
//setpxecision(int p) 設置浮點數的精度位數 輸出
setprecision(int p) 設置浮點數的精度位數 輸出
(setpxecision應該為setprecision,使用時需要包含頭文件:#include <iomanip.h>)
//比如要把123當作十六進制輸出:file1<<hex<<123;要把3.1415926以5位精度輸出:file1<<setpxecision(5)<<3.1415926。
比如要把123當作十六進制輸出:file1<<hex<<123;要把3.1415926以5位精度輸出:file1<<setprecision(5)<<3.1415926。
2、二進制文件的讀寫
①put()
put()函數向流寫入一個字元,其原型是ofstream &put(char ch),使用也比較簡單,如file1.put('c');就是向流寫一個字元'c'。
②get()
get()函數比較靈活,有3種常用的重載形式:
一種就是和put()對應的形式:ifstream &get(char &ch);功能是從流中讀取一個字元,結果保存在引用ch中,如果到文件尾,返回空字元。如file2.get(x);表示從文件中讀取一個字元,並把讀取的字元保存在x中。
另一種重載形式的原型是: int get();這種形式是從流中返回一個字元,如果到達文件尾,返回EOF,如x=file2.get();和上例功能是一樣的。
還有一種形式的原型是:ifstream &get(char *buf,int num,char delim='n');這種形式把字元讀入由 buf 指向的數組,直到讀入了 num 個字元或遇到了由 delim 指定的字元,如果沒使用 delim 這個參數,將使用預設值換行符'n'。例如:
file2.get(str1,127,'A');//從文件中讀取字元到字元串str1,當遇到字元'A'或讀取了127個字元時終止。
③讀寫數據塊
要讀寫二進制數據塊,使用成員函數read()()和write()成員函數,它們原型如下:
read()(unsigned char *buf,int num);
write(const unsigned char *buf,int num);
read()()從文件中讀取 num 個字元到 buf 指向的緩存中,如果在還未讀入 num 個字元時就到了文件尾,可以用成員函數 int gcount();來取得實際讀取的字元數;而 write() 從buf 指向的緩存寫 num 個字元到文件中,值得注意的是緩存的類型是 unsigned char *,有時可能需要類型轉換。
例:
unsigned char str1[]="I Love You";
int n[5];
ifstream in("xxx.xxx");
ofstream out("yyy.yyy");
out.write(str1,strlen(str1));//把字元串str1全部寫到yyy.yyy中
in.read((unsigned char*)n,sizeof(n));//從xxx.xxx中讀取指定個整數,注意類型轉換
in.close();out.close();
四、檢測EOF
成員函數eof()用來檢測是否到達文件尾,如果到達文件尾返回非0值,否則返回0。原型是int eof();
例: if(in.eof())ShowMessage("已經到達文件尾!");
五、文件定位
和C的文件操作方式不同的是,C++ I/O系統管理兩個與一個文件相聯系的指針。一個是讀指針,它說明輸入操作在文件中的位置;另一個是寫指針,它下次寫操作的位置。每次執行輸入或輸出時,相應的指針自動變化。所以,C++的文件定位分為讀位置和寫位置的定位,對應的成員函數是 seekg()和 seekp(),seekg()是設置讀位置,seekp是設置寫位置。它們最通用的形式如下:
istream &seekg(streamoff offset,seek_dir origin);
ostream &seekp(streamoff offset,seek_dir origin);
streamoff定義於 iostream.h 中,定義有偏移量 offset 所能取得的最大值,seek_dir 表示移動的基準位置,是一個有以下值的枚舉:
ios::beg: 文件開頭
ios::cur: 文件當前位置
ios::end: 文件結尾
這兩個函數一般用於二進制文件,因為文本文件會因為系統對字元的解釋而可能與預想的值不同。
例:
file1.seekg(1234,ios::cur);//把文件的讀指針從當前位置向後移1234個位元組
file2.seekp(1234,ios::beg);//把文件的寫指針從文件開頭向後移1234個位元組
如果vc編程的話最好使用CFile類等更加方便於文件操作</CA>

刪除文件的函數是
BOOL DeleteFile(
LPCTSTR lpFileName // 參數是文件名
)
返回值是BOOL值TRUE表示刪除成功,FALSE表示刪除失敗

⑩ c語言怎樣刪除文件

首先要說明的是這里並不是指刪除C編譯器裡面的文件,呵呵,如果只是要刪除那些文件的話,那就很簡單,直接選中文件後按delete鍵就可以刪除了,但是我們刪除那些文件幹嘛?我們還要用它寫程序啊,呵呵。我在這里要說的是,怎樣使用C語言編寫程序來刪除文件。

在C語言中,我們可以使用remove()函數來刪除指定的文件,具體語法為:
Int remove(char *filename);其中filename是一個指向字元串的指針,該字元串可以組成有效的文件名,也可以包含路徑說明。如果我們要刪除D盤下的ABC.txt文件,我們就可以這樣寫:remove(「D:\ABC.txt」);

閱讀全文

與c加加編譯器怎麼返回刪除的文件相關的資料

熱點內容
現在的壓縮包都是加密 瀏覽:329
施工員找工作去哪個app 瀏覽:630
安卓手機的游戲怎麼打開 瀏覽:198
pdf掃描轉文字 瀏覽:532
微機室裡面的雲伺服器 瀏覽:108
excel能編程嗎 瀏覽:931
android系統框架的介紹 瀏覽:947
無盤系統伺服器如何配置 瀏覽:836
背負貸款如何緩解壓力 瀏覽:82
linux獲取日期時間 瀏覽:881
搬磚問題最合適的演算法 瀏覽:446
小米安卓機密碼忘記了如何解鎖 瀏覽:910
產電plc編程手冊 瀏覽:761
vscodephp 瀏覽:535
阿里雲linux桌面 瀏覽:754
php二維數組搜索 瀏覽:116
ps快捷命令工具箱 瀏覽:253
c4d教程pdf 瀏覽:462
linux集群安裝配置 瀏覽:154
stc單片機介紹 瀏覽:902