POSIX -lukutoiminto C -ohjelmoinnissa

Posix Read Function C Programing

Perinteisissä POSIX -yhteensopivissa käyttöjärjestelmissä ohjelma käytti lukujärjestelmäkutsua saadakseen tietoja tiedostojärjestelmässä olevasta asiakirjasta. Tiedosto määrittelee asiakirjan kuvaajan, jota käytetään yleensä aiemmasta avauskutsusta. Tämä lukujärjestelmäpuhelu lukee tiedot tavuina ja kokonaisluvun, jonka soittaja määrittää asiakirjasta, ja tallentaa sen sitten kutsumekanismin tarjoamaan puskuriin.

Toiminnon määritelmä

Ennen kuin määrität lukutoiminnon koodissasi, sinun on sisällytettävä pakolliset paketit.



#sisältää

Näin määrität POSIX -lukutoiminnon:



>>ssize_t pread(intnorsunluu,mitätön *buf,koko_tnbyte, off_t offset);
>>ssize_t lukenut(intfd,mitätön *buf,koko_tnbytes);

Lukumenetelmäkutsusta voidaan ottaa kolme parametriargumenttia:



int fd: Tiedoston kuvaaja, josta tiedot on luettava. Voisimme joko käyttää avoimen järjestelmäkutsun kautta hankittua tiedostojen kuvaajaa tai käyttää vain 0, 1 tai 2, jotka viittaavat tyypilliseen tuloon, normaaliin lähtöön tai säännölliseen virheeseen.

Mitätön *buf: Puskuri tai merkkijono, johon luetut tiedot tallennetaan ja säilytetään.

Koko_tbbyte: Niiden tavujen lukumäärä, jotka oli luettava asiakirjasta ennen katkaisua. Kaikki tiedot voidaan tallentaa puskuriin, jos luettavat tiedot ovat lyhyempiä kuin nbytes.



Kuvaus

Read () -menetelmä yrittää lukea 'nbyte' tavuja puskurivälimuistiin, johon 'buf' viittaa, joko tiedostosta, joka on liitetty avoimen asiakirjan kuvaajaan 'Fildes' tai 'fd'. Se ei määritä useiden samanaikaisten lukujen luonnetta samassa virrassa, FIFO: ssa tai päätelaitteessa.

Asiakirjoissa, jotka mahdollistavat lukemisen, lukuprosessi alkaa asiakirjan siirtymästä ja siirtymä kasvaa luetuilla tavuilla. Jos asiakirjan siirtymä on tiedoston reunalla tai sen ulkopuolella, tavuja ei lueta, ja luku () ei anna mitään.

Kun luku on 0, luku () tunnistaa alla mainitut virheet. Jos virheitä ei ole tai jos luku () ei ole kirjattu virheisiin, luku () tuottaa nollaa ja sen lukumäärä on 0 eikä sillä siten ole muita vaikutuksia.

Jos määrä on suurempi kuin SSIZE_MAX POSIX.1: n mukaan, tulos määräytyy toteutuksen mukaan.

Palauta arvo

Saavutuksen jälkeen palautettujen tavujen 'luettu' ja 'valmiiksi' numeroiden on oltava ei-negatiivisia kokonaislukuja, kun taas nolla osoittaa tiedoston loppuun. Asiakirjan sijaintia edistetään tällä numerolla, tai muuten virheen merkitsemiseksi menetelmät palauttavat -1 ja määrittävät 'errno'. Kun tämä luku on pienempi kuin pyydetty tavu, se ei ole tavu. Voi olla mahdollista, että tällä hetkellä käytettävissä on vähemmän tavuja.

Virheet

Esivalmius- ja lukutoiminto epäonnistuu, jos seuraavat virheet ilmenevät:

EAGAIN:

Asiakirjan tai tiedoston kuvaaja 'fd' kuuluu ei-socket-tiedostoon, joka on merkitty estämättömäksi (O NONBLOCK) ja estää lukemisen.

EWOULDBLOCK:

Kuvaaja 'fd' kuuluu pistorasiaan, joka on merkitty estämättömäksi (O_NONBLOCK) ja estää lukeman.

EBADF:

Fd ei välttämättä ole käyttökelpoinen kuvaaja tai se ei ole avoinna lukemista varten.

EFAULT:

Tämä tapahtuu, kun 'buf' on tavoitettavan osoitetilan ulkopuolella.

EINTR:

Ennen tietotietojen lukemista puhelu on saattanut katketa ​​signaalin avulla.

VALINTA:

Tämä virhe ilmenee, kun fd -kuvaaja on osallisena objektissa, joka ei sovellu lukemiseen, tai asiakirja purettiin O_DIRECT -lipun kanssa ja yksi tai toinen buf -osoitteessa mainittu osoite, luku ', tai asiakirjan siirtymä ei liity asianmukaisesti.

VALINTA:

Kuvaaja 'fd' on ehkä muodostettu käyttämällä kutsua timerfd_create (2), ja väärän kokoinen puskuri on annettu luettavaksi.

EIO:

Se on tulo-/lähtövirhe. Se tapahtuu, kun taustaprosessiryhmä yrittää lukea sen päätelaitteesta ja toinen tai toinen jättää huomiotta tai estää SIGTTINin tai sen prosessiryhmä menetetään. Toinen syy tähän virheeseen voi olla matalan tason tulo-/lähtövirhe, kun se lukee kiintolevyltä tai nauhalta. Toinen mahdollinen syy EIO: lle verkotetuissa tiedostoissa on neuvoa antavan lukituksen poistaminen tiedoston kuvaajalta ja kyseisen lukituksen epäonnistuminen.

EISDIR:

Tiedoston kuvaus 'fd' kuuluu hakemistoon.

Huomautuksia:

Myös muita virheitä voi esiintyä, jotka riippuvat kuvaajaan 'fd' linkitetystä objektista. Sekä size_t- että ssize_t -lomakkeet ovat merkitsemättömiä ja merkittyjä POSIX.1: n määrittämiä numeerisia tietotyyppejä. Linuxissa enintään 0x7ffff000 (2 147 479 552) tavua voidaan lähettää lukutoiminnolla (ja vastaavilla järjestelmäpuheluilla) ja palauttaa alun perin lähetettyjen tavujen määrä (sekä 32- että 64-bittisissä alustoissa). NFS -tiedostojärjestelmissä aikaleima muuttuu ensimmäisellä hetkellä, kun pieniä tietovirtoja luetaan, myöhemmät puhelut eivät tee niin. Se laukaistaan ​​asiakaspuolen attribuuttien välimuistista, koska vaikka kaikki eivät, NFS-asiakkaat lopettavat päivityksen palvelimelle st_atime (viimeinen tiedoston käyttöaika) kautta, ja asiakkaan puskurista saadut asiakaspuolen lukemat eivät aiheuta muutoksia st. atime palvelimella, koska palvelinpuolen lukemia ei ole saatavilla. Kun poistat asiakaspuolen attribuuttien välimuistin, UNIX-metatietoja voidaan käyttää, mutta tämä lisäisi merkittävästi palvelimen kuormitusta ja vaikuttaisi useimmissa tapauksissa tuottavuuteen.

Esimerkki 01:

Tässä on C -ohjelma, joka osoittaa lukutoiminnon kutsun Linux -järjestelmässä. Kirjoita alla oleva komento sellaisenaan uuteen tiedostoon. Lisää kirjastoja ja alustaa kuvaaja ja koko päätoiminnossa. Kuvaaja avaa tiedoston, ja kokoa käytetään tiedoston tietojen lukemiseen.

Yllä olevan koodin lähtö on alla olevan kuvan mukainen.

Esimerkki 02:

Alla on toinen esimerkki lukutoiminnon toiminnan havainnollistamiseksi.

Luo toinen tiedosto ja kirjoita alla oleva koodi muistiin. Tässä on kaksi kuvaajaa, fd1 ja fd2, joilla molemmilla on oma pääsy avoimen taulukon tiedostoihin. Joten foobar.txt -tiedostossa jokaisella kuvaajalla on tiedoston sijainti. Foobar.txt -tiedoston ensimmäinen tavu käännetään fd2: sta, ja tulos on c = f, ei c = o.

Johtopäätös

Olemme lukeneet C -ohjelmoinnin POSIX -lukutoiminnon tehokkaasti. Toivottavasti epäilyksiä ei ole jäljellä.