• وبلاگ : پاي سيب
  • يادداشت : Cellular automaton
  • نظرات : 0 خصوصي ، 82 عمومي
  • ساعت ویکتوریا

    نام:
    ايميل:
    سايت:
       
    متن پيام :
    حداکثر 2000 حرف
    كد امنيتي:
      
      
     
    + ليسپ 
    زبان‌هاي برنامه نويسي Lisp معمولا از يک خط دستور محاوره‌اي استفاده مي‌کنند،که مي‌تواند با يک محيط پيچيده? گسترش يافته ترکيب شود.کاربر اصطلاحات و دستورات را در خط دستور وارد کرده يا با رهبري IDE آنها را به سيستم Lisp مي‌فرستد. Lisp دستورات را مي‌خواند ، آن‌ها را ارزيابي مي‌کند و نتايج را چاپ مي‌کند. به اين دليل است که خط دستور زبان Lisp به حلقه? Read-Eval-Print يا REPL معروف است.
    نمونه? ساده‌اي از عمليات REPL در زير آمده‌است. اين يک شرح ساده‌است که بسياري از المان‌هاي Lispواقعي در آن نميايد مانند ماکروها و کوئت‌ها.
    تابع read جملات متني را به عنوان ورودي مي‌پذيرد و آنها را به ساختار ليست تجزيه مي‌کند. به عنوان مثال ، وقتي شما رشته? (+ 1 2) را در اعلان تايپ مي‌کنيد، تابع read آن را به يک ليست پيوندي حاصل از 3 المان ترجمه مي‌کند: علامت + ، عدد 1 و عدد 2 . خيلي اتفاق مي‌افتد که ليست قسمت موثري از يک کد Lisp باشد که قابل ارزيابي است.به همين دليل است که يک قطار از ليست به يک تابع نام عملگر مع مي‌دهد.
    تابع eval ساختار ليست را ارزيابي مي‌کند و نوعي ديگر از ساختار را به عنوان نتيجه باز مي‌گرداند.ارزيابي کردن لزوما تفسير کردن معني نمي‌دهد؛ بعضي سيستم‌هاي Lisp هر عبارتي را به زبان ماشين تبديل مي‌کنند. خيلي ساده است؛ به هر حال؛ براي تعريف ارزيابي به عنوان تفسير : براي ارزيابي يک ليست که نام تابع دارد ، eval ابتدا تمام آرگومان‌هاي داده شده به cdr اش را ارزيابي مي‌کند و سپس تابع را روي آن آرگومان‌ها اعمال مي‌کند.در اين مثال ، تابع عمل جمع است و به آرگومان‌هاي (1 2) اعمال مي‌شود که نتيجه 3 است.اين نتيجه? ارزيابي است.
    اين وظيفه? تابع print است که نتيجه را به کاربر نمايش دهد. براي نتيجه? ساده? 3 اين کار ناقابل است. يک عبارت که با قسمتي از ساختار ليست ارزيابي مي‌شود مياز دارد که print ليست را به حرکت در آورد و در خروجي به شکل يک عبارت S نمايش دهد.
    براي اجرا کردن يک REPL در Lisp ، تنها لازم است که اين سه تابع را اجرا کنيد و يک تابع حلقه بي نهايت را.(به طور طبيعي اجراي eval پس از اجراي عملگرهاي ويژه‌اي مانند if پيچيده خواهد شد.)يک REPL ساده به خودي خود با يک خط کد انجام شد: (loop(print(eval(red))))

    ليست در اصل تعداد کمي ساختار کنترلي دارد. منتها در تکامل و گسترش زبان تعداد زيادي به آن اضافه شدند.(عملگر اصلي شرايط در زبان Lisp که cond بود بعدا متشکل شد از ساختار if-then-else )

    برنامه نويسان در نسخه? Scheme حلقه‌ها را به صورت بازگشت دم( tail recursion ) بيان مي‌کنند. موسسات متعارف علوم کامپيوتر Scheme بعضي دانشجويان را متعاقد مي‌کند که تنها راه تکرار در زبان Lisp استفاده از بازگشت دم است؛ اين اشتباه است. تمامي نسخه‌هاي متداول ديده شده از Lisp داراي ساختارهاي الزامي براي تکرار هستند.درScheme دستور do به عنوان دستور حلقه پيچيده? Lisp است. علاوه بر اين مساله? اصلي که شي گرايي را مهمتر از مساله? فاعلي کرده اين است که Scheme نيازهاي ويژه‌اي براي کارکردن با فراخواني دم(tail calls )دارد، در نتيجه دليل ترغيب Scheme به استفاده از بازگشت دم اين است که روش صراحتا با تعريف خود زبان پشتيباني مي‌شود . در مقابل ، ANSI Common Lisp نيازي به بهينه سازي که معمولا به حذف فراخواني دم گفته مي‌شود ندارد. در نتيجه اين حقيقت که بازگشت دم به عنوان يک جايگزين تصادفي براي استفاده از ساختارهاي مبتني بر تکرار ( مانند do dolist loop ) توصيه نمي‌شود تنها يک مساله? برتري ادبي نيست ، ولي بالقوه يکي از کارآمدهاست ( بعد از اين که اين روش فقط به عنوان يک پرش ساده به کار نرفت) و به عنوان يک تصحيح برنامه‌است .
    بعضي از ساختارهاي کنترلي Lisp عملگرهاي ويژه‌اي هستند ، هم ارز کليدواژه‌هاي ترکيبي باقي زبان‌ها. عباراتي که اين عملگرها استفاده مي‌کنند ظاهري شبيه فراخواني تابع دارد، تفاوت اينجاست که آرگومان‌ها ضرورتا نبايد ارزيابي شوند يا در مورد تکرار شايد بارها ارزيابي شوند. در مقابل اکثر زبان‌هاي برنامه نويسي ، Lisp به برنامه نويسان اجازه مي‌دهد با خود زبان ساختاهاي کنترلي را پياده سازي کنند.ساختارهاي کنترلي زيادي در ماکروهاي Lisp پياده سازي مي‌شوند و برنامه نويسان مي‌توانند هر ماکرو را گسترش دهند ،براي آناني که مي‌خواهند بدانند چطور کار مي‌کند.
    هر دوي Lisp Commonو Scheme داراي عملگرهاي کنترلي غير محلي هستند.تفاوت اين عملگرها يکي از عميق ترين تفاوت‌ها مابين اين دو نسخه? زبان است. Scheme از ورودي مستمر با استفاده از روش call/cc پشتيباني مي‌کند ، که به برنامه اجازه? ذخيره ( و بعدا بازيابي کردن) يک عمليات ويژه را مي‌دهد . Common Lisp از ورودي مستمر پشتيباني نمي‌کند ولي از راه‌هاي زيادي براي انجام رهايي از تکرار پشتيباني مي‌کند.