שאלות נפוצות
ציר זמן
צ'אט
פרספקטיבה

LFE

שפת תכנות מוויקיפדיה, האנציקלופדיה החופשית

Remove ads

LFE (קיצור של Lisp Flavored Erlang) היא שפת תכנות פונקציונלית בעלת מערכת איסוף זבל ממשפחת שפות Lisp, שתוכננה ופותחה על ידי רוברט וירדינג (Robert Virding) ושוחררה לראשונה בשנת 2008. היא בנויה על Core Erlang ועל BEAM, המכונה הווירטואלית של שפת התכנות Erlang.

יש לערוך ערך זה. ייתכן שהערך סובל מבעיות ניסוח, סגנון טעון שיפור או צורך בהגהה, או שיש לעצב אותו, או מפגמים טכניים כגון מיעוט קישורים פנימיים.
עובדות מהירות פרדיגמות, תאריך השקה ...
Remove ads

תכונות

LFE פותחה באמצעות Erlang כדי ליצור ניב Lisp שיתמוך ב-Fault Tolerance ( היכולת של מערכת לתפקד גם כאשר אחד מרכיביה כושל ) ובמערכות זמן אמת. בנוסף, היא תומכת בחישוב מבוזר. אחד היתרונות המשמעותיים ביותר בכתיבת קוד ב-LFE הוא שניתן לגשת לספריות ה-OTP של Erlang לצורך הפיתוח.

LFE היא שפה מרובת פרדיגמות, כלומר, היא תומכת במספר עקרונות תכנותיים:

תכנות פונקציונלי - תכנות פונקציונלי שם דגש על קריאה לפעולות ופישוטן כביטויים.

מטא תכנות - בפרדיגמה זו, ניתן ״לשכתב את השפה״, כלומר, לשנות ערכים ופעולות אשר מוגדרים בשפה.

Concurrent Computing - חישובים מסוימים מתרחשים במקביל, במקום באופן סדרתי (זה אחר זה).

ל-LFE ישנה מערכת איסוף זבל, כלומר, מערכת שבה סביבת הריצה של תוכנית מחשב משחררת באופן אוטומטי זיכרון שהוקצה דינאמית, ואין בו עוד צורך.

Remove ads

היסטוריה

פיתוח LFE החל בשנת 2007, כאשר רוברט וירדניג החל ליצור אב טיפוס של שפת Lisp שרצה ב-Erlang. וירדינג הכריז על שחרור הגרסה הראשונה של LFE במרץ 2008. הגרסה הראשונה הייתה מוגבלת ולא היה מעטפת ( Shell ) של Lisp .

רציונל

רוברט וירדינג הצהיר שיצר את LFE ממספר סיבות:

  • היה לו ניסיון מוקדם של תכנות עם Lisp.
  • הוא היה מעוניין לבצע מימוש של Lisp משלו בשפת התכנות Erlang.
  • הוא היה סקרן לראות כיצד מימוש זה יבוצע ויראה.
  • מאז שסייע בפיתוח Erlang, רצה וירדינג ליצור ניב Lisp אשר יוכל לרוץ על BEAM ( המכונה הווירטואלית של Erlang ) ויוכל לבצע אינטראקציה מלאה עם Erlang וספריות ה-OTP שלה.
  • הוא רצה להתנסות בלבצע הידור של שפה אחרת ב-Erlang.

תחביר

Symbolic Expressions

כמו ניבי Lisp רבים, LFE היא שפה שבה כל הקוד והמידע נכתבים כביטויים, וישנה הפרדה מועטה עד לא קיימת בתחביר של הצהרה לעומת של ביטוי. כל ביטוי נכתב בתוך סוגריים, ונקראים Symbolic Expression, או בקיצור- S Expression.

רשימות

ב-LFE, האיברים במבנה הנתונים רשימה (list) מופרדים על ידי רווח. רשימה מוגדרת על ידי המילה השמורה list בתחילת הביטוי ( כחלק מהכתיב התחילי של ניבי Lisp ), לדוגמה:

(list 1 2 'foo)

רשימה זו מורכבת מהמספרים 1 ו-2 ומה- symbol foo׳.

Remove ads

דוגמאות קוד

ניתן לתכנת ב- LFE באמצעות שורת פקודה (המכונה REPL-Read Evaluate Print Loop) או בקובץ (פרויקט).

דוגמה ליצירת משתנה מסוג רשימה בשורת הפקודה של LFE :

> (set my-list (lists:seq 1 6))
(1 2 3 4 5 6)

דוגמה לפונקציה בפרויקט שהפלט שלה הוא hello-world' - מסוג symbol:

(defmodule my-test-lib
 (export (my-fun 0)))

;;; -----------
;;; library API
;;; -----------

(defun my-fun ()
 'hello-world)

המילה השמורה defmodule ( קיצור של define module ) יוצרת מודול, והמילה השמורה defun ( קיצור של define function ) יוצרת פעולה. על מנת לייצא את הפעולה, משתמשים בפעולה המובנית export אשר לוקחת כפרטמטר את שם הפעולה ( my-fun ) וכן את מספר הפרמטרים ( 0 ).

Remove ads

ציר זמן של ניבי Lisp

מידע נוסף LISP 2, LISP 1.5, LISP 1, Maclisp ...
Remove ads

קישורים חיצוניים

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads