當前位置:首頁 » 編程語言 » c語言庫函數doc
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言庫函數doc

發布時間: 2022-10-09 21:07:33

『壹』 c語言 清屏函數

#include <stdio.h>

#include <windows.h>

printf("請輸入游標位置(x,y)用逗號隔開/n");

scanf("%d,%d",&x,&y);

GoToXY(x,y);

printf("x=%d,y=%d",x,y);

scanf("%d",&x);}

void GoToXY(int x, int y)

{COORD pos = {x,y}; //設置游標位置

HANDLE hOut = GetStdHandle(STD_OUTPUT_HANDLE); // 獲取標准輸出設備句柄

SetConsoleCursorPosition(hOut, pos);

函數說明

system()會調用fork()產生子進程,由子進程來調用/bin/sh-c string來執行參數string字元串所代表的命令,此命令執行完後隨即返回原調用的進程。在調用system()期間SIGCHLD 信號會被暫時擱置,SIGINT和SIGQUIT 信號則會被忽略。

如果fork()失敗 返回-1:出現錯誤

如果exec()失敗,表示不能執行Shell,返回值相當於Shell執行了exit(127)

如果執行成功則返回子Shell的終止狀態

以上內容參考:網路-system

『貳』 c語言上機練習題doc

main()
{
int a[20],i,j=0,sum=0,*p;
p=a;
for(i=0;i<20;i++)
{
scanf("%d",p+i);
if(*(p+i)%2==0) sum+=*(p+i);
}
printf(" \n偶數和是%d\n",*(p+i));
for(i=0;i<20;i++)
{
printf(" %d\t",*(p+i));
j++;
if(j%5==0)
printf("\n");
}
}

『叄』 用C語言讀取xml文件,怎麼實現

我上次才給人寫過
xml文件內容

<?xmlversion="1.0"encoding="UTF-8"?>
-<aicomoa_response>
-<country_list>
-<country>
<id>7</id>
<pid>0</pid>
<continent_id>1</continent_id>
<guohao>93</guohao>
<cntitle>阿富汗</cntitle>
<entitle>Afghanistan</entitle>
<hztitle>阿富汗</hztitle>
<jptitle>アフガニスタン</jptitle>
<kotitle>??????</kotitle>
<jp_pinyin>ア</jp_pinyin>
<pinyin>AFuHan</pinyin>
<sid>0</sid>
<jibie>1</jibie>
</country>
-<country>
<id>8</id>
<pid>0</pid>
<continent_id>2</continent_id>
<guohao>355</guohao>
<cntitle>阿爾巴尼亞</cntitle>
<entitle>Albania</entitle>
<hztitle>阿爾巴尼亞</hztitle>
<jptitle>アルバニア</jptitle>
<kotitle/>
<jp_pinyin>ア</jp_pinyin>
<pinyin>AErBaNiYa</pinyin>
<sid>0</sid>
<jibie>1</jibie>
</country>
</country_list>
</aicomoa_response>

運行結果

Info[0]=[id:7|pid:0|continent_id:1|guohao:93|cntitle:阿富汗|entitle:Afghanistan|
hztitle:阿富汗|jptitle:アフガニスタン|kotitle:??????|jp_pinyin:ア|pinyin:AFuHan|
sid:0|jibie:1|]
Info[1]=[id:7|pid:0|continent_id:1|guohao:93|cntitle:阿富汗|entitle:Afghanistan|
hztitle:阿富汗|jptitle:アフガニスタン|kotitle:??????|jp_pinyin:ア|pinyin:AFuHan|
sid:0|jibie:1|]
Pressanykeytocontinue

代碼

#include<stdio.h>
#include<string.h>
main()
{
inti=0;
FILE*fp;
charszFileBuff[1024]={0},szBuff[100][1024];
charid[10]={0},pid[10]={0},continent_id[10]={0},guohao[10]={0},
cntitle[64]={0},entitle[64]={0},hztitle[64]={0},jptitle[64]={0},
kotitle[64]={0},jp_pinyin[64]={0},pinyin[64]={0},sid[10]={0},jibie[10]={0};
char*lFirst,*lEnd;

fp=fopen("country.txt","r");
if(fp==NULL)
{
printf("readXMLfileerror! ");
}
while(fgets(szFileBuff,1023,fp))
{
if((lFirst=strstr(szFileBuff,"<id>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</id>");
memcpy(id,lFirst+4,lEnd-lFirst-4);
}
if((lFirst=strstr(szFileBuff,"<pid>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</pid>");
memcpy(pid,lFirst+5,lEnd-lFirst-5);
}
if((lFirst=strstr(szFileBuff,"<continent_id>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</continent_id>");
memcpy(continent_id,lFirst+14,lEnd-lFirst-14);
}
if((lFirst=strstr(szFileBuff,"<guohao>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</guohao>");
memcpy(guohao,lFirst+8,lEnd-lFirst-8);
}
if((lFirst=strstr(szFileBuff,"<cntitle>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</cntitle>");
memcpy(cntitle,lFirst+9,lEnd-lFirst-9);
}
if((lFirst=strstr(szFileBuff,"<entitle>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</entitle>");
memcpy(entitle,lFirst+9,lEnd-lFirst-9);
}
if((lFirst=strstr(szFileBuff,"<hztitle>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</hztitle>");
memcpy(hztitle,lFirst+9,lEnd-lFirst-9);
}
if((lFirst=strstr(szFileBuff,"<jptitle>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</jptitle>");
memcpy(jptitle,lFirst+9,lEnd-lFirst-9);
}
if((lFirst=strstr(szFileBuff,"<kotitle>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</kotitle>");
memcpy(kotitle,lFirst+9,lEnd-lFirst-9);
}
if((lFirst=strstr(szFileBuff,"<jp_pinyin>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</jp_pinyin>");
memcpy(jp_pinyin,lFirst+11,lEnd-lFirst-11);
}
if((lFirst=strstr(szFileBuff,"<pinyin>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</pinyin>");
memcpy(pinyin,lFirst+8,lEnd-lFirst-8);
}
if((lFirst=strstr(szFileBuff,"<sid>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</sid>");
memcpy(sid,lFirst+5,lEnd-lFirst-5);
}
if((lFirst=strstr(szFileBuff,"<jibie>"))!=NULL)
{
lEnd=strstr(lFirst+1,"</jibie>");
memcpy(jibie,lFirst+7,lEnd-lFirst-7);
}
if((lFirst=strstr(szFileBuff,"</country>"))!=NULL)
{
sprintf(szBuff[i],"id:%s|pid:%s|continent_id:%s|guohao:%s|cntitle:%s|entitle:%s|hztitle:%s|jptitle:%s|kotitle:%s|jp_pinyin:%s|pinyin:%s|sid:%s|jibie:%s|",
id,pid,continent_id,guohao,cntitle,entitle,hztitle,jptitle,kotitle,jp_pinyin,pinyin,sid,jibie);
printf("Info[%d]=[%s] ",i++,szBuff);
}
}
fclose(fp);
}

『肆』 C語言怎麼使用動態鏈接庫,如何創建(高手進)

C程序編譯成dll文件只不過是在要公開的介面函數聲明前面加上幾個特定的修飾符而已。用dev-cpp建了個dll的默認文檔,一切都很明了。(我把源代碼貼在下面)

/*dll.h文件*/

#ifndef _DLL_H_
#define _DLL_H_

#if BUILDING_DLL
# define DLLIMPORT __declspec (dllexport)
#else /* Not BUILDING_DLL */
# define DLLIMPORT __declspec (dllimport)
#endif /* Not BUILDING_DLL */

DLLIMPORT void HelloWorld (void);

#endif /* _DLL_H_ */

/*dllmain.c文件*/

/* Replace "dll.h" with the name of your header */
#include "dll.h"
#include <windows.h>
#include <stdio.h>
#include <stdlib.h>

DLLIMPORT void HelloWorld ()
{
MessageBox (0, "Hello World from DLL!\n", "Hi", MB_ICONINFORMATION);
}

BOOL APIENTRY DllMain (HINSTANCE hInst /* Library instance handle. */ ,
DWORD reason /* Reason this function is being called. */ ,
LPVOID reserved /* Not used. */ )
{
switch (reason)
{
case DLL_PROCESS_ATTACH:
break;

case DLL_PROCESS_DETACH:
break;

case DLL_THREAD_ATTACH:
break;

case DLL_THREAD_DETACH:
break;
}

/* Returns TRUE on success, FALSE on failure */
return TRUE;
}

關於以上代碼的幾點解釋:
一、__declspec (dllexport):這是關鍵,它標志著這個這個函數將成為對外的介面。(以下是我在網上下載的dllexport、dllimport、_declspec的一些說明):
使用包含在DLL的函數,必須將其導入。導入操作時通過dllimport來完成的,dllexport和dllimport都是vc(visual C++)和bc(Borland C++)所支持的擴展的關鍵字。但是dllexport和dllimport關鍵字不能被自身所使用,因此它的前面必須有另一個擴展關鍵字__declspec。通用格式如下:__declspec(specifier)其中specifier是存儲類標示符。對於DLL,specifier將是dllexport和dllimport。而且為了簡化說明導入和導出函數的語句,用一個宏名來代替__declspec.在此程序中,使用的是DllExport。如果用戶的DLL被編譯成一個C++程序,而且希望C程序也能使用它,就需要增加「C」的連接說明。#define DllExport extern "C"__declspec(dllexport),這樣就避免了標准C++命名損壞。(當然,如果讀者正在編譯的是C程序,就不要加入extern 「C」,因為不需要它,而且編譯器也不接受它)。

二、BOOL APIENTRY DllMain ()說明:(以下是我在網上收集的資料)

1、每一個DLL必須有一個入口點,DllMain是一個預設的入口函數。DllMain負責初始化(Initialization)和結束(Termination)工作,每當一個新的進程或者該進程的新的線程訪問DLL時,或者訪問DLL的每一個進程或者線程不再使用DLL或者結束時,都會調用DllMain。但是,使用TerminateProcess或TerminateThread結束進程或者線程,不會調用DllMain。
DllMain的函數原型:
BOOL APIENTRY DllMain(HANDLE hMole,DWORD ul_reason_for_call,LPVOID lpReserved)
{
switch(ul_reason_for_call)
{
case DLL_PROCESS_ATTACH:
.......
case DLL_THREAD_ATTACH:
.......
case DLL_THREAD_DETACH:
.......
case DLL_PROCESS_DETACH:
.......
return TRUE;
}
}

參數:
hMoudle:是動態庫被調用時所傳遞來的一個指向自己的句柄(實際上,它是指向_DGROUP段的一個選擇符);
ul_reason_for_call:是一個說明動態庫被調原因的標志。當進程或線程裝入或卸載動態連接庫的時候,操作系統調用入口函數,並說明動態連接庫被調用的原因。它所有的可能值為:
DLL_PROCESS_ATTACH: 進程被調用;
DLL_THREAD_ATTACH: 線程被調用;
DLL_PROCESS_DETACH: 進程被停止;
DLL_THREAD_DETACH: 線程被停止;
lpReserved:是一個被系統所保留的參數。

看到這里,我想大家應該會對將c程序編譯成dll文件有了個大體的概念。

關於對於dll文件的使用,我在vb.net里做了以下測試:
首先用vs.net 2003新建一個vb.net應用程序。
然後在工程屬性中引用System.Runtime.InteropServices命名空間。
然後在默認的窗體文件中添加如下代碼:
Public Class Form1
Inherits System.Windows.Forms.Form

#Region " Windows 窗體設計器生成的代碼 "

Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

End Sub

Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Hello()
End Sub
End Class

Mole test
Sub main()
Dim frm As New Form1
Application.Run(frm)

End Sub
<DllImport("test.dll", EntryPoint:="HelloWorld", setlasterror:=True)> Public Sub Hello()

End Sub
End Mole

然後把上面用devcpp生成的test.dll放入工程bin目錄下,測試成功。

關於dll文件的一點設想:
關於多語言創建dll文件和動態使用dll文件,我感覺應該是插件技術plugin技術最直接的實現方式。特別是現在的.net平台,為動態導入dll文件中的函數提供了更簡易的方法。一個實現插件的基本思想可以是,在主程序和插件程序內做出一個規定的通訊方式,比如將一個可以代表使用插件功能的對象,由主程序創建對應插件程序的對象,然後由插件程序傳址調用,調用修改後的對象中保存了插件功能信息(比如插件名稱、功能函數指針等),然後再由主程序進行處理。

以下是網上摘抄的一點資料:

動態鏈接庫中定義有兩種函數:導出函數(export function)和內部函數(internal function)。導出函數可以被其它模塊調用,內部函數在定義它們的DLL程序內部使用。

輸出函數的方法有以下幾種:

1、傳統的方法

在模塊定義文件的EXPORT部分指定要輸入的函數或者變數。語法格式如下:
entryname[=internalname] [@ordinal[NONAME]] [DATA] [PRIVATE]

其中:

entryname是輸出的函數或者數據被引用的名稱;

internalname同entryname;

@ordinal表示在輸出表中的順序號(index);

NONAME僅僅在按順序號輸出時被使用(不使用entryname);

DATA表示輸出的是數據項,使用DLL輸出數據的程序必須聲明該數據項為_declspec(dllimport)。

上述各項中,只有entryname項是必須的,其他可以省略。

對於「C」函數來說,entryname可以等同於函數名;但是對「C++」函數(成員函數、非成員函數)來說,entryname是修飾名。可以從.map映像文件中得到要輸出函數的修飾名,或者使用DUMPBIN /SYMBOLS得到,然後把它們寫在.def文件的輸出模塊。DUMPBIN是VC提供的一個工具。

如果要輸出一個「C++」類,則把要輸出的數據和成員的修飾名都寫入.def模塊定義文件。

2、在命令行輸出

對鏈接程序LINK指定/EXPORT命令行參數,輸出有關函數。

3、使用MFC提供的修飾符號_declspec(dllexport)

在要輸出的函數、類、數據的聲明前加上_declspec(dllexport)的修飾符,表示輸出。__declspec(dllexport)在C調用約定、C編譯情況下可以去掉輸出函數名的下劃線前綴。extern "C"使得在C++中使用C編譯方式成為可能。在「C++」下定義「C」函數,需要加extern 「C」關鍵詞。用extern "C"來指明該函數使用C編譯方式。輸出的「C」函數可以從「C」代碼里調用。

例如,在一個C++文件中,有如下函數:
extern "C" {void __declspec(dllexport) __cdecl Test(int var);}
其輸出函數名為:Test

MFC提供了一些宏,就有這樣的作用。

AFX_CLASS_IMPORT:__declspec(dllexport)

AFX_API_IMPORT:__declspec(dllexport)

AFX_DATA_IMPORT:__declspec(dllexport)

AFX_CLASS_EXPORT:__declspec(dllexport)

AFX_API_EXPORT:__declspec(dllexport)

AFX_DATA_EXPORT:__declspec(dllexport)

AFX_EXT_CLASS: #ifdef _AFXEXT
AFX_CLASS_EXPORT
#else
AFX_CLASS_IMPORT

AFX_EXT_API:#ifdef _AFXEXT
AFX_API_EXPORT
#else
AFX_API_IMPORT

AFX_EXT_DATA:#ifdef _AFXEXT
AFX_DATA_EXPORT
#else
AFX_DATA_IMPORT

像AFX_EXT_CLASS這樣的宏,如果用於DLL應用程序的實現中,則表示輸出(因為_AFX_EXT被定義,通常是在編譯器的標識參數中指定該選項/D_AFX_EXT);如果用於使用DLL的應用程序中,則表示輸入(_AFX_EXT沒有定義)。

要輸出整個的類,對類使用_declspec(_dllexpot);要輸出類的成員函數,則對該函數使用_declspec(_dllexport)。如:

class AFX_EXT_CLASS CTextDoc : public CDocument
{

}

extern "C" AFX_EXT_API void WINAPI InitMYDLL();

這幾種方法中,最好採用第三種,方便好用;其次是第一種,如果按順序號輸出,調用效率會高些;最次是第二種。

『伍』 怎麼對C語言中的文件進行內容添加,刪除,查找的操作

c語言文件操作

13.3 文件的打開與關閉
文件在進行讀寫操作之前要先打開,使用完畢要關閉。所謂打開文件,實際上是建立文件的各種有關信息,並使文件指針指向該文件,以便進行其它操作。關閉文件則斷開指針與文件之間的聯系,也就禁止再對該文件進行操作。

在C語言中,文件操作都是由庫函數來完成的。在本章內將介紹主要的文件操作函數。

13.3.1 文件的打開(fopen函數)
fopen函數用來打開一個文件,其調用的一般形式為:

文件指針名=fopen(文件名,使用文件方式);

其中,

「文件指針名」必須是被說明為FILE 類型的指針變數;

「文件名」是被打開文件的文件名;

「使用文件方式」是指文件的類型和操作要求。

「文件名」是字元串常量或字元串數組。

例如:

FILE *fp;

fp=("file a","r");

其意義是在當前目錄下打開文件file a,只允許進行「讀」操作,並使fp指向該文件。

又如:

FILE *fphzk

fphzk=("c:\\hzk16","rb")

其意義是打開C驅動器磁碟的根目錄下的文件hzk16,這是一個二進制文件,只允許按二進制方式進行讀操作。兩個反斜線「\\ 」中的第一個表示轉義字元,第二個表示根目錄。

使用文件的方式共有12種,下面給出了它們的符號和意義。

文件使用方式
意義

「rt」
只讀打開一個文本文件,只允許讀數據

「wt」
只寫打開或建立一個文本文件,只允許寫數據

「at」
追加打開一個文本文件,並在文件末尾寫數據

「rb」
只讀打開一個二進制文件,只允許讀數據

「wb」
只寫打開或建立一個二進制文件,只允許寫數據

「ab」
追加打開一個二進制文件,並在文件末尾寫數據

「rt+」
讀寫打開一個文本文件,允許讀和寫

「wt+」
讀寫打開或建立一個文本文件,允許讀寫

「at+」
讀寫打開一個文本文件,允許讀,或在文件末追加數據

「rb+」
讀寫打開一個二進制文件,允許讀和寫

「wb+」
讀寫打開或建立一個二進制文件,允許讀和寫

「ab+」
讀寫打開一個二進制文件,允許讀,或在文件末追加數據

對於文件使用方式有以下幾點說明:

1) 文件使用方式由r,w,a,t,b,+六個字元拼成,各字元的含義是:

r(read): 讀

w(write): 寫

a(append): 追加

t(text): 文本文件,可省略不寫

b(banary): 二進制文件

+: 讀和寫

2) 凡用「r」打開一個文件時,該文件必須已經存在,且只能從該文件讀出。

3) 用「w」打開的文件只能向該文件寫入。若打開的文件不存在,則以指定的文件名建立該文件,若打開的文件已經存在,則將該文件刪去,重建一個新文件。

4) 若要向一個已存在的文件追加新的信息,只能用「a」方式打開文件。但此時該文件必須是存在的,否則將會出錯。

5) 在打開一個文件時,如果出錯,fopen將返回一個空指針值NULL。在程序中可以用這一信息來判別是否完成打開文件的工作,並作相應的處理。因此常用以下程序段打開文件:

6) if((fp=fopen("c:\\hzk16","rb")==NULL)

{

printf("\nerror on open c:\\hzk16 file!");

getch();

exit(1);

}

這段程序的意義是,如果返回的指針為空,表示不能打開C盤根目錄下的hzk16文件,則給出提示信息「error on open c:\ hzk16 file!」,下一行getch()的功能是從鍵盤輸入一個字元,但不在屏幕上顯示。在這里,該行的作用是等待,只有當用戶從鍵盤敲任一鍵時,程序才繼續執行,因此用戶可利用這個等待時間閱讀出錯提示。敲鍵後執行exit(1)退出程序。

7) 把一個文本文件讀入內存時,要將ASCII碼轉換成二進制碼,而把文件以文本方式寫入磁碟時,也要把二進制碼轉換成ASCII碼,因此文本文件的讀寫要花費較多的轉換時間。對二進制文件的讀寫不存在這種轉換。

8) 標准輸入文件(鍵盤),標准輸出文件(顯示器),標准出錯輸出(出錯信息)是由系統打開的,可直接使用。

13.3.2 文件關閉函數(fclose函數)
文件一旦使用完畢,應用關閉文件函數把文件關閉,以避免文件的數據丟失等錯誤。

fclose函數調用的一般形式是:

fclose(文件指針);

例如:

fclose(fp);

正常完成關閉文件操作時,fclose函數返回值為0。如返回非零值則表示有錯誤發生。

13.4 文件的讀寫
對文件的讀和寫是最常用的文件操作。在C語言中提供了多種文件讀寫的函數:

·字元讀寫函數 :fgetc和fputc

·字元串讀寫函數:fgets和fputs

·數據塊讀寫函數:freed和fwrite

·格式化讀寫函數:fscanf和fprinf

下面分別予以介紹。使用以上函數都要求包含頭文件stdio.h。

13.4.1 字元讀寫函數fgetc和fputc
字元讀寫函數是以字元(位元組)為單位的讀寫函數。每次可從文件讀出或向文件寫入一個字元。

1. 讀字元函數fgetc

fgetc函數的功能是從指定的文件中讀一個字元,函數調用的形式為:

字元變數=fgetc(文件指針);

例如:

ch=fgetc(fp);

其意義是從打開的文件fp中讀取一個字元並送入ch中。

對於fgetc函數的使用有以下幾點說明:

1) 在fgetc函數調用中,讀取的文件必須是以讀或讀寫方式打開的。

2) 讀取字元的結果也可以不向字元變數賦值,

例如:

fgetc(fp);

但是讀出的字元不能保存。

3) 在文件內部有一個位置指針。用來指向文件的當前讀寫位元組。在文件打開時,該指針總是指向文件的第一個位元組。使用fgetc 函數後,該位置指針將向後移動一個位元組。 因此可連續多次使用fgetc函數,讀取多個字元。應注意文件指針和文件內部的位置指針不是一回事。文件指針是指向整個文件的,須在程序中定義說明,只要不重新賦值,文件指針的值是不變的。文件內部的位置指針用以指示文件內部的當前讀寫位置,每讀寫一次,該指針均向後移動,它不需在程序中定義說明,而是由系統自動設置的。

【例13.1】讀入文件c1.doc,在屏幕上輸出。

#include<stdio.h>

main()

{

FILE *fp;

char ch;

if((fp=fopen("d:\\jrzh\\example\\c1.txt","rt"))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

fclose(fp);

}
本常式序的功能是從文件中逐個讀取字元,在屏幕上顯示。程序定義了文件指針fp,以讀文本文件方式打開文件「d:\\jrzh\\example\\ex1_1.c」,並使fp指向該文件。如打開文件出錯,給出提示並退出程序。程序第12行先讀出一個字元,然後進入循環,只要讀出的字元不是文件結束標志(每個文件末有一結束標志EOF)就把該字元顯示在屏幕上,再讀入下一字元。每讀一次,文件內部的位置指針向後移動一個字元,文件結束時,該指針指向EOF。執行本程序將顯示整個文件。

2. 寫字元函數fputc

fputc函數的功能是把一個字元寫入指定的文件中,函數調用的形式為:

fputc(字元量,文件指針);

其中,待寫入的字元量可以是字元常量或變數,例如:

fputc('a',fp);

其意義是把字元a寫入fp所指向的文件中。

對於fputc函數的使用也要說明幾點:

1) 被寫入的文件可以用寫、讀寫、追加方式打開,用寫或讀寫方式打開一個已存在的文件時將清除原有的文件內容,寫入字元從文件首開始。如需保留原有文件內容,希望寫入的字元以文件末開始存放,必須以追加方式打開文件。被寫入的文件若不存在,則創建該文件。

2) 每寫入一個字元,文件內部位置指針向後移動一個位元組。

3) fputc函數有一個返回值,如寫入成功則返回寫入的字元,否則返回一個EOF。可用此來判斷寫入是否成功。

【例13.2】從鍵盤輸入一行字元,寫入一個文件,再把該文件內容讀出顯示在屏幕上。

#include<stdio.h>

main()

{

FILE *fp;

char ch;

if((fp=fopen("d:\\jrzh\\example\\string","wt+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("input a string:\n");

ch=getchar();

while (ch!='\n')

{

fputc(ch,fp);

ch=getchar();

}

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

程序中第6行以讀寫文本文件方式打開文件string。程序第13行從鍵盤讀入一個字元後進入循環,當讀入字元不為回車符時,則把該字元寫入文件之中,然後繼續從鍵盤讀入下一字元。每輸入一個字元,文件內部位置指針向後移動一個位元組。寫入完畢,該指針已指向文件末。如要把文件從頭讀出,須把指針移向文件頭,程序第19行rewind函數用於把fp所指文件的內部位置指針移到文件頭。第20至25行用於讀出文件中的一行內容。

【例13.3】把命令行參數中的前一個文件名標識的文件,復制到後一個文件名標識的文件中,如命令行中只有一個文件名則把該文件寫到標准輸出文件(顯示器)中。

#include<stdio.h>

main(int argc,char *argv[])

{

FILE *fp1,*fp2;

char ch;

if(argc==1)

{

printf("have not enter file name strike any key exit");

getch();

exit(0);

}

if((fp1=fopen(argv[1],"rt"))==NULL)

{

printf("Cannot open %s\n",argv[1]);

getch();

exit(1);

}

if(argc==2) fp2=stdout;

else if((fp2=fopen(argv[2],"wt+"))==NULL)

{

printf("Cannot open %s\n",argv[1]);

getch();

exit(1);

}

while((ch=fgetc(fp1))!=EOF)

fputc(ch,fp2);

fclose(fp1);

fclose(fp2);

}

本程序為帶參的main函數。程序中定義了兩個文件指針fp1和fp2,分別指向命令行參數中給出的文件。如命令行參數中沒有給出文件名,則給出提示信息。程序第18行表示如果只給出一個文件名,則使fp2指向標准輸出文件(即顯示器)。程序第25行至28行用循環語句逐個讀出文件1中的字元再送到文件2中。再次運行時,給出了一個文件名,故輸出給標准輸出文件stdout,即在顯示器上顯示文件內容。第三次運行,給出了二個文件名,因此把string中的內容讀出,寫入到OK之中。可用DOS命令type顯示OK的內容。

13.4.2 字元串讀寫函數fgets和fputs
1. 讀字元串函數fgets

函數的功能是從指定的文件中讀一個字元串到字元數組中,函數調用的形式為:

fgets(字元數組名,n,文件指針);

其中的n是一個正整數。表示從文件中讀出的字元串不超過 n-1個字元。在讀入的最後一個字元後加上串結束標志'\0'。

例如:

fgets(str,n,fp);

的意義是從fp所指的文件中讀出n-1個字元送入字元數組str中。

【例13.4】從string文件中讀入一個含10個字元的字元串。

#include<stdio.h>

main()

{

FILE *fp;

char str[11];

if((fp=fopen("d:\\jrzh\\example\\string","rt"))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

fgets(str,11,fp);

printf("\n%s\n",str);

fclose(fp);

}

本例定義了一個字元數組str共11個位元組,在以讀文本文件方式打開文件string後,從中讀出10個字元送入str數組,在數組最後一個單元內將加上'\0',然後在屏幕上顯示輸出str數組。輸出的十個字元正是例13.1程序的前十個字元。

對fgets函數有兩點說明:

1) 在讀出n-1個字元之前,如遇到了換行符或EOF,則讀出結束。

2) fgets函數也有返回值,其返回值是字元數組的首地址。

2. 寫字元串函數fputs

fputs函數的功能是向指定的文件寫入一個字元串,其調用形式為:

fputs(字元串,文件指針);

其中字元串可以是字元串常量,也可以是字元數組名,或指針變數,例如:

fputs(「abcd「,fp);

其意義是把字元串「abcd」寫入fp所指的文件之中。

【例13.5】在例13.2中建立的文件string中追加一個字元串。

#include<stdio.h>

main()

{

FILE *fp;

char ch,st[20];

if((fp=fopen("string","at+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("input a string:\n");

scanf("%s",st);

fputs(st,fp);

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

本例要求在string文件末加寫字元串,因此,在程序第6行以追加讀寫文本文件的方式打開文件string。然後輸入字元串,並用fputs函數把該串寫入文件string。在程序15行用rewind函數把文件內部位置指針移到文件首。再進入循環逐個顯示當前文件中的全部內容。

13.4.3 數據塊讀寫函數fread和fwtrite
C語言還提供了用於整塊數據的讀寫函數。可用來讀寫一組數據,如一個數組元素,一個結構變數的值等。

讀數據塊函數調用的一般形式為:

fread(buffer,size,count,fp);

寫數據塊函數調用的一般形式為:

fwrite(buffer,size,count,fp);

其中:

buffer 是一個指針,在fread函數中,它表示存放輸入數據的首地址。在fwrite函數中,它表示存放輸出數據的首地址。

size 表示數據塊的位元組數。

count 表示要讀寫的數據塊塊數。

fp 表示文件指針。

例如:

fread(fa,4,5,fp);

其意義是從fp所指的文件中,每次讀4個位元組(一個實數)送入實數組fa中,連續讀5次,即讀5個實數到fa中。

【例13.6】從鍵盤輸入兩個學生數據,寫入一個文件中,再讀出這兩個學生的數據顯示在屏幕上。

#include<stdio.h>

struct stu

{

char name[10];

int num;

int age;

char addr[15];

}boya[2],boyb[2],*pp,*qq;

main()

{

FILE *fp;

char ch;

int i;

pp=boya;

qq=boyb;

if((fp=fopen("d:\\jrzh\\example\\stu_list","wb+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("\ninput data\n");

for(i=0;i<2;i++,pp++)

scanf("%s%d%d%s",pp->name,&pp->num,&pp->age,pp->addr);

pp=boya;

fwrite(pp,sizeof(struct stu),2,fp);

rewind(fp);

fread(qq,sizeof(struct stu),2,fp);

printf("\n\nname\tnumber age addr\n");

for(i=0;i<2;i++,qq++)

printf("%s\t%5d%7d %s\n",qq->name,qq->num,qq->age,qq->addr);

fclose(fp);

}

本常式序定義了一個結構stu,說明了兩個結構數組boya和boyb以及兩個結構指針變數pp和qq。pp指向boya,qq指向boyb。程序第16行以讀寫方式打開二進制文件「stu_list」,輸入二個學生數據之後,寫入該文件中,然後把文件內部位置指針移到文件首,讀出兩塊學生數據後,在屏幕上顯示。

------

回復此文章 |
回復主題:Re:c語言文件操作 | 作者: haohao | 軍銜:六級軍士 | 發表時間:2004-07-28 11:08:47
下午應該把這個搞定了.
------

回復此文章 |
回復主題:Re:Re:c語言文件操作 | 作者: haohao | 軍銜:六級軍士 | 發表時間:2004-07-28 11:10:23
13.7 C庫文件
C系統提供了豐富的系統文件,稱為庫文件,C的庫文件分為兩類,一類是擴展名為".h"的文件,稱為頭文件,在前面的包含命令中我們已多次使用過。在".h"文件中包含了常量定義、類型定義、宏定義、函數原型以及各種編譯選擇設置等信息。另一類是函數庫,包括了各種函數的目標代碼,供用戶在程序中調用。 通常在程序中調用一個庫函數時,要在調用之前包含該函數原型所在的".h" 文件。

下面給出Turbo C的全部".h"文件。

Turbo C頭文件

n ALLOC.H 說明內存管理函數(分配、釋放等)。

n ASSERT.H 定義 assert調試宏。

n BIOS.H 說明調用IBM—PC ROM BIOS子程序的各個函數。

n CONIO.H 說明調用DOS控制台I/O子程序的各個函數。

n CTYPE.H 包含有關字元分類及轉換的名類信息(如 isalpha和toascii等)。

n DIR.H 包含有關目錄和路徑的結構、宏定義和函數。

n DOS.H 定義和說明MSDOS和8086調用的一些常量和函數。

n ERRON.H 定義錯誤代碼的助記符。

n FCNTL.H 定義在與open庫子程序連接時的符號常量。

n FLOAT.H 包含有關浮點運算的一些參數和函數。

n GRAPHICS.H 說明有關圖形功能的各個函數,圖形錯誤代碼的常量定義,正對不同驅動程序的各種顏色值,及函數用到的一些特殊結構。

n IO.H 包含低級I/O子程序的結構和說明。

n LIMIT.H 包含各環境參數、編譯時間限制、數的范圍等信息。

n MATH.H 說明數學運算函數,還定了 HUGE VAL 宏, 說明了matherr和matherr子程序用到的特殊結構。

n MEM.H 說明一些內存操作函數(其中大多數也在STRING.H中說明)。

n PROCESS.H 說明進程管理的各個函數,spawn…和EXEC …函數的結構說明。

n SETJMP.H 定義longjmp和setjmp函數用到的jmp buf類型,說明這兩個函數。

n SHARE.H 定義文件共享函數的參數。

n SIGNAL.H 定義SIG[ZZ(Z] [ZZ)]IGN和SIG[ZZ(Z] [ZZ)]DFL常量,說明rajse和signal兩個函數。

n STDARG.H 定義讀函數參數表的宏。(如vprintf,vscarf函數)。

n STDDEF.H 定義一些公共數據類型和宏。

n STDIO.H 定義Kernighan和Ritchie在Unix System V 中定義的標准和擴展的類型和宏。還定義標准I/O 預定義流:stdin,stdout和stderr,說明 I/O流子程序。

n STDLIB.H 說明一些常用的子程序:轉換子程序、搜索/ 排序子程序等。

n STRING.H 說明一些串操作和內存操作函數。

n SYS\STAT.H 定義在打開和創建文件時用到的一些符號常量。

n SYS\TYPES.H 說明ftime函數和timeb結構。

n SYS\TIME.H 定義時間的類型time[ZZ(Z] [ZZ)]t。

n TIME.H 定義時間轉換子程序asctime、localtime和gmtime的結構,ctime、 difftime、 gmtime、 localtime和stime用到的類型,並提供這些函數的原型。

n VALUE.H 定義一些重要常量,包括依賴於機器硬體的和為與Unix System V相兼容而說明的一些常量,包括浮點和雙精度值的范圍。

13.8 本章小結
1. C系統把文件當作一個「流」,按位元組進行處理。

2. C文件按編碼方式分為二進制文件和ASCII文件。

3. C語言中,用文件指針標識文件,當一個文件被打開時,可取得該文件指針。

4. 文件在讀寫之前必須打開,讀寫結束必須關閉。

5. 文件可按只讀、只寫、讀寫、追加四種操作方式打開,同時還必須指定文件的類型是二進制文件還是文本文件。

6. 文件可按位元組,字元串,數據塊為單位讀寫,文件也可按指定的格式進行讀寫。

7. 文件內部的位置指針可指示當前的讀寫位置,移動該指針可以對文件實現隨機讀寫。

『陸』 C語言中的g_free和free的區別,有沒有網址可以查看到g_free的定義

g_free是glib庫的介面,可以用來替換標準的free介面,使用時需要包含glib.h頭文件。
glib庫是Linux平台下最常用的C語言函數庫,它具有很好的可移植性和實用性。
glib是Gtk +庫和Gnome的基礎。glib可以在多個平台下使用,比如Linux、Unix、Windows等。glib為許多標準的、常用的C語言結構提供了相應的替代物。
g_free的定義可以在
http://web.mit.e/barnowl/share/gtk-doc/html/glib/glib-Memory-Allocation.html#g-free這個網站看到。
請採納,謝謝。

『柒』 c語言調試問題!

ungetch()是庫函數中的函數,原型是這樣的:int ungetch(int);
你自己又定義一個類型返回值類型不一樣的,那就不要包含下面這個頭文件了嘛:
#include <conio.h>

補充:
摟主,你說的調試不是單步調試吧?編譯都有錯,根本調試不了。

--------------------Configuration: aaa - Win32 Debug--------------------
Compiling...
b.cpp
E:\MYDOC\VC6\aaa\b.cpp(75) : error C2556: 'void __cdecl ungetch(int)' : overloaded function differs only by return type from 'int __cdecl ungetch(int)'
c:\program files\microsoft visual studio\vc98\include\conio.h(104) : see declaration of 'ungetch'
E:\MYDOC\VC6\aaa\b.cpp(75) : error C2371: 'ungetch' : redefinition; different basic types
c:\program files\microsoft visual studio\vc98\include\conio.h(104) : see declaration of 'ungetch'
E:\MYDOC\VC6\aaa\b.cpp(81) : error C2137: empty character constant
E:\MYDOC\VC6\aaa\b.cpp(111) : error C2556: 'void __cdecl ungetch(int)' : overloaded function differs only by return type from 'int __cdecl ungetch(int)'
c:\program files\microsoft visual studio\vc98\include\conio.h(104) : see declaration of 'ungetch'
Error executing cl.exe.

b.obj - 4 error(s), 0 warning(s)

能編譯通過的如下,修改了兩處:
#include <stdio.h>
#include <stdlib.h>
//#include <conio.h> //自己定義了函數庫中的函數,就不要使用函數庫了

#define MAXOP 100
#define NUMBER '0'

int getop(char []);
void push(double);
double pop(void);

main()
{
int type;
double op2;
char s[MAXOP];

while ((type=getop(s))!=EOF) {
switch(type) {
case NUMBER:
push(atof(s));
case '+':
push(pop()+pop());
case '*':
push(pop()*pop());
case '-':
op2=pop();
push(pop()-op2);
break;
case '/':
op2=pop();
if(op2!=0.0)
push(pop()/op2);
else
printf("error:zero divisor\n");
break;
case '\n':
printf("\t%.8g\n",pop());
break;
default:
printf("error:unknown command %s\n",s);
break;
}
}
return 0;
}

#define MAXVAL 100
int sp=0;
double val[MAXVAL];

void push(double f)
{
if (sp<MAXVAL)
val[sp++]=f;
else
printf("error:stack fill,can't push %g\n",f);
}

double pop(void)
{
if (sp>0)
return val[--sp];
else {
printf("error: stack empty\n");
return 0.0;
}
}

#include <ctype.h>

int getch(void);
void ungetch(int);

int getop(char s[])
{
int i,c;

while ((s[0]=c=getch())==' '||c=='\t')//注意空格的寫法
;
s[1]='\0';
if (!isdigit(c)&&c!='.')
return c;
i=0;
if (isdigit(c))
while (isdigit(s[++i]=c=getch()))
;
if (c=='.')
while (isdigit(s[++i]=c=getch()))
;
s[i]='\0';
if (c!=EOF)
ungetch(c);
return NUMBER;
}

#define BUFSIZE 100

char buf[BUFSIZE];
int bufp=0;

int getch(void)
{
return (bufp>0)?buf[--bufp] :getchar();
}

void ungetch(int c)
{
if(bufp >=BUFSIZE)
printf("ungetch: too many chatacters\n");
else
buf[bufp++]=c;
}