Rumah > Artikel > Operasi dan penyelenggaraan > Cara memanggil sistem asas fail pengendalian Linux
Sistem pengendalian Linux mematuhi konsep bahawa semuanya adalah fail Hampir semua peranti fail boleh dikendalikan dengan satu set panggilan sistem, iaitu open()/close()/write()/read(), dsb. Panggilan sistem adalah serupa dengan panggilan perpustakaan C dalam fail pengendalian. Manual manusia yang disertakan dengan Linux adalah yang paling berwibawa. Semak penggunaan panggilan sistem dengan menyemak manual lelaki.
Nama kod—— Maksud
1 —— >
int&mdash ;&mdash ;Deskriptor fail fd, setiap kali anda membuka fail, anda akan mendapat deskriptor fail ini ialah integer Kami melakukan operasi baca dan tulis melalui deskriptor fail.
Kegagalan: -1/usr/include
mode_t ialah alias jenis, yang sebenarnya merupakan integer yang ditandatangani Untuk fungsi terbuka, parameter ketiga
bendera: buka hanya digunakan semasa mencipta fail baharu 🎜>
Nota:
Ini sebenarnya makro yang ditakrifkan Apabila berbilang parameter perlu digunakan, gunakan bitwise ATAU "Yang lain tidak akan diperkenalkan satu persatu, sila semak diri anda apabila anda perlu menggunakannya.
tulis()|
Nilai pulangan
:Jika berjaya, ia mempunyai telah ditulis Bilangan bait yang dimasukkan;
-1 jika ralat berlaku; nilai pulangan fungsi Apabila tidak sama, ia bermakna terdapat ralat dalam penulisan dan boleh digunakan untuk menyemak sama ada penulisan berjaya;
: Deskriptor fail untuk menulis fail; : cache untuk menyimpan data yang akan ditulis; 🎜>: meminta untuk menulis Bilangan bait data pada satu-satu masa; operasi menulis bermula daripada anjakan semasa fail Jika Apabila fail dibuka dan pilihan O_APPEND ditentukan, mengimbangi fail ditetapkan ke hujung semasa fail sebelum setiap operasi tulis. Selepas penulisan yang berjaya, pengimbangan fail ditambah dengan bilangan bait yang sebenarnya ditulis. baca()
Mulakan dengan anjakan semasa fd
Sebelum berjaya kembali, anjakan ditambah dengan bilangan bait yang sebenarnya dibaca (anjakan ini boleh ditetapkan sendiri). ;
buf
Nota: Apabila proses ditamatkan, semua fail yang dibuka akan ditutup secara automatik oleh kernel.
Nota: fungsi tanpa cache ini adalah panggilan sistem yang disediakan oleh kernel; ini adalah sama seperti IO yang kami pelajari dalam Operasi bahasa C berbeza kerana ia bukan sebahagian daripada standard C, tetapi merupakan sebahagian daripada POSIX.
Apabila standard C beroperasi pada fail, ia beroperasi pada penunjuk struktur FILE dan deskriptor fail digunakan di sini.
Julat deskriptor fail ialah 0——OPEN MAX Had atas yang diterima pakai oleh Unix awal ialah 19 (iaitu, setiap proses dibenarkan untuk membuka 20 fail Sekarang banyak sistem akan meningkat tidak lama lagi hingga 63. Linux ialah 1024, nombor khusus boleh didapati dalam fail pengepala
Penerangan fail dan penuding fail
FAIL * fdopen (int fd,const char *mode), tukarkan deskriptor fail menjadi penunjuk fail; >
off_t lseek(int fd,off_t offset,int whence);
: Fail sudah dibuka deskriptor;
fd
: jumlah anjakan; 🎜>
offset
whence
#include<stdio.h> #include<fcntl.h> #include<string.h> #include<stdlib.h> #include<unistd.h> #include<errno.h> //生成空洞文件 char *buffer = "0123456789"; int main(int argc,char *argv[]) { if(argc < 2) { fprintf(stderr,"-usage:%s [file]\n",argv[0]); exit(1); } int fd = open(argv[1],O_WRONLY | O_CREATE | O_TRUNC,0777); if(fd < 0) { perror("open error"); exit(1); } size_t size = strlen(buffer) * sizeof(char); //将字符串写入到空洞文件中 if(write(fd,buffer,size) != size) { perror("write error"); exit(1); } //定位到文件尾部的10个字节处 if(lseek(fd,10L;SEERK_END) < 0) { perror("lseek error"); exit(1); } //从文件尾部的10个字节处再写入字符串 if(write(fd,buffer,size) != size) { perror("write error"); exit(1); } close(fd); return 0; }
Kita dapat melihat bahawa apabila kita menggunakan lebih banyak arahan untuk melihat kandungan fail, kita dapati kandungan yang dipaparkan hanya hasil penulisan sekali sahaja. Gunakan perintah odSEEK_SET
Buka fail baharu
Baca sebahagian daripada fail binari asal dan tuliskannya ke dalam fail baharu
Baca dan tulis berulang kali
sehingga bacaan selesai, kemudian berhenti selepas menulis [read() == 0 digunakan sebagai syarat untuk berhenti gelung, jika tidak boleh dibaca, ia adalah selesai]
Menyalin selesai
Menyalin selesai
Setiap kali kami membuka fail, struktur seperti fail struct akan dijana dalam kernel untuk mewakili fail terbuka dan merekodkan maklumat berikut:
Fail mengimbangi (bermula dari 0, penuding fail mengimbangi apabila data ditulis)
Kiraan rujukan (beberapa proses menggunakan fail Buka ini)
nod inod (menyimpan maklumat atribut proses: siapa yang menciptanya, apakah nama, dan di mana ia disimpan pada cakera. Melalui nod inod ini, kita boleh mencari fail khusus yang sepadan)
Kaedah pembukaan: seperti mod baca sahaja, mod tulis sahaja terbuka
Ujian 1: Buka fail dahulu dan kemudian fork
close(fd) ditulis pada bahagian paling luar, dan proses ibu bapa dan anak akan ditutup Setiap kali ia ditutup, kiraan rujukan akan dikurangkan dengan 1 sehingga mencapai 0.
Keputusan larian adalah seperti berikut:
Sebabnya adalah seperti berikut:
Ujian 2: Pertama garpu dan kemudian buka fail
Selepas mengubah suai kod, keputusan yang dijalankan berubah seperti berikut:
Kerana proses ibu bapa dan anak membuka fail mereka sendiri selepas ia dipisahkan, Fail struktur mereka sendiri dijana dan mengimbangi fail tidak lagi dikongsi.
Dalam senario aplikasi sebenar, kami kebanyakannya menggunakan fail yang dibuka oleh proses induk dan proses anak untuk mengakses borang ini.
Atas ialah kandungan terperinci Cara memanggil sistem asas fail pengendalian Linux. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!