وظيفة قراءة POSIX في برمجة C.

Posix Read Function C Programing



في أنظمة التشغيل التقليدية المتوافقة مع POSIX ، للحصول على معلومات من مستند موجود في نظام الملفات ، استخدم البرنامج استدعاء نظام القراءة. يتم تحديد واصف المستند الذي يتم الوصول إليه عادةً من استدعاء سابق لفتحه بواسطة الملف. يقرأ استدعاء نظام القراءة هذا المعلومات بالبايت والعدد الصحيح الذي يحدده المتصل من المستند ، ثم يحفظه في مخزن مؤقت توفره آلية الاستدعاء.

تعريف الوظيفة

قبل تحديد وظيفة القراءة في التعليمات البرمجية الخاصة بك ، يجب عليك تضمين بعض الحزم المطلوبة.







#يشمل

إليك كيفية تحديد وظيفة قراءة POSIX:



>>ssize_t pread(intعاج،فارغ *بوفsize_tnbyte ، off_t offset)؛
>>قراءة ssize_t(intfdفارغ *بوفsize_tن بايت)؛

يمكن الحصول على ثلاث معاملات معامِلات من استدعاء طريقة read:



int fd: واصف الملف للملف الذي سيتم قراءة المعلومات منه. يمكن أن نستخدم إما واصف ملف تم الحصول عليه عن طريق استدعاء نظام مفتوح ، أو يمكننا فقط استخدام 0 أو 1 أو 2 للإشارة إلى الإدخال النموذجي أو الإخراج العادي أو الخطأ العادي ، على التوالي.





باطل * بوف: المخزن المؤقت أو مجموعة الأحرف التي يجب حفظ البيانات المقروءة فيها والاحتفاظ بها.

الحجم_البايت: عدد البايت المطلوب قراءته من المستند قبل الاقتطاع. يمكن تخزين جميع المعلومات في المخزن المؤقت إذا كانت المعلومات المراد قراءتها أقصر من nbytes.



وصف

تحاول طريقة read () قراءة بايت 'nbyte' في ذاكرة التخزين المؤقت المؤقت المشار إليها بواسطة 'buf' إما من الملف المرتبط بموصف المستند المفتوح 'Fildes' أو 'fd'. لا تحدد طبيعة العديد من القراءات المتزامنة على نفس الدفق أو FIFO أو الوحدة الطرفية.

في المستندات التي تمكّن القراءة ، تبدأ عملية القراءة عند إزاحة المستند ، وتتم زيادة الإزاحة بعدد وحدات البايت المقروءة. إذا كانت إزاحة المستند عند حافة الملف أو خارجها ، فلا توجد وحدات بايت للقراءة ، ولا ينتج عن القراءة () أي بايت.

عندما يكون العدد صفرًا ، ستتعرف قراءة () على الأخطاء المذكورة أدناه. إذا لم تكن هناك أخطاء ، أو إذا لم يتم حساب القراءة () بالأخطاء ، فإن القراءة () ينتج عنها صفر مع عدد 0 وبالتالي ليس لها تداعيات أخرى.

إذا كان العدد أكبر من SSIZE_MAX ، وفقًا لـ POSIX.1 ، فسيتم تحديد النتيجة من خلال التنفيذ.

قيمة الإرجاع

يجب أن يكون عدد البايتات 'قراءة' و 'pread' التي تم إرجاعها عند الإنجاز عددًا صحيحًا غير سالب بينما يشير الصفر إلى نهاية الملف. يتقدم موضع المستند بهذا الرقم ، وإلا ، للدلالة على خطأ ، ترجع الطرق -1 وتعيين 'خطأ'. عندما يكون هذا الرقم أقل من عدد البايت المطلوب ، فإنه ليس بايت خطأ. قد يكون من الممكن أن يكون عدد البايتات المتاحة أقل في الوقت الحالي.

أخطاء

لن تنجح وظيفة pread و read في حالة حدوث هذه الأخطاء:

EAGAIN:

ينتمي واصف المستند أو الملف 'fd' إلى ملف غير مأخذ توصيل تم تصنيفه على أنه غير محظور (O NONBLOCK) وسيحظر القراءة.

EWOULDBLOCK:

ينتمي الواصف 'fd' إلى المقبس الذي تم تصنيفه على أنه غير محظور (O_NONBLOCK) وسيحظر القراءة.

EBADF:

قد لا يكون 'fd' واصفاً قابلاً للاستخدام ، أو قد لا يكون مفتوحًا للقراءة.

EFAULT:

يحدث هذا عندما يكون 'buf' الخاص بك خارج مساحة العنوان التي يمكن الوصول إليها.

EINTR:

قبل قراءة بيانات المعلومات ، قد تكون المكالمة قد انفصلت بسبب إشارة.

اختيار:

يحدث هذا الخطأ عندما يكون واصف 'fd' الخاص بك متورطًا في كائن ، وهو غير مناسب للقراءة ، أو عندما يكون المستند غير مرتبط بعلامة O_DIRECT ، وعنوان واحد أو آخر مذكور في 'buf' ، القيمة المشار إليها في 'count أو لم يتم إقران إزاحة المستند بشكل مناسب.

اختيار:

قد يكون قد تم تشكيل الواصف 'fd' باستخدام استدعاء لـ timerfd_create (2) ، وقد تم إعطاء المخزن المؤقت للحجم غير الصحيح للقراءة.

EIO:

إنه خطأ إدخال / إخراج. يحدث ذلك عندما تحاول مجموعة معالجة الخلفية القراءة من مطرافها التنظيمي ، ويكون أحدهما أو الآخر يتجاهل أو يحجب SIGTTIN ، أو أن مجموعة العمليات الخاصة به قد فقدت. قد يكون سبب آخر لهذا الخطأ هو خطأ الإدخال / الإخراج منخفض المستوى أثناء القراءة من قرص ثابت أو شريط. سبب آخر محتمل لـ EIO على ملفات البيانات المتصلة بالشبكة هو إزالة القفل الإرشادي على واصف الملف وفشل هذا القفل.

EISDIR:

ينتمي واصف الملف 'fd' إلى دليل.

ملحوظات:

قد تحدث العديد من الأخطاء الأخرى أيضًا ، بناءً على الكائن المرتبط بالواصف 'fd'. كلا النموذجين size_t و ssize_t هما نوعان من أنواع البيانات الرقمية غير المميزة والمحددة بواسطة POSIX.1. في نظام Linux ، يمكن إرسال 0x7ffff000 (2،147،479،552) بايت على الأكثر عن طريق وظيفة القراءة (واستدعاءات النظام المكافئة) ، مع إرجاع عدد البايتات التي تم إرسالها في الأصل (على كل من الأنظمة الأساسية 32 بت و 64 بت). مع أنظمة ملفات NFS ، في اللحظة الأولى فقط يتم تغيير الطابع الزمني عن طريق قراءة تدفقات صغيرة من المعلومات ، فإن الاستدعاءات اللاحقة لن تفعل ذلك. يتم تشغيله عن طريق التخزين المؤقت لسمات جانب العميل لأنه ، على الرغم من أنه ليس كل عملاء NFS ، توقفوا عن التحديث إلى الخادم عبر st_atime (وقت الوصول إلى الملف الأخير) وقراءات جانب العميل التي تم الوفاء بها من المخزن المؤقت للعميل لن تؤدي إلى إجراء تغييرات على st- في أي وقت على الخادم حيث لا تتوفر قراءات من جانب الخادم. من خلال إزالة التخزين المؤقت للسمة من جانب العميل ، يمكن الوصول إلى بيانات تعريف UNIX ، ولكن هذا سيزيد بشكل كبير من الحمل على الخادم ويؤثر على الإنتاجية في معظم الحالات.

المثال 01:

هنا برنامج C لتوضيح استدعاء وظيفة القراءة على نظام Linux. اكتب الأمر أدناه كما هو في ملف جديد. أضف مكتبات ، وفي الوظيفة الرئيسية ، قم بتهيئة واصف وحجم. يقوم الواصف بفتح الملف ، ويستخدم الحجم لقراءة بيانات الملف.

سيكون إخراج الكود أعلاه كما هو موضح في الصورة أدناه.

المثال 02:

ويرد أدناه مثال آخر لتوضيح عمل وظيفة القراءة.

قم بإنشاء ملف آخر واكتب الكود أدناه كما هو. فيما يلي وصفان ، fd1 و fd2 ، كلاهما لهما إمكانية الوصول إلى ملف الجدول المفتوح الخاص بهما. لذلك بالنسبة إلى foobar.txt ، يكون لكل واصف موقع ملف خاص به. تتم ترجمة البايت الأول من foobar.txt من fd2 ، والنتيجة هي c = f وليس c = o.

استنتاج

لقد قرأنا وظيفة قراءة POSIX في برمجة C بكفاءة. نأمل ألا تكون هناك شكوك.