സിഎൽയു (പ്രോഗ്രാമിങ് ഭാഷ)

പ്രോഗ്രാമിങ് ഭാഷ From Wikipedia, the free encyclopedia

Remove ads

മസ്സാചുസെറ്റ്സ് ഇൻസ്റ്റിറ്റ്യൂട്ട് ഓഫ് ടെക്നോളജിയിൽ (എം.ഐ.ടി) സ്ഥാപിച്ച പ്രോഗ്രാമിങ് ഭാഷയാണ് സിഎൽയു(CLU). 1974 നും 1975 നും ഇടയിൽ ബാർബറ ലിൽക്കോവും അവരുടെ വിദ്യാർത്ഥികളും ചേർന്നാണ് ഇത് രൂപപ്പെടുത്തിയെടുത്തത്. ഇത് വിപുലമായ ഉപയോഗത്തിലില്ലെങ്കിലും, ഇപ്പോൾ അത് വ്യാപകമായി ഉപയോഗിക്കപ്പെടുന്ന പല സവിശേഷതകളും അവതരിപ്പിച്ചു, ഒബ്ജക്റ്റ് ഓറിയെൻറഡ് പ്രോഗ്രാമിങ്ങിൻറെ (OOP) വികസനത്തിൽ ഒരു ഘട്ടം എന്ന നിലയിലാണ് ഇത് കാണുന്നത്.

വസ്തുതകൾ ശൈലി:, രൂപകൽപ്പന ചെയ്തത്: ...

അമൂർത്തമായ ഡാറ്റ തരങ്ങൾ, [4] കോൾ-ബൈ-ഷെയറിംഗ്, ഇറ്റേറ്റെർസ്, മൾട്ടിപ്പിൾ റിട്ടേൺ വാല്യൂസ് (ഒരു സമാന്തര അസൈൻമെൻറ്), ടൈപ്പ്-സുരക്ഷിതമായ പാരാമീറ്ററൈസ്ഡ് തരങ്ങൾ, ടൈപ്പ്-സേഫ് വേരിയൻറ് തരങ്ങൾ എന്നിവയാണ് പ്രധാന സംഭാവനകൾ. കൺസ്ട്രറ്ററുകളും രീതികളും ഉപയോഗിക്കുന്നതും, എന്നാൽ ഇൻഹെറിറ്റെൻസ് (Inheritance) ഇല്ലാത്തതുമാണ്.

Remove ads

ക്ലസ്റ്ററുകൾ

ഏറ്റവും പുതിയ ഭാഷാ രൂപകൽപ്പനകൾക്ക് തുടക്കമിടാൻ ആൽഗോൾ(ALGOL) അടിസ്ഥാനമാക്കിയുള്ളതാണ് സിഎൽയുടെ സിൻറാക്സ്. ഒരു കൂട്ടം ക്ലസ്റ്റർ എന്ന ആശയം, സിഎൽയുടെ ടൈപ്പുചെയ്യൽ വിപുലീകരണവും ഭാഷയുടെ പേരിൻറെ റൂട്ട് (CLUster) ആണ്.[5]ക്ലസ്റ്ററുകൾ ഒരു ഒഒ (OO) ഭാഷയിലെ "ക്ലാസ്" എന്ന സങ്കല്പത്തിന് സാധാരണയായി യോജിക്കുന്നു, സമാന സിന്റാക്സ് ഉണ്ട്. ഉദാഹരണത്തിന്, സങ്കീർണ്ണ സംഖ്യകൾ കൊണ്ടുവരുന്ന ഒരു ക്ലസ്റ്ററിനായുള്ള സിഎൽയു സിൻറാക്സ് ഇതാണ്:

    complex_number = cluster is add, subtract, multiply, ...
        rep = record [ real_part: real, imag_part: real ]
        add = proc ... end add;
        subtract = proc ... end subtract;
        multiply = proc ... end multiply;
        ...
    end complex_number;

ഒരു ക്ലസ്റ്റർ എന്നത് ഒരു മൊഡ്യൂളാണ്, അതിൻറെ എല്ലാ ഘടകങ്ങളും സംഗ്രഹിക്കുന്നു, "is" ക്ലോസിൽ സ്പഷ്ടമായി പേരുള്ളത് ഒഴികെ. ഇത് സമീപകാല ഒഒ (OO) ഭാഷകളിൽ ഒരു ക്ലാസിലെ പൊതു ഘടകങ്ങളെ സൂചിപ്പിക്കുന്നു. ഒരു ക്ലസ്റ്റർ ക്ലസ്റ്ററിനു പുറത്ത് പേരുനൽകുന്ന ഒരു തരം ക്ലസ്റ്റർ കൂടി നിർവ്വചിക്കുന്നു (ഇവിടെ, "complex_number"), എന്നാൽ അതിൻറെ റെപ്രസെൻറേഷൻ ടൈപ്പ് (rep) ബാഹ്യ ക്ലയൻറുകളിൽ നിന്ന് മറഞ്ഞിരിക്കുകയാണ്.

ക്ലസ്റ്റർ പേരുകൾ ആഗോളമാണ്, മറ്റ് ക്ലസ്റ്ററുകൾക്കുള്ളിൽ "പ്രാദേശിക" ഗ്രൂപ്പുകൾ സൃഷ്ടിക്കാൻ നാമസ്പെയ്സ് സംവിധാനം ഏർപ്പെടുത്തിയിരുന്നില്ല.

സിഎൽയുവിന് ഇതര തരത്തിലുള്ള പരിവർത്തനങ്ങൾ സാധ്യമല്ല. ഒരു ക്ലസ്റ്ററിൽ, സ്പഷ്ട തരത്തിനും (explicit type) അവതരണത്തിനും ഇടയിലുള്ള വ്യതിരിക്തമായ തരങ്ങൾക്ക് (abstract type) വ്യത്യാസങ്ങൾ ഉണ്ടാകുന്നു. ഒരു സാർവത്രിക തരം ഉണ്ട്, ഒരു വസ്തു പ്രത്യേക തരം ആണെന്ന് പരിശോധിക്കാൻ force[] എന്ന നടപടിക്രമം ഉപയോഗിക്കുന്നു. ഒബ്ജക്ടുകൾ മൂട്ടബിൾ (mutable) അല്ലെങ്കിൽ ഇംമൂട്ടബിൾ (immutable) ആകാം, രണ്ടാമത്തേത്, ബേസ്, ബൂളിയനുകൾ, പ്രതീകങ്ങൾ, സ്ട്രിങ്ങുകൾ തുടങ്ങിയ അടിസ്ഥാന ഘടകങ്ങളാണ്.[5]

Remove ads

മറ്റ് സവിശേഷതകൾ

സിഎൽയു ടൈപ്പ്സിസ്റ്റത്തിൻറെ മറ്റൊരു പ്രധാന സവിശേഷത ഇറ്ററേറ്റുകൾ (iterators) ആണ്, അവ സീരിയലിൽ നിന്ന് ഒബ്ജക്റ്റുകൾ തിരികെ നൽകുന്നു, ഒന്നിനുപുറകെ ഒന്നായി.[5] ഒരേപോലുള്ള ആപ്ലിക്കേഷൻ പ്രോഗ്രാമിംഗ് ഇൻറർഫേസ് (എപിഐ) ഇറ്റർറേറ്ററുകൾ വാഗ്ദാനം ചെയ്യുന്നു, അവ ഉപയോഗിക്കുന്ന ഡാറ്റ എന്തുതന്നെയായാലും. അങ്ങനെ സങ്കീർണ്ണമായ_ സംഖ്യകളുടെ ശേഖരത്തിനായി ഇറ്ററേറ്ററുകൾ പൂർണ്ണസംഖ്യകളുടെ ഒരു അറേയ്ക്കായി അവയ്ക്ക് പരസ്പരം ഉപയോഗിക്കാനാകും. സിഎൽയു ഇറ്ററേറ്ററുകളുടെ ഒരു പ്രത്യേക സവിശേഷത അവ കോറൻഡീസിനെ പ്പോലെയാണ് നടപ്പാക്കപ്പെടുന്നത്, യീൽഡ് (yield) പ്രസ്താവന വഴി കോളറിനായി ഓരോ മൂല്യവും നൽകപ്പെടുന്നു. സിഎൽയുവിയിൽ ഉള്ള ഇറ്ററേറ്ററുകൾ ഇന്ന് പല ആധുനിക ഭാഷകളുടെ ഒരു പൊതു സവിശേഷതയാണ്, സി#, റൂബി, പൈത്തൺ എന്നീ പ്രോഗ്രാമിംഗ് ഭാഷകളിലും ഉപയോഗിക്കുന്നു, ഈയിടെയായി അവ പലപ്പോഴും ജനറേറ്ററായി അറിയപ്പെടുന്നു.


മറ്റ് ഭാഷകളിലുള്ള വിവിധ ശ്രമങ്ങളെ അടിസ്ഥാനമാക്കി; സിഎൽയുവിൽ ഒഴിവാക്കൽ കൈകാര്യം ചെയ്യൽ (Exception handling) ഉൾപ്പെടുത്തയിരിക്കുന്നു. ഒഴിവാക്കലുകൾ സിഗ്നൽ ഉപയോഗിച്ച് ഉയർത്തുകയും അവയെ കൈകാര്യം ചെയ്യുകയും ചെയ്യുന്നു. മറ്റ് മിക്ക ഭാഷകൾക്കും പുറമേയുള്ള ഒഴിവാക്കലുകൾ അത്ര സംക്ഷിപ്തമായല്ല കൈകാര്യം ചെയ്യുന്നത്. കൂടാതെ ഒഴിവാക്കൽ കൈകാര്യം ചെയ്യാവുന്ന മറ്റ് മിക്ക ഭാഷകളിൽ നിന്നും വ്യത്യസ്തമായി, സിഎൽയുവിൽ നിന്നുള്ള ഒഴിവാക്കലുകൾ സാധാരണ നിർവ്വഹണത്തിൻറെ ഭാഗമായി കണക്കാക്കപ്പെട്ടിരിക്കുന്നു, അവ ഒരു "സാധാരണ", ലൂപ്പുകളുടെ പുറത്താക്കൽ അല്ലെങ്കിൽ പ്രവർത്തനങ്ങളിൽ നിന്ന് മടങ്ങിവരാനുള്ള ഫലപ്രദമായ വഴികൾ; മറ്റ് വ്യവസ്ഥകൾ ബാധകമാകുമ്പോൾ "എപ്പോഴെങ്കിലും ഒഴികെ" മടക്കസന്ദേശങ്ങൾ നേരിട്ട് ലഭ്യമാക്കുന്നതിന് ഇത് അനുവദിക്കുന്നു.

ടൈപ്പ്-സുരക്ഷിത വേരിയൻറ് തരം ഉള്ള ആദ്യത്തെ ഭാഷയായി സിഎൽയു ഉപയോഗിക്കപ്പെടുന്നു, എംഎൽ(ML) ഭാഷക്ക് മുൻപുണ്ടായിരുന്നതിനെ വൺഓഫ്സ് (oneofs) എന്ന് വിളിച്ചിരുന്നു. സിഎൽയുവിലെ അന്തിമ സവിശേഷത സമാന്തര കർത്തവ്യം (ഒന്നിലധികം അസൈൻമെൻറ്) ആണ്, ഇവിടെ ഒരു അസൈൻമെൻറ് ഓപ്പറേഷൻറെ ഇടത് വശത്ത് ഒന്നിൽ കൂടുതൽ വേരിയബിളുകൾ ദൃശ്യമാകും. ഉദാഹരണത്തിന്, എഴുതുന്നത് ഇപ്രകാരമാണ് x,y := y,x x and y മൂല്യങ്ങൾ കൈമാറും. ഇതേപോലെ, പ്രവർത്തനങ്ങൾ x, y, z: = f (t) പോലുള്ള പല മൂല്യങ്ങളും നൽകാം. സമാന്തര അസൈൻമെൻറ് (മൾട്ടി റിട്ടേൺ വാല്യൂഷനുകളൊന്നും ഇല്ലെങ്കിലും) സി.എ.പി.എൽ (1963), ഒരേ സമയത്തുളള അസൈൻമെൻറ് [6] എന്ന പേരിലാണ് അറിയപ്പെട്ടിരുന്നത്, പക്ഷെ സിഎൽയു ജനകീയവൽക്കരിക്കപ്പെട്ടു. പിന്നീടുള്ള ഭാഷകളിലേക്ക് സമാന്തര അസൈൻമെൻറ് നയിക്കുന്ന നേരിട്ടുള്ള സ്വാധീനമായി പലപ്പോഴും ക്രെഡിറ്റ് നൽകിയിട്ടുണ്ട്.

ഒരു സിഎൽയു പ്രോഗ്രാമിലെ എല്ലാ വസ്തുക്കളുടെയും നിലനിൽപ് ഹീപ്പിലാണ്(program live in the heap), ഓട്ടോമാറ്റിക്കായി മെമ്മറി മാനേജ് ചെയ്യുന്നു. പരാമീറ്ററൈസ് തരത്തെ ഉപയോക്താവ് നിർവ്വചിച്ച ഡാറ്റ അബ്സ്ട്രാഷൻസ് സിഎൽയു പിന്തുണയ്ക്കുന്നു. യഥാർത്ഥ തരം ആർഗ്യുമെൻറുകളിൽ നിയന്ത്രണങ്ങൾ പ്രകടിപ്പിക്കുന്ന ഘടന ഉപയോഗിച്ച് ടൈപ്പ്-സുരക്ഷിതമായ നിയന്ത്രണമുള്ള പാരാമീറ്ററൈസ്ഡ് തരങ്ങൾ വാഗ്ദാനം ചെയ്യുന്ന ആദ്യത്തെ ഭാഷയായിരുന്നു ഇത്.

Remove ads

മറ്റ് പ്രോഗ്രാമിങ് ഭാഷകളിൽ മേലുള്ള സ്വാധീനം

പല ഭാഷകളിലും സിഎൽയു സ്വാധീനിച്ചിരിക്കുന്നു. ഏകദേശ കണക്ക് അനുസരിച്ച് അവയിൽ ഇനിപ്പറയുന്നവ ഉൾപ്പെടുന്നു:

  • സിഎൽയുവും അഡയും സി++ ടെംപ്ലേറ്റുകൾക്കുള്ള പ്രധാന പ്രചോദനങ്ങൾ ആയിരുന്നു.
  • സിഎൽയുവിൻറെ ഒഴിവാക്കൽ കൈകാര്യം ചെയ്യൽ(Exception handling) സംവിധാനങ്ങൾ സി++, ജാവ എന്നിവ പോലുള്ള ഭാഷകളെ സ്വാധീനിച്ചു.
  • സാത്തർ, പൈത്തൺ, സി# എന്നിവയിൽ ഉപയോഗിക്കുന്ന ഇറ്ററേറ്ററുകൾ (iterators) ആദ്യം ഉപയോഗിച്ചത് സിഎൽയുവിലായിരുന്നു.
  • പേൾ ലൂഅ എന്നീ പ്രോഗ്രാമിംഗ് ഭാഷകൾ സിഎൽയുവിൽ ഉള്ള ഫംഗ്ഷൻ കോളുകളിൽ നിന്ന് ഒന്നിലധികം അസൈൻമെൻറുകളും മൾട്ടി റിട്ടേണുകളും എടുത്തിട്ടുണ്ട്.[7]
  • പൈത്തണും റൂബിയും സിഎൽയുവിൽ നിന്നും പല ആശയങ്ങളും കടം വാങ്ങി, യീൽഡ് പ്രസ്താവന, മൾട്ടിപ്പിൾ അസൈൻമെൻറ് എന്നിവ.

അവലംബം

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads