معضلة العام 2038

معضلة عام 2038 (المعروفة أيضًا باسم Y2038 ، [1] Y2K38 ، أو ايبوكلابيس[2] [3]) هي خطأ برمجي في تنسيق الوقت في أنظمة الكمبيوتر ذات معمارية 32 بت عند محاولتها تمثيل الأوقات بعد الساعة 03:14:07 بالتوقيت العالمي المنسق في الـ19 يناير 2038.

صورة متحركة توضح المعضلة أثناء حدوثها. تجاوز السعة يحدث عند الساعة 03:14:08.

تتواجد المشكلة في الأنظمة التي تقيس الوقت بنظام توقيت يونكس - حيث تُقاس عدد الثواني المنقضية منذ «عصر يونكس» والذي يبدأ من منتصف الليل من 1 كانون الثاني 1970 حسب التوقيت العالمي المنسق (00:00:00 UTC في 1 يناير 1970) - ويكون تخزين عدد الثواني في نوع البيانات الذي يدعى «عدد صحيح بإشارة ذو حجم 32 بت». نوع البيانات هذا قادر فقط على تمثيل الأعداد الصحيحة بين سالب 231 (2 إلى قوة 31) وموجب 1 -231، مما يعني أن آخر وقت يمكن ترميزه هو 1 -231 ثانية بعد عصر يونكس والذي يكون (03:14:07 بالتوقيت العالمي المنسق في 19 يناير 2038). ستؤدي محاولة تمثيل الثانية التالية (03:14:08) إلى تجاوز العدد الصحيح أي تجاوز القدرة التخزينية لنوع البيانات «عدد صحيح بإشارة ذو حجم 32 بت»، ما سيؤدي إلى حدوث خطأ يؤدي إلى تعيين قيمته لسالب 231 والتي ستفسرها الأنظمة على أنها 231 ثانية قبل عصر يونكس والذي سيكون الساعة 20:45:52 بالتوقيت العالمي المنسق في 13 ديسمبر 1901. إن المعضلة مشابهة في طبيعتها لمشكلة عام 2000 .

قد تواجه أنظمة الكمبيوتر التي تستخدم نظام توقيت يونكس في العمليات الهامة أخطاء فادحة إذا لم يتم حل معضلة Y2038 مبكرًا. وقد حدث أن واجهت بعض الأنظمة التي تستخدم التواريخ اللاحقة الأخطاء بالفعل. أكثر الأنظمة عرضة للأخطاء هي تلك التي نادرًا ما يتم تحديثها أو لا يتم تحديثها أبدًا، مثل الأنظمة القديمة أو المدمجة. لا يوجد حل شامل لهذه المشكلة، لكنه تم بالفعل تحديث العديد من الأنظمة الحديثة لقياس وقت يونكس بأعداد صحيحة حسب معمارية 64 بت والتي لن يحدث بها تجاوز للسعة ل حتى 292 مليار.

السبب

تقيس العديد من أنظمة الكمبيوتر الوقت والتاريخ على أنه وقت يونكس، وهو معيار دولي لعرض الوقت رقميًا في الأنظمة الحاسوبية. يتم تعريف وقت يونكس على أنه عدد الثواني المنقضية منذ منتصف الليل (00:00:00) بالتوقيت العالمي المنسق من 1 يناير 1970 (تم اختيار هذا الوقت عشوائيًا من قبل المبرمجين)، وأطلق على هذا الوقت اسم عصر يونكس.

تم ترميز وقت يونكس تاريخيًا باعتباره عددًا صحيحًا بإشارة ذو حجم 32 بت (اسم آخر: عدد صحيح 32 بت بإشارة)، وهو نوع بيانات يتكون من 32 رقمًا ثنائيًا (بت) والتي تمثل قيمة عدد صحيح، حيث تعني كلمة «بإشارة» أن هناك بت واحدة محجوزة لإشارة الموجب أو السالب (+/-). وبالتالي، يمكن أن يُمثَّل قيمًا صحيحة فقط من سالب 231 إلى موجب 1 -231 ضمناً. وبالتالي، إذا تم استخدام عدد صحيح 32 بت بإشارة لتخزين وقت يونكس، فإن آخر وقت يمكن تخزينه هو 1 -231 الذي يساوي 2,147,483,647 ثانية بعد عصر يونكس، والذي يكون الساعة 03:14:07 UTC في الـ19 يناير 2038.[4] الأنظمة التي تحاول زيادة هذه القيمة بمقدار ثانية واحدة لتصل إلى 231 ثانية بعد عصر يونكس (03:14:08) ستعاني من تجاوز عدد صحيح، مما يؤدي عن غير قصد إلى قلب بت الإشارة إلى سالب. يؤدي هذا إلى تغيير قيمة العدد الصحيح إلى سالب 231 ، أي 231 ثانية قبل عصر يونكس وليس بعده ، والتي ستفسرها الأنظمة على أنها الساعة 20:45:52 يوم الجمعة، 13 ديسمبر 1901. من هنا، ستستمر الأنظمة في العد التصاعدي، باتجاه الصفر (أي باتجاه عصر يونكس)، ثم لأعلى خلال الأعداد الصحيحة الموجبة مرة أخرى. نظرًا لأن العديد من أنظمة الكمبيوتر تستخدم حسابات الوقت لعمل وظائف مهمة، فقد تؤدي المعضلة إلى حدوث أخطاء فادحة.

انظر أيضا

مراجع

  1. "Is the Year 2038 problem the new Y2K bug?"، The Guardian، 17 ديسمبر 2014، مؤرشف من الأصل في 25 يناير 2022، اطلع عليه بتاريخ 11 أكتوبر 2018.
  2. Bergmann, Arnd (6 فبراير 2020)، "The end of an Era"، Linaro، مؤرشف من الأصل في 18 أبريل 2021.
  3. Wagenseil, Paul (28 يوليو 2017)، "Digital 'Epochalypse' Could Bring World to Grinding Halt"، Tom's Guide، مؤرشف من الأصل في 29 نوفمبر 2021.
  4. Diomidis Spinellis (2006)، Code quality: the open source perspective، Effective software development series in أوريلي ميديا (ط. illustrated)، Adobe Press، ص. 49، ISBN 978-0-321-16607-4، مؤرشف من الأصل في 18 مايو 2021.
  • بوابة علم الحاسوب
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.