Rumah  >  Artikel  >  Operasi dan penyelenggaraan  >  Cara memanggil sistem asas fail pengendalian Linux

Cara memanggil sistem asas fail pengendalian Linux

WBOY
WBOYke hadapan
2023-05-15 21:25:111628semak imbas

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 —— >

  • 2 —— Fungsi dan alatan yang boleh dipanggil oleh kernel sistem
  • 3 —— daripada pustaka fungsi C
  • 4 —— ; Fail konfigurasi atau format fail tertentu
  • 6 —— , Contohnya, sistem fail Linux, protokol rangkaian, dsb.
  • 8 —— — dan Fail Berkaitan Kernel
  • Ambil perhatian bahawa fail pengepala sistem biasanya disimpan dalam direktori
  • dalam Linux beberapa fail pengepala yang disertakan di bawah termasuk sys, yang sebenarnya berada di bawah disertakan Fail pengepala dalam subdirektori

    open()——Buka atau buat fail
  • Jenis nilai pulangan:

    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

Kejayaan: >= 0, iaitu deskriptor fail;

mode_t ialah alias jenis, yang sebenarnya merupakan integer yang ditandatangani Untuk fungsi terbuka, parameter ketiga Cara memanggil sistem asas fail pengendalian Linux

bendera: buka hanya digunakan semasa mencipta fail baharu 🎜>

  • Nota:

    Ini sebenarnya makro yang ditakrifkan Apabila berbilang parameter perlu digunakan, gunakan bitwise ATAU "
  • ” untuk membentuk berbilang parameter bendera <.>
  • juga boleh digunakan dengan cara berikut:

Yang lain tidak akan diperkenalkan satu persatu, sila semak diri anda apabila anda perlu menggunakannya. Cara memanggil sistem asas fail pengendalian Linux

tulis()

|

Nilai pulangan

:

Cara memanggil sistem asas fail pengendalian Linux

Jika berjaya, ia mempunyai telah ditulis Bilangan bait yang dimasukkan; Cara memanggil sistem asas fail pengendalian Linux

Cara memanggil sistem asas fail pengendalian Linux-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;

Cara memanggil sistem asas fail pengendalian Linux

: 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()

  • Nilai pulangan
  • : Bilangan bait dibaca

Jika penghujung fail telah dicapai, ia adalah 0; jika terdapat ralat, ia adalah -1; 🎜>

: Deskriptor fail untuk membaca fail;

    : cache untuk menyimpan data bacaan; 🎜>: permintaan untuk membaca Bilangan bait data pada satu masa; 🎜>Nota:
  • Operasi baca bermula dari fail

    Mulakan dengan anjakan semasa fd Sebelum berjaya kembali, anjakan ditambah dengan bilangan bait yang sebenarnya dibaca (anjakan ini boleh ditetapkan sendiri). ;

  • tutup()
  • buf

    Nota: Apabila proses ditamatkan, semua fail yang dibuka akan ditutup secara automatik oleh kernel.

    Cara memanggil sistem asas fail pengendalian Linux

    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 .

    Cara memanggil sistem asas fail pengendalian Linux

    Cara memanggil sistem asas fail pengendalian Linux

    Penerangan fail dan penuding fail

    • FAIL * fdopen (int fd,const char *mode), tukarkan deskriptor fail menjadi penunjuk fail; >

    • lseeek function

    • Fungsi:
    Cari fail terbuka

    off_t lseek(int fd,off_t offset,int whence);

    : Fail sudah dibuka deskriptor;

    • fd: jumlah anjakan; 🎜>

    • : Tetapkan ofset fail untuk mengimbangi bait dari permulaan fail; fail ditetapkan kepada nilai semasa tambah ofset, dan ofset boleh menjadi positif atau negatif, dan offset; boleh positif Boleh negatif (jika ia adalah nilai positif pada masa ini, ia melibatkan fail lubang, sila lihat penjelasan di bawah); kembalikan anjakan fail baharu (Anjakan mutlak) **Jika ralat berlaku, ia adalah -1 apabila meletakkan ke hujung fail, saiz fail boleh dikembalikan; >Fungsi lseek juga boleh digunakan untuk menentukan sama ada fail yang terlibat boleh Tetapkan anjakan Jika deskriptor fail merujuk kepada paip atau FIFO, lseek mengembalikan -1 dan menetapkan errno kepada EPLPE

      offset

    • Contoh fail lubang:

      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

      - c untuk melihat kod ASSCI fail, kita akan mendapati bahawa antara dua kandungan, terdapat 10
    • 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

    Cara memanggil sistem asas fail pengendalian Linux

    Menyalin selesai

    Cara memanggil sistem asas fail pengendalian Linux

    Selepas membuka fail, Bolehkah anak proses fork berkongsi akses kepada fail yang sama seperti proses induk?

    Cara memanggil sistem asas fail pengendalian Linux

    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

    Cara memanggil sistem asas fail pengendalian Linux

    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:

    Cara memanggil sistem asas fail pengendalian Linux

    Sebabnya adalah seperti berikut:

    Cara memanggil sistem asas fail pengendalian Linux

    Ujian 2: Pertama garpu dan kemudian buka fail

    Selepas mengubah suai kod, keputusan yang dijalankan berubah seperti berikut:

    Cara memanggil sistem asas fail pengendalian Linux

    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!

Kenyataan:
Artikel ini dikembalikan pada:yisu.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam