歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> 關於Linux

Linux環境編程-文件基本操作

Linux 下目錄是/這樣的  而windows是\怎麼記呢?\和w是不是一樣的反向?所以Linux的目錄就是反的反向,好記了。

一:open函數

名稱:

open

目標:

打開一個文件。

頭文件:

#include <sys/types.h>

#include <sys/stat.h>

#include < fcntl.h>

函數原形:

int open(const char * pathname,int flags);

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

參數:

pathname    文件名

    

flags          打開模式

返回值:

-1     遇到錯誤

    

int    打開成功,返回文件描述符。

這個系統調用在進程和文件之間建立一條連接,這個連接被稱為文件描述符,它就像一條由進程通向內核的管道。

要打開一個文件,必須指定文件名和打開模式,有3種打開模式:只讀,只寫,可讀可寫,分別對應於O_RDONLY,O_WRONLY,O_RDWR,這在頭文件/usr/include/fcntl.h中有定義。

       打開文件是內核提供的服務,如果在打開過程中內核檢測到任何錯誤,這個系統調用就會返回-1。錯誤的類型是各種各樣的,如:要打開的文件不存在。即使文件存在可能因為權限不夠而無法打開,在open的聯機幫助中列出了各種可能的錯誤,大家可以看看。

       UNIX允許一個文件被多個進程訪問,也就是說當一個文件被一個進程打開後,這個文件還可以被其它進程打開。

      如果文件被順利打開內核會返回一個正整數的值,這個數值就叫文件描述符,文件描述符是是一個簡單的整數,用以標明每一個被進程所打開的文件,描述符0代表標准輸出,對應的宏是 STDOUT_FILENO,描述符1代表標准輸入,對應的宏為STDIN_FILENO,描述符2代表標准錯誤輸出,對應的宏為STDERR_FILENO,系統給進程分配描述符都是從3開始的,如果同時打開好幾個文件,它們所對應的的文件描述符是不同的,如果一個文件打開多次,對應的文件描述符也不相同。必須通過文件描述符對文件操作。下面的程序可以證明這一點。

 

二:read函數

名稱:

read

目標:

把數據讀到緩沖區。

頭文件:

#include < unistd.h>

函數原形:

ssize_t read(int fd, void *buf, size_t count)

參數:

fd       文件描述符

 

buf      用來存放數據的目的緩沖區

 

count     要讀取的字節數

返回值:

-1       遇到錯誤

    

numread  成功關閉,返回所讀取的字節數目。

read這個系統調用請求內核從fd所指定的文件中讀取qty字節的數據,存放到buf所指定的內存空間中,內核如果成功地讀取了數據,就返回所讀取的字節數目。否則返回-1。

當文件的字節數沒有你想要的那麼多時,read就會判斷下一個數值是不是’\0’,如果是就停止讀取,然後退出。numread返回的是’\0’之前的字節數,也就是是原文件的字節數而不是你想讀的字節數。

 

三:close函數

名稱:

close

目標:

關閉一個文件。

頭文件:

#include < unistd.h>

函數原形:

int close(int fd)

參數:

fd    文件描述符

返回值:

-1     遇到錯誤

    

int    關閉成功,返回文件描述符。

       Close這個系統調用會關閉進程和文件fd之間的連接,如果關閉過程中出現錯誤,close返回-1,如:fd所指的文件並不存在。關閉成功則返回文件描述符。

代碼: 一個基本的打開文件,讀取,並關閉的例子

#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<stdlib.h>
#include<stdio.h>
main()
{
int fd,size;
char s [ ]="Linux Programmer!\n",buffer[1024];

fd=open("show_read.c",O_RDONLY);
size=read(fd,buffer,sizeof(buffer));
close(fd);
printf("%s",buffer);
}


 四:craet函數

名稱:

creat

目標:

創建/重寫一個文件

頭文件:

#include <sys/types.h>

#include <stat.h>

#include < fcntl.h>

函數原形:

int creat(const char *pathname,mode_t mode)

參數:

pathname   文件名

 

mode      訪問模式

返回值:

-1         遇到錯誤

    \

fd         創建成功,返回文件描述符

       Creat告訴內核創建一個名為filename的文件,如果這個文件不存在,就創建它,如果已經存在,就把它的內容清空,把文件的長度設為0。    

       如果內核成功地創建了文件,那麼文件的許可位(permission bits)被設置為由第二個參數mode所指定的值.如:

fd=creat(“addressbook”,0644);

       創建一個名為addressbook的文件,如果文件不存在,那麼文件的許可位被設為 rw-r-r—.

如果文件已存在它的內容會被清空。任一情況下,fd都會是指向addressbook的文件描述符。

 

五:write函數

名稱:

write

目標:

將內存中的數據寫入文件。

頭文件:

#include < unistd.h>

函數原形:

size_t write(int fd, const void *buf, size_t count)

參數:

fd       文件描述符

 

buf      內存數據

 

count    要寫的字節數

返回值:

-1       遇到錯誤

    

Num written  成功寫入,返回寫入的字節數目。

在實際的寫入過程中,可能會出現寫入的字節數少於所要求的。這可能有兩個原因,第一是有的系統對文件的最大尺寸有限制,第二是磁盤空間接近滿了。在上述兩種情況下內核都會盡力把數據往文件中寫,並將實際寫入的字節數返回,所以調用write後都必須檢查返回值是否與要寫入的相同,如果不同就要采取相應的措施。

       學完上面幾個系統調用,我們就可以自己編寫的cp命令了。它的基本思路是從原文件讀取數據寫入緩沖,再將緩沖的數據寫入目標文件。

 

代碼:新建一個文件並寫入內容

#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<stdlib.h>
#include<stdio.h>
main()
{
int fd,size;
char s [ ]="Linux Programmer!\n",buffer[1024];


char filename[]="newfile.txt";
fd=creat(filename,0644);
fd=open(filename,O_WRONLY|O_CREAT);
write(fd,s,sizeof(buffer));

fd=open(filename,O_RDONLY);
size=read(fd,buffer,sizeof(buffer));
close(fd);
printf("%s",buffer);

}
Copyright © Linux教程網 All Rights Reserved