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

من ويكيبيديا، الموسوعة الحرة
[مراجعة غير مفحوصة][مراجعة غير مفحوصة]
تم حذف المحتوى تمت إضافة المحتوى
Addbot (نقاش | مساهمات)
ط بوت: ترحيل 37 وصلة إنترويكي, موجودة الآن في ويكي بيانات على d:q193076
لا ملخص تعديل
سطر 18: سطر 18:
[[تصنيف:أنماط برمجة]]
[[تصنيف:أنماط برمجة]]
[[تصنيف:برمجة|وظيفية]]
[[تصنيف:برمجة|وظيفية]]
[[تصنيف:علم الحاسوب| ]]
{{بوابة علم الحاسوب}}
{{علم الحاسوب}}

نسخة 09:19، 26 أبريل 2013

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

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

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

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

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

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

المراجع

concepts of programming languages By Robert W.Sebesta قالب:بوابة علم الحاسوب