c語言打開文件函數fd c語言調用函數打開文件

c語言庫函數的打開文件函數

c語言標準庫中用于打開文件的函數是fopen()。

在依安等地區,都構建了全面的區域性戰略布局,加強發展的系統性、市場前瞻性、產品創新能力,以專注、極致的服務理念,為客戶提供成都網站建設、網站設計 網站設計制作按需定制網站,公司網站建設,企業網站建設,成都品牌網站建設,全網營銷推廣,成都外貿網站建設公司,依安網站建設費用合理。

函數原型:FILE

*

fopen(const

char

*

path,const

char

*

mode);

 

參數說明:path指明要打開的文件名,mode指明以什么方式打開。詳細在下面介紹。

返回值:文件順利打開后,指向該流的文件指針就會被返回。如果文件打開失敗則返回NULL,并把錯誤代碼存在errno

中。示例如下

#includestdio.h

//根據需要修改成自己要打開的文件即可。

#define F_PATH "d:\\myfile\\file.dat"

int main(void)

{

FILE *fp=NULL;//需要注意

fp=fopen(F_PATH,"r"); //以只讀方式打開一個文件

if(NULL==fp)

{

return -1;//要返回錯誤代碼

}

fclose(fp); //打開一個文件停止操作后,要關閉打開的文件

fp=NULL;//需要指向空,否則會指向原打開文件地址

return 0;

}

參數mode的類型:

r

以只讀方式打開文件,該文件必須存在。

r+

以可讀寫方式打開文件,該文件必須存在。

rb+

讀寫打開一個二進制文件,允許讀寫數據,文件必須存在。

w

打開只寫文件,若文件存在則文件長度清為0,即該文件內容會消失。若文件不存在則建立該文件。

w+

打開可讀寫文件,若文件存在則文件長度清為零,即該文件內容會消失。若文件不存在則建立該文件。

a

以附加的方式打開只寫文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾,即文件原先的內容會被保留。(EOF符保留)

a+

以附加方式打開可讀寫的文件。若文件不存在,則會建立該文件,如果文件存在,寫入的數據會被加到文件尾后,即文件原先的內容會被保留。

(原來的EOF符不保留)

wb

只寫打開或新建一個二進制文件;只允許寫數據。

wb+

讀寫打開或建立一個二進制文件,允許讀和寫。

ab+

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

c語言中如何在函數中打開一個文件?

fopen函數用來打開一個文件,其調用的一般形式為:文件指針名=fopen(文件名,使用文件方式)其中,“文件指針名”必須是被說明為FILE類型的指針變量,“文件名”是被打開文件的文件名。“使用文件方式”是指文件的類型和操作要求。“文件名”是字符串常量或字符串數組。例如:

FILE*fp;

fp=("filea","r");

其意義是在當前目錄下打開文件filea,只允許進行“讀”操作,并使fp指向該文件。

c語言怎么打開文件內容

1、首先需要下載專門的c語言編程軟件,一般從百度下載就可以。

2、打開下載好的c語言編程軟件,界面如下圖所示。

3、在標題下方點擊打開項目,操作如下圖所示。

4、軟件會自動幫你找到自己做的文件,點擊需要打開的文件。

5、可以看到文件打開,自己可以進行查看,或者修改,添加程序。

c語言文件描述詞

fd文件描述符,打開的文件都有一個fd,fd對應內存中文件管理數據結構,也就是很多國人寫的教材中所謂的FCB(文件控制塊),類unix系統的文件IO操作有關的系統調用都使用fd作為其參數,如write,read,dup,dup2,fcntl和訪問文件屬性信息的函數之類的,因此,fd類似windows平臺的文件操作API所使用的文件句柄。c語言中文件io操作的庫函數是基于FILE結構,FILE只是對file descriptor做了封裝。記住 stdin對應的fd為0,stdout為1,stderr為2,如果你打開的文件的fd3,說明出錯了。理解否?

c 語言中打開文件的函數名為

C語言open()函數:打開文件函數

相關函數:read, write, fcntl, close, link,stat, umask, unlink, fopen

頭文件:#include sys/types.h #includesys/stat.h #include fcntl.h

定義函數:

intopen(const char * pathname, int flags);

intopen(const char * pathname, int flags, mode_t mode);

函數說明:

參數 pathname 指向欲打開的文件路徑字符串. 下列是參數flags 所能使用的旗標:

O_RDONLY 以只讀方式打開文件

O_WRONLY 以只寫方式打開文件

O_RDWR 以可讀寫方式打開文件. 上述三種旗標是互斥的, 也就是不可同時使用, 但可與下列的旗標利用OR(|)運算符組合.

O_CREAT 若欲打開的文件不存在則自動建立該文件.

O_EXCL 如果O_CREAT 也被設置, 此指令會去檢查文件是否存在. 文件若不存在則建立該文件, 否則將導致打開文件錯誤. 此外, 若O_CREAT 與O_EXCL 同時設置, 并且欲打開的文件為符號連接, 則會打開文件失敗.

O_NOCTTY 如果欲打開的文件為終端機設備時, 則不會將該終端機當成進程控制終端機.

O_TRUNC 若文件存在并且以可寫的方式打開時, 此旗標會令文件長度清為0, 而原來存于該文件的資料也會消失.

O_APPEND 當讀寫文件時會從文件尾開始移動, 也就是所寫入的數據會以附加的方式加入到文件后面.

O_NONBLOCK 以不可阻斷的方式打開文件, 也就是無論有無數據讀取或等待, 都會立即返回進程之中.

O_NDELAY 同O_NONBLOCK.

O_SYNC 以同步的方式打開文件.

O_NOFOLLOW 如果參數pathname 所指的文件為一符號連接, 則會令打開文件失敗.

O_DIRECTORY 如果參數pathname 所指的文件并非為一目錄, 則會令打開文件失敗。注:此為Linux2. 2 以后特有的旗標, 以避免一些系統安全問題.

參數mode 則有下列數種組合, 只有在建立新文件時才會生效, 此外真正建文件時的權限會受到umask 值所影響, 因此該文件權限應該為 (mode-umaks).

S_IRWXU00700權限, 代表該文件所有者具有可讀、可寫及可執行的權限.

S_IRUSR或S_IREAD, 00400 權限,代表該文件所有者具有可讀取的權限.

S_IWUSR或S_IWRITE, 00200 權限, 代表該文件所有者具有可寫入的權限.

S_IXUSR或S_IEXEC, 00100 權限,代表該文件所有者具有可執行的權限.

S_IRWXG00070 權限, 代表該文件用戶組具有可讀、可寫及可執行的權限.

S_IRGRP00040 權限, 代表該文件用戶組具有可讀的權限.

S_IWGRP00020 權限, 代表該文件用戶組具有可寫入的權限.

S_IXGRP00010 權限, 代表該文件用戶組具有可執行的權限.

S_IRWXO00007 權限, 代表其他用戶具有可讀、可寫及可執行的權限.

S_IROTH00004 權限, 代表其他用戶具有可讀的權限

S_IWOTH00002 權限, 代表其他用戶具有可寫入的權限.

S_IXOTH00001 權限, 代表其他用戶具有可執行的權限.

返回值:若所有欲核查的權限都通過了檢查則返回0 值, 表示成功, 只要有一個權限被禁止則返回-1.

錯誤代碼:

EEXIST參數pathname 所指的文件已存在, 卻使用了O_CREAT 和O_EXCL旗標.

EACCESS參數pathname 所指的文件不符合所要求測試的權限.

EROFS 欲測試寫入權限的文件存在于只讀文件系統內.

EFAULT參數pathname 指針超出可存取內存空間.

EINVAL參數mode 不正確.

ENAMETOOLONG參數 pathname 太長.

ENOTDIR參數pathname 不是目錄.

ENOMEM核心內存不足.

ELOOP 參數pathname 有過多符號連接問題.

EIOI/O 存取錯誤.

附加說明:使用access()作用戶認證方面的判斷要特別小心, 例如在access()后再作open()空文件可能會造成系統安全上的問題.

范例

#includeunistd.h

#includesys/types.h

#includesys/stat.h

#includefcntl.h

main()

{

intfd, size;

chars[] = "Linux Programmer!\n", buffer[80];

fd =open("/tmp/temp", O_WRONLY|O_CREAT);

write(fd, s, sizeof(s));

close(fd);

fd =open("/tmp/temp", O_RDONLY);

size= read(fd, buffer, sizeof(buffer));

close(fd);

printf("%s", buffer);

}

執行

LinuxProgrammer!

分享題目:c語言打開文件函數fd c語言調用函數打開文件
分享路徑:http://m.kartarina.com/article4/dodsjie.html

成都網站建設公司_創新互聯,為您提供App開發響應式網站網站維護企業建站面包屑導航品牌網站制作

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都定制網站建設
主站蜘蛛池模板: 亚洲国产精品无码久久九九 | 国产成人无码一区二区三区在线| 日韩av无码一区二区三区| 无码人妻视频一区二区三区| 性无码一区二区三区在线观看| 亚洲av日韩aⅴ无码色老头| 日韩精品无码成人专区| 久久久久久亚洲av成人无码国产| 熟妇人妻无码xxx视频| 亚洲国产精品无码专区影院| 欲色aV无码一区二区人妻| YW尤物AV无码国产在线观看| 亚洲精品无码mⅴ在线观看| 超清无码熟妇人妻AV在线电影| 日韩丰满少妇无码内射| 本免费AV无码专区一区| 成人麻豆日韩在无码视频| 久久精品无码一区二区WWW| 免费看成人AA片无码视频吃奶| 久久精品亚洲AV久久久无码| 国产成人无码AV一区二区在线观看| 在线看片无码永久免费视频| 亚洲AV无码一区二区二三区软件 | 蜜桃无码AV一区二区| 国产午夜无码片免费| 色欲aⅴ亚洲情无码AV| 中文字幕无码中文字幕有码| 无码精品人妻一区二区三区漫画 | 18禁无遮拦无码国产在线播放| 亚洲AV中文无码乱人伦在线视色| 亚洲av无码不卡久久| 青青草无码免费一二三区| 亚洲中文字幕久久精品无码APP| 免费无码一区二区| 亚洲熟妇无码八V在线播放| 久久人妻无码中文字幕| 色噜噜综合亚洲av中文无码 | 亚洲国产精品无码成人片久久 | 五月丁香六月综合缴清无码| 无码狠狠躁久久久久久久| 麻豆AV无码精品一区二区|