برمجة وظيفية: الفرق بين النسختين

من ويكيبيديا، الموسوعة الحرة
[مراجعة غير مفحوصة][مراجعة غير مفحوصة]
تم حذف المحتوى تمت إضافة المحتوى
لا ملخص تعديل
سطر 1: سطر 1:
{{صفحة جديدة|تاريخ=أغسطس 2008}}
{{صفحة جديدة|تاريخ=أغسطس 2008}}
[[تصنيف: برمجة]]
'''البرمجة الوظيفية'''
'''البرمجة الوظيفية'''
البرمجة الوظيفية هي البرمجة التي تتعامل مع الحسابات كحل الدوال الرياضية باتباع قواعد و قوانين رياضية. الهدف من البرمجة الوظيفية محاكاة طريقة حل الدوال الرياضية بأكبر درجة ممكنة .هذا الهدف هو ماجعل البرمجة الوظيفية تختلف تمامًا عن البرمجة باستخدام لغات الأوامر في طريقة تعاملها مع المشكلات و حلها .
البرمجة الوظيفية هي [[البرمجة]] التي تتعامل مع الحسابات كحل الدوال الرياضية باتباع قواعد و قوانين رياضية. الهدف من البرمجة الوظيفية محاكاة طريقة حل الدوال الرياضية بأكبر درجة ممكنة .هذا الهدف هو ماجعل البرمجة الوظيفية تختلف تمامًا عن البرمجة باستخدام لغات الأوامر في طريقة تعاملها مع المشكلات و حلها .


== اللغات الوظيفية ==
== اللغات الوظيفية ==
سطر 10: سطر 11:
بالرغم من أفضلية اللغات الوظيفية البحتة على تلك المستخدمة كلغات أوامر إلا أن ضعف تنفيذها على الحاسبات المبنية على نموذج فون نيومان (von Neumann) حد من استخدامها و انتشارها.
بالرغم من أفضلية اللغات الوظيفية البحتة على تلك المستخدمة كلغات أوامر إلا أن ضعف تنفيذها على الحاسبات المبنية على نموذج فون نيومان (von Neumann) حد من استخدامها و انتشارها.


أشهر هذه اللغات و أقدمها هي الـ LISP
أشهر هذه اللغات و أقدمها هي الـ Lisp
و منها أيضا Haskell و Scheme و ML و لغات أخرى كثيرة و متعددة




== المراجع ==
== المراجع ==

نسخة 11:18، 20 يونيو 2009

خطأ في التعبير: عامل < غير متوقع.

البرمجة الوظيفية البرمجة الوظيفية هي البرمجة التي تتعامل مع الحسابات كحل الدوال الرياضية باتباع قواعد و قوانين رياضية. الهدف من البرمجة الوظيفية محاكاة طريقة حل الدوال الرياضية بأكبر درجة ممكنة .هذا الهدف هو ماجعل البرمجة الوظيفية تختلف تمامًا عن البرمجة باستخدام لغات الأوامر في طريقة تعاملها مع المشكلات و حلها .

اللغات الوظيفية

في اللغات الوظيفية البحتة لا يوجد أي استخدام للمتغيرات أو جمل المساواة مما يعطي حرية أكبر للمبرمج بحيث لايهتم للأماكن المحجوزة لبرنامجه في الذاكرة.كذلك يتم التحكم في مسار تنفيذ البرنامج باستخدام الدوال الرياضية و الجمل الشرطية و الاستدعاء الذاتي بدلاً من تنفيذه بطريقة متسلسلة و باستخدام التكرار (iterative repetition) كما هو الحال مع لغات الأوامر.

ميزة أخرى مهمة في هذه اللغات و هي أنها تُعطي نفس النتيجة إذا أُعطيت نفس المتغيرات ، هذه الخاصية هي ما تُطلق عليهاالشفافية المرجعية (referential transparency) .بالرغم من أن تنفيذ اللغات الوظيفية يتم بواسطة المترجمات (interpreters) إلا أنه يمكن عمل(compilation) لها.كذلك تحوي هذه اللغات تركيب هيكلي بسيط جدًا .الدوال المعقدة يتم بنائها باستخدام مايُطلق عليه نماذج وظيفية (functional forms) أي أن الدوال تستخدم كمتغيرات مرسلة أو قيم مرتجعة أو كلاهما.

بالرغم من أفضلية اللغات الوظيفية البحتة على تلك المستخدمة كلغات أوامر إلا أن ضعف تنفيذها على الحاسبات المبنية على نموذج فون نيومان (von Neumann) حد من استخدامها و انتشارها.

أشهر هذه اللغات و أقدمها هي الـ Lisp و منها أيضا Haskell و Scheme و ML و لغات أخرى كثيرة و متعددة


المراجع

concepts of programming languages By Robert W.Sebesta