Jump to content

ഐക്കൺ (പ്രോഗ്രാമിങ് ഭാഷ)

വിക്കിപീഡിയ, ഒരു സ്വതന്ത്ര വിജ്ഞാനകോശം.
(Icon (programming language) എന്ന താളിൽ നിന്നും തിരിച്ചുവിട്ടതു പ്രകാരം)
ഐക്കൺ
ശൈലി:multi-paradigm: structured, text-oriented
പുറത്തുവന്ന വർഷം:1977; 47 വർഷങ്ങൾ മുമ്പ് (1977)
രൂപകൽപ്പന ചെയ്തത്:Ralph Griswold
ഏറ്റവും പുതിയ പതിപ്പ്:9.5.1/ ജൂൺ 6, 2013; 11 വർഷങ്ങൾക്ക് മുമ്പ് (2013-06-06)
ഡാറ്റാടൈപ്പ് ചിട്ട:dynamic
പ്രധാന രൂപങ്ങൾ:Icon, Jcon
വകഭേദങ്ങൾ:Unicon
സ്വാധീനിക്കപ്പെട്ടത്:SNOBOL, SL5, ALGOL
സ്വാധീനിച്ചത്:Unicon, Python, Goaldi
വെബ് വിലാസം:www.cs.arizona.edu/icon

ഐക്കൺ വളരെ ഉയർന്ന നിലവാരമുള്ള പ്രോഗ്രാമിങ് ഭാഷയാണ്, ഗണിത നിർദ്ദേശങ്ങളുള്ള നിർവ്വഹണ രീതികളും, പാഠഭാഗങ്ങളും മാനദണ്ഡങ്ങൾ കൈകാര്യം ചെയ്യുന്നതിനുള്ള സൗകര്യവും ഉൾപ്പെടുത്തിയിട്ടുണ്ട്. ഇത് സ്ട്രിംഗ് പ്രോസ്സസിംഗ് ഭാഷകൾക്കുള്ള SNOBOL, SL5 എന്നിവയുമായി ബന്ധപ്പെട്ടിരിക്കുന്നു. ഐക്കൺ ഒബ്ജക്റ്റ് ഓറിയെന്റഡ് അല്ല, എന്നാൽ ഐഡോൾ എന്ന ഒരു ഒബ്ജക്റ്റ് ഓറിയെൻറഡ് എക്സ്റ്റൻഷൻ 1996 ൽ ആണ് വികസിപ്പിച്ചത്. പിന്നീട് യൂണികോണായി മാറി.

അടിസ്ഥാന വാക്യഘടന

[തിരുത്തുക]

ഘടനാപരമായ പ്രോഗ്രാമിങ് ഭാഷകളുടെ ആൽഗോൾ(ALGOL) ക്ലാസ്സിൽ നിന്നും ഐക്കൺ ഭാഷ വേർതിരിക്കപ്പെട്ടിരിക്കുന്നു, സി അല്ലെങ്കിൽ പാസ്കൽ പോലെയുള്ള വാക്യഘടന ഉണ്ട്. ഐക്കൺ പാസ്കലിനോട് ഏറ്റവും അടുത്ത സാദൃശ്യമുണ്ട്, := സിന്റാക്സ്, അസൈൻമെന്റുകൾ, നടപടിക്രമം കീവേഡ്, സമാന സിന്റാക്സ്. മറുവശത്ത്, എക്സിക്യൂഷൻ ഗ്രൂപ്പുകൾ നിർമ്മിക്കുന്നതിനായി സി ശൈലിയിലുള്ള ബ്രാക്കറ്റുകൾ ഐക്കൺ ഉപയോഗിക്കുന്നു, ഒപ്പം പ്രോഗ്രാമുകൾ "മെയിൻ" പ്രോസസ് നടത്തുന്നതിലൂടെ ആരംഭിക്കുകയും ചെയ്യുന്നു. മിക്ക രീതികളിലും ഐക്കണാണ് മിക്ക സ്ക്രിപ്റ്റിംഗ് ഭാഷകളുമായി ഫീച്ചറുകൾ പങ്കുവയ്ക്കുന്നത് (SNOBOL, SL5, അതിൽ നിന്ന് എടുത്തതാണ്): വേരിയബിളുകൾ പ്രഖ്യാപിക്കപ്പെടേണ്ടതില്ല, ടൈപ്പുകളെ സ്വപ്രേരിതമായി കാസ്റ്റുചെയ്യും, കൂടാതെ നമ്പറുകൾ സ്ട്രിങ്ങുകളായി മാറ്റുകയും സ്വപ്രേരിതമായി മടങ്ങുകയും ചെയ്യും.

പ്രോസീജെഴ്സ് ആണ് ഐക്കൺ പ്രോഗ്രാമുകളുടെ അടിസ്ഥാന നിർമ്മാണ ബ്ലോക്കുകൾ. അവർ പാസ്കൽ നാമധേയം ഉപയോഗിച്ചുവെങ്കിലും, സി പ്രവർത്തനങ്ങൾ പോലെ പ്രവർത്തിക്കുകയും മൂല്യങ്ങൾ മടക്കിനൽകുകയും ചെയ്യുന്നു; ഇവിടെ ഐക്കണിൽ function കീവേഡ് ഇല്ല.

 procedure doSomething(aString)
   write(aString)
 end

ലക്ഷ്യം നടപ്പിലാക്കുക

[തിരുത്തുക]

ഐക്കണുകളുടെ പ്രധാന ആശയങ്ങളിൽ ഒന്നാണ്, മറ്റ് മിക്ക പ്രോഗ്രാമിംഗ് ഭാഷകളിലും ഉള്ള, നിയന്ത്രണ ഘടകങ്ങൾ "വിജയിക്കുക" അല്ലെങ്കിൽ "പരാജയപ്പെടുക" എന്ന ബൂളിയൻ യുക്തിയിൽ അധിഷ്ഠിതമാണ്. ഈ മാതൃക പ്രകാരം, ലളിതമായ താരതമ്യങ്ങൾ a < b എന്ന കോഡ് മിക്ക ഭാഷകളുടെയും പോലെ "വലതു വശത്തുള്ള പ്രവർത്തനങ്ങൾ ശരിയെന്നു വിലയിരുത്തുക" എന്നല്ല അർത്ഥമാക്കുന്നത്; പകരം ഇത് കൂടുതൽ അർത്ഥമാക്കുന്നത് "ശരിയായ പ്രവർത്തനങ്ങൾ വിജയിക്കുകയാണെങ്കിൽ" എന്നതാണ്. ഈ സാഹചര്യത്തിൽ, താരതമ്യം ചെയ്യൽ ശരിയാണെങ്കിൽ < (less than) ഓപ്പറേറ്റർ വിജയിക്കുന്നു, അതിനാൽ അവസാന ഫലം ഒരുപോലെയാണ്. ഇതുകൂടാതെ, < ഓപ്പറേറ്റർ അതിൻറെ രണ്ടാമത്തെ ആർഗ്യുമെൻറ് നൽകുന്നു, അത് വിജയിക്കുകയാണെങ്കിൽ, അതുപോലുള്ള കാര്യങ്ങൾ അനുവദിക്കുന്നു if a < b < c, മിക്കവാറും ഭാഷകളിൽ സാധാരണമായ ഒരു താരതമ്യം രണ്ട് ഇൻഇക്വാളിറ്റിയുടെ സംയോജനമായി എഴുതണം if a < b && b < c.

ലളിതമായ ഈ കോഡ് എല്ലാ ഫ്ലോ നിയന്ത്രണങ്ങളും ഐക്കണിൽ വിജയിക്കുന്നതോ അല്ലെങ്കിൽ പരാജയപ്പെടുന്നതോ ആയതിനാൽ, നിങ്ങൾക്ക് നിഗൂഢമായ ഉദാഹരണങ്ങൾ പരിഗണിക്കുമ്പോൾ ഈ ആശയത്തിൻറെ പ്രയോഗം കൂടുതൽ വ്യക്തമാകും:

if a := read() then write(a)

റീഡ് () കമാൻഡ് പരാജയപ്പെടുമ്പോൾ, ഉദാഹരണത്തിന് ഫയൽ അവസാനിക്കുമ്പോൾ, ഈ ചെയിനിൽ പരാജയപ്പെടൽ കൈമാറും, റൈറ്റ് () കമാൻഡ് അതുപോലെ തന്നെ പരാജയപ്പെടും. ഒരു കൺട്രോൾ ഘടന എന്ന നിലയിൽ, പരാജയത്തിൽ നിർത്തുന്നു, ഫയൽ ശൂന്യമാക്കുമ്പോൾ ഇത് നിർത്തലാക്കും എന്നർത്ഥം. താരതമ്യത്തിനായി, സമാനമായ ഒരു ഉദാഹരണം പരിഗണിക്കുക സ്യൂഡോകോഡിൽ ആണ് (സി++ ൻറെയും, ജാവ പോലുള്ള ഭാഷകളിലേയും സിൻറാക്സ് ഉപയോഗിച്ച്):

 try {
   while ((a = read()) != EOF) {
     write(a);
   }
 } catch (Exception e) {
   // do nothing, exit the loop
 }

ഈ കേസിൽ രണ്ട് താരതമ്യങ്ങൾ ആവശ്യമാണ്: ഒന്നാമത്തേത് ഫയലിൻറെ അവസാനം (EOF), മറ്റ് പിശകുകൾ എന്നിവയ്ക്ക് മറ്റൊന്ന്. ജാവ പിശകുകൾ അനുവദിക്കാത്തതിനാൽ, ലോജിക്കൽ ഘടകങ്ങളായി, ഐക്കണിൻറെ കീഴിൽ ഇതിനെ താരതമ്യം ചെയ്യാം, പകരം നീളമുള്ളtry/catch(ട്രൈ ഓർ കാച്ച്) സിൻറാക്സ് ഉപയോഗിയ്ക്കണം. ബ്ളോക്കുകൾ ഉപയോഗിക്കുമ്പോൾ പെർഫോമൻസ് ഉപയോഗിക്കുന്നത് കൂടാതെ, ഒരു പിശക് സംഭവിക്കുന്നില്ലെങ്കിൽ പോലും, ഐക്കൺ ഒഴിവാക്കുന്ന ഒന്നാണ് ഡിസ്റ്റിബ്യൂട്ടെഡ് കോസ്റ്റ്.

ലക്ഷ്യം നടപ്പാക്കൽ പോലെ, ഐക്കൺ ഈ ആശയത്തെ സൂചിപ്പിക്കുന്നു, ചില ലക്ഷ്യങ്ങളിൽ എത്തുന്നതുവരെ ഈ നടപ്പാക്കൽ തുടർന്നു. മുകളിലുള്ള ഉദാഹരണത്തിൽ ലക്ഷ്യം പൂർത്തീകരിക്കുന്നത് വരെ മുഴുവൻ ഫയലും വായിക്കണം; റീഡ് കമാൻഡ് വിജയിക്കുന്നതുവരെ തുടരുന്നു, കൂടുതൽ വിവരങ്ങൾ വായിക്കപ്പെടെണ്ടതാണ്, അവിടെ ഇൻഫോർമേഷൻ ഇല്ലാത്തപ്പോൾ പരാജയപ്പെടുന്നു. അങ്ങനെ ലക്ഷ്യം നടപ്പിലാക്കുന്നതിന് റിട്ടേൺ കോഡുകൾ അല്ലെങ്കിൽ സമാനമായ നിർമ്മിതികൾ പരിശോധിച്ച് നിർദ്ദേശങ്ങൾ ഉപയോഗിക്കുന്നതിനു പകരമാണ്, ഭാഷയെ നേരിട്ട് കോഡ് ചെയ്തിരിക്കുന്നത്.

ജനറേറ്ററുകൾ

[തിരുത്തുക]

ഉദാഹരണത്തിന്, ഐക്കണിലെ എക്സ്പ്രഷനുകൾ പലപ്പോഴും ഒരൊറ്റ മൂല്യം നൽകുന്നു,x < 5 ൻറെ മൂല്യം 5 ൽ കുറവാണെങ്കിൽ അല്ലെങ്കിൽ പരാജയപ്പെടുകയാണെങ്കിൽx < 5വിലയിരുത്തുകയും വിജയിക്കുകയും ചെയ്യും. എന്നിരുന്നാലും താഴെ പറയുന്ന ഉദാഹരണങ്ങളിൽ അനേകം എക്സ്പ്രഷനുകൾ വിജയിക്കുകയോ പരാജയപ്പെടുകയോ ചെയ്യുന്നില്ല എന്ന വസ്തുതയിൽ ആശ്രയിച്ച്, അതേ സമയം തന്നെ മൂല്യങ്ങൾ തിരികെ നൽകുന്നു. ഇത് എല്ലാത്തിനും മാതൃകകളിലേക്ക് നയിക്കുന്നു; മൂല്യങ്ങൾ തുടർന്നും പരാജയപ്പെടുവോളം എല്ലാ കാരണങ്ങളും തുടരുന്നു.

ഇത് ജനറേറ്ററായി അറിയപ്പെടുന്ന ഐക്കണിലെ ഒരു പ്രധാന ആശയമാണ്. ജനറേറ്ററുകൾ അധികമായി ഭാഷയിലുള്ള ലൂപ്പ് പ്രവർത്തനം ഡ്രൈവ് ചെയ്യുന്നു, പക്ഷെ കൂടുതൽ നേരിട്ട് ചെയ്യുന്നു; പ്രോഗ്രാമർ ഒരു ലൂപ്പ് എഴുതുന്നില്ല, തുടർന്ന് മൂല്യങ്ങൾ പിൻവലിച്ച് താരതമ്യം ചെയ്യുന്നു, ഐക്കൺ എല്ലാം നിങ്ങൾക്കായി ചെയ്യും.

ഐക്കണിൻറെ പ്രതീകത്തിനുള്ളിൽ, ഫലത്തിൻറ‌െ ശ്രേണിയിൽ ഒരു പദപ്രയോഗം അല്ലെങ്കിൽ പ്രവർത്തനത്തിൻറെ വിലയിരുത്തൽ നടത്തുന്നു. എക്സ്പ്രഷൻ അല്ലെങ്കിൽ ഫങ്ഷൻ ഉപയോഗിച്ച് സൃഷ്ടിക്കാൻ സാധ്യമായ എല്ലാ മൂല്യങ്ങളും ഒരു സീക്വൻസിനുണ്ട്. ഫലത്തിൻറെ സീക്വൻസ് തീർന്നിരിക്കുമ്പോൾ (ഉദാഹരണത്തിന്, ഫലങ്ങളുടെ പരിധിക്കുള്ളിൽ കൂടുതൽ മൂല്യങ്ങൾ ഇല്ല), എക്സ്പ്രഷൻ അല്ലെങ്കിൽ പ്രവർത്തനം പരാജയപ്പെടുന്നു. ഐക്കണിൻറെ ലക്ഷ്യം മൂല്യനിർണ്ണയം അല്ലെങ്കിൽ വ്യക്തമായും ഓരോ ഭാഗവും വഴി ഐക്കണിലെ ലക്ഷ്യം നേടുക വഴി റിസൾട്ട് ലഭിക്കുന്നതാണ്.

ഐക്കണിൽ നിരവധി ജനറേറ്റർ-നിർമ്മാതാക്കൾ ഉൾപ്പെടുന്നു. എതെങ്കിലും ഒന്ന് പരാജയപ്പെടുന്നതുവരെ ആൾട്ടർനേറ്റീവ് സിൻറാക്സ് ഒരു ശ്രേണിയിൽ ഇനങ്ങൾ സൃഷ്ടിക്കാൻ അനുവദിക്കുന്നു:

 1 | "hello" | x < 5

"1", "ഹലോ", "5" എന്നിവ x 5 ന് താഴെയാണെങ്കിൽ റിസൾട്ട് സ‌ൃഷ്ടിക്കാൻ കഴിയും. ആൾട്ടർനേറ്റർമാർ മിക്കപ്പോഴും "അല്ലെങ്കിൽ" എന്ന രീതിയിൽ വായിക്കാൻ കഴിയും, ഉദാഹരണത്തിന്:

 if y < (x | 5) then write("y=", y)

x അല്ലെങ്കിൽ 5-നേക്കാൾ ചെറുതാണെങ്കിൽ y യുടെ മൂല്യം എഴുതുന്നു. ഓരോ മൂല്യവും ഇടത്തുനിന്ന് വലത്തേക്ക് ആന്തരികമായി ഐക്കൺ പരിശോധിക്കുന്നു ഒരു വിജയം നേടുന്നതു വരെ അല്ലെങ്കിൽ ലിസ്റ്റ് എംമ്പ്റ്റി ആകുന്നതു വരെ. മാത്രമല്ല അത് പരാജയപ്പെടുന്നു. അകത്തുളള കോളുകൾ പരാജയപ്പെടാത്ത പക്ഷം ഫംഗ്ഷനുകൾ വിളിക്കില്ല എന്ന് ഓർത്തുവെയ്ക്കുക, അങ്ങനെ ഈ ഉദാഹരണം ചുരുക്കാൻ കഴിയും:

 write("y=", (x | 5) > y)

മറ്റൊരു ലളിതമായ ജനറേറ്റർ, ആണ് to എന്നത്, ഇത് പൂർണ്ണസംഖ്യകളുടെ പട്ടിക ഉണ്ടാക്കുന്നു; every write(1 to 10) ഈ കോഡിൽ കാണുന്നതെന്താണോ അത് കൃത്യതയോടെ ചെയ്യും. ബാംഗ് സിൻറാക്സ് ഒരു ലിസ്റ്റിലെ എല്ലാ ഇനങ്ങളും സൃഷ്ടിക്കുന്നു; every write(!aString) എസ്ട്രിങിൻറെ (aString) ഓരോ ക്യാരക്റ്ററും ഒരു പുതിയ വരിയിൽ ഔട്ട്പുട്ട് ചെയ്യും.

ഈ ആശയത്തിൻറെ ശക്തി തെളിയിക്കുന്നതിനായി, സ്ട്രിംഗ് പ്രവർത്തനങ്ങൾ പരിഗണിക്കുന്നു. മിക്ക ഭാഷകളിലും find അല്ലെങ്കിൽ indexOf എന്നറിയപ്പെടുന്ന ഒരു ഫംഗ്ഷൻ മറ്റൊരു സ്ട്രിംഗ് ലൊക്കേഷനിൽ മറ്റൊരു സ്ഥാനം നൽകുന്നു. പരിഗണിക്കുക:

s = "All the world's a stage. And all the men and women merely players";
 i = indexOf("the", s)

ഈ കോഡ് "the" എന്ന വാക്കിൻറെ ആദ്യ സംഭവത്തിൻറെ 4-ാം സ്ഥാനത്ത് വരും. "The" എന്ന മറ്റൊരു ഉദാഹരണത്തിൽ ഒരു ഇതര ഫോം ഉപയോഗിക്കണം,

i = indexOf("the", s, 5)

അഞ്ചാമത്തെ സ്ഥാനത്ത് നിന്ന് നോക്കണം എന്ന് 5 ൻറെ അവസാനം പറയുന്നു. "The" യുടെ എല്ലാ സന്ദർഭങ്ങളും എക്സ്ട്രാക്റ്റു ചെയ്യുന്നതിന്, ഒരു ലൂപ്പ് ഉപയോഗിക്കണം ...

 s = "All the world's a stage. And all the men and women merely players";
 i = indexOf("the", s)
 while i != -1 {
   write(i);
   i =  indexOf("the", s, i+1);
 }

ഐക്കണിനു കീഴിൽ find എന്ന പ്രവർത്തനം ഒരു ജനറേറ്ററാണ്, ഓരോ സമയത്തും സ്ട്രിങ്ങിൻറെ അടുത്ത ഇൻസ്റ്റൻസ് തിരികെയെത്തുകയും, അത് സ്ട്രിംഗിൻറെ അവസാനം കടന്നു കഴിഞ്ഞാൽ, അവസാനം പരാജയപ്പെടുന്നതിനുമുമ്പ് അത് പുനരാരംഭിക്കും. ഐക്കണിൻറെ അതേ കോഡ് എഴുതാം:

s := "All the world's a stage. And all the men and women merely players"
 every write(find("the",s))

"the" എന്ന സ്ഥാനത്ത് 5 ആണെങ്കിൽ, സ്ഥാനം മാത്രം തിരികെ നൽകും, താരതമ്യപ്പെടുത്തൽ പരാജയപ്പെടുകയാണെങ്കിൽ, write() കോഡ് മുമ്പ് പാസ് ചെയ്യാൻ കഴിയാത്തതിനാൽ പരാജയപ്പെട്ടു. പരിഗണിക്കപ്പെടേണ്ട ഈ കോഡിന് ഒരു ചെറിയ "ട്രിക്ക്" ഉണ്ട്: താരതമ്യങ്ങൾ വലതു കൈ ഫലങ്ങൾ നൽകുന്നു, അതിനാൽ താരതമ്യത്തിൻറെ വലതുവശത്തെ കണ്ടെത്തൽ പ്രധാനമാണ്. 5 വലത് ഭാഗത്ത് വയ്ക്കുകയാണെ ങ്കിൽ, 5 എഴുതപ്പെടും. ജനറേറ്ററുകൾ വഴി ലൂപ്പുചെയ്യുന്നതി നായി ഐക്കൺ നിരവധി നിയന്ത്രണ സംവിധാനങ്ങൾ ചേർക്കുന്നു. ഓരോ every ഓപ്പറേറ്റർക്കും സമാനമായ സമയത്ത് while, ഒരു ജനറേറ്ററിനാൽ തിരിച്ചുകിട്ടുന്ന എല്ലാ ഇനങ്ങളിലൂടെയും വീണ്ടും ലൂപ്പിംഗ് ചെയ്ത് പരാജയത്തിൽ കലാശിക്കുന്നു:

every k := i to j do
   write(someFunction(k))

ഈ കേസിൽ വൈയിൽ ലൂപ്(while-loop)ന് പകരം everyഎന്ന കോഡ് എന്തുകൊണ്ട് ഉപയോഗിക്കുന്നു? കാരണംwhileആദ്യ ഫലം വിലയിരുത്തുക, എന്നാൽ everyഎല്ലാ ഫലങ്ങളും നൽകുന്നു.every എന്ന കോഡിൽ ഓരോ വാക്യഘടനയും സ്മോൾടോക്കിനു കീഴിലുള്ള ബ്ലോക്കുകൾ പോലെയുള്ള ഒരു ഫങ്ഷനിൽ ഫംങ്ഷനിലേക്ക് മൂല്യം നൽകുന്നു. ഉദാഹരണത്തിന് മുകളിൽ പറഞ്ഞ ലൂപ്പ് ഇങ്ങനെ വീണ്ടും എഴുതാൻ സാധിക്കും:

every write(someFunction(i to j))

suspend കീവേഡ് ഉപയോഗിച്ച് ഉപയോക്താവിന് പുതിയ ജനറേറ്ററുകൾ എളുപ്പത്തിൽ നിർമ്മിക്കാൻ കഴിയും:

procedure findOnlyOdd(pattern, theString)
   every i := find(pattern, theString) do
     if i % 2 = 1 then suspend i
 end

പാറ്റേൺ കണ്ടെത്തുന്നതിനായി TheString-ൽ ഈ ഉദാഹരണം ശ്രദ്ധിക്കുന്നു. ഒരെണ്ണം കണ്ടെത്തിയപ്പോൾ, അതിൻറെ സ്ഥാനം ഓഡ്(odd) ആണ്,suspend എന്ന കോഡിൻറെ സ്ഥാനം ഫങ്ഷനിൽ തിരികെയെത്തുന്നു. അവിടെ ആന്തരിക ജനറേറ്ററിലും, അടുത്ത ഇറേറ്ററിൽ എവിടെയാണോ നിർത്തിയത് അവിടെ നിന്നാണ് അത് പോകാൻ അനുവദിക്കുന്നത്, return, കോഡിൽ നിന്ന് വ്യത്യസ്തമായി, ആന്തരിക ജനറേറ്ററുകളിൽ suspend രേഖപ്പെടുത്തുന്നു, അടുത്ത ആവർത്തനത്തിൽ വിട്ട് കളഞ്ഞത് എവിടെയാണോ അത് എടുക്കാൻ അനുവദിക്കുന്നു.

സ്ട്രിംഗുകൾ

[തിരുത്തുക]

സ്ക്രിപ്റ്റ് പോലുള്ള പ്രവർത്തനം നിലനിർത്തുന്നതിന്, സ്ട്രിംഗ് ഉപയോഗിച്ച് എളുപ്പത്തിൽ പ്രവർത്തിക്കുന്നതിന് ഐക്കൺ നിരവധി സവിശേഷതകൾ ചേർക്കുന്നു. ഇതിൽ ഏറ്റവും ശ്രദ്ധേയമായത് സ്കാനിംഗ് സിസ്റ്റം ആണ്, അത് ആവർത്തിച്ച് വിളിക്കുന്നത് സ്ട്രിംഗിൽ പ്രവർത്തിക്കുന്നു:

s ? write(find("the"))

നേരത്തെ കാണിച്ചിരിക്കുന്ന ഉദാഹരണങ്ങളുടെ ഒരു ചെറിയ രൂപമാണിത്. ഈ സന്ദർഭത്തിൽ ചോദ്യ ചിഹ്നത്തിനു മുമ്പിലുള്ള പരാമീറ്ററുകൾക്ക് പുറത്ത് find ഫംഗ്ഷൻറെ വിഷയം സ്ഥാപിക്കുന്നു. ഐക്കൺ പ്രവർത്തനങ്ങൾ മനഃപൂർവ്വം (സ്വയമെ എതിരാണ്) ഈ വിഷയം പാരാമീറ്റർ ലിസ്റ്റുകളിൽ തിരിച്ചറിയുന്നതിനായി എഴുതിയിരിക്കുന്നു, അവ ഈ രീതിയിൽ പിൻവലിക്കാൻ അനുവദിക്കുന്നു.

ബ്രാക്കറ്റിനുള്ളിൽ ഒരു ശ്രേണി സ്പെസിഫിക്കേഷൻ ഉപയോഗിച്ചുകൊണ്ട് ഒരു സ്ട്രിംഗിൽ നിന്ന് ഉപസ്ട്രിംഗുകൾ വേർതിരിച്ചെടുക്കാം. ഒരു റേഞ്ച് സ്പെസിഫിക്കേഷൻ ഒരു പ്രതീകത്തിലേക്ക് ഒരു പോയിൻറ് മടക്കി നൽകാൻ കഴിയും, അല്ലെങ്കിൽ സ്ട്രിംഗിൻറെ ഒരു സ്ലൈസ്. സ്ട്രിംഗുകൾ വലത് അല്ലെങ്കിൽ ഇടത് ഭാഗത്തുനിന്നും ഇൻഡെക്സ് ചെയ്യാവുന്നതാണ്. ഒരു സ്ട്രിംഗിലെ സ്ഥാനങ്ങൾ പ്രതീകങ്ങൾക്കിടയിലായിരിക്കണം നിർവചിച്ചിരിക്കുന്നത്. 1A2B3C4 ഇത് വലത്തു നിന്നും വ്യക്തമാക്കാം −3A−2B−1C0 ഉദാഹരണത്തിന്,

 "Wikipedia"[1]     ==> "W"
 "Wikipedia"[3]     ==> "k"
 "Wikipedia"[0]     ==> "a"
 "Wikipedia"[1:3]   ==> "Wi"
 "Wikipedia"[-2:0]  ==> "ia"
 "Wikipedia"[2+:3]  ==> "iki"

അവസാന ഉദാഹരണം അവസാനത്തെ ഒരു സ്ഥാനത്ത് പകരം ഉപയോഗിക്കുന്നതിന് തുല്യമാണ്

ഒരു സൂചികയ്ക്കുള്ളിൽ ഒരു ശ്രേണിയിലേക്ക് ലിപ്യന്തരണം ആയി ഉപയോഗിക്കാവുന്നതാണ്. ഇത് മറ്റൊരു സ്ട്രിംഗിലേക്ക് സ്ട്രിംഗുകളോ സ്ട്രിംഗിൻറെ ഭാഗങ്ങളോ ഇല്ലാതാക്കാനോ ഉപയോഗിക്കാം. ഉദാഹരണത്തിന്,

s := "abc"
    s[2] := "123"
    s now has a value of "a123c"
    s := "abcdefg"
    s[3:5] := "ABCD"
    s now has a value of "abABCDefg"
    s := "abcdefg"
    s[3:5] := ""
    s now has a value of "abefg"

മുകളിൽ സൂചിപ്പിച്ചതുപോലെ, ഐക്കണുകളുടെ സബ്സ്ക്രിപ്റ്റ് ഘടകങ്ങൾക്കിടയിലുള്ള ഇൻഡൈസുകൾ തമ്മിലാണ്. സ്ട്രിംഗ് നൽകിയിരിക്കുന്നത് ഇപ്രകാരമാണ് s := "ABCDEFG", സൂചികകൾ: 1A2B3C4D5E6F7G8.സ്ലൈസ് s [3: 5] എന്നത് സൂചികകൾ 3 നും 5 നും ഇടയിലുള്ള സ്ട്രിംഗ് ആയ "സിഡി" ആണ്.

മറ്റ് ഘടനകൾ

[തിരുത്തുക]

ഐക്കൺ ഉപയോക്താവിന് അവരുടെ സ്വന്തം പട്ടികകൾ (അല്ലെങ്കിൽ നിരകൾ) എളുപ്പത്തിൽ നിർമ്മിക്കാൻ അനുവദിക്കുന്നു:

aCat := ["muffins", "tabby", 2002, 8]

ഒരു ലിസ്റ്റിലെ ഇനങ്ങൾ ഏതെങ്കിലും തരത്തിലായിരിക്കാം, മറ്റ് ഘടനകൾ ഉൾപ്പെടെ. വലിയ ലിസ്റ്റുകൾ പെട്ടെന്ന് നിർമ്മിക്കുന്നതിന്, ഐക്കൺ list ജനറേറ്റർ ഉൾക്കൊള്ളുന്നു; i := list(10, "word")"പദം" എന്നതിൻറെ 10 കോപ്പികൾ ഉൾക്കൊള്ളുന്ന ഒരു ലിസ്റ്റ് നിർമ്മിക്കുന്നു.

മറ്റ് ഭാഷകളിൽ അറേ പോലുള്ളവ, ഐക്കണുകളിൽ സ്ഥാനം നോക്കി കാണിക്കാൻ അനുവദിക്കുന്നു, ഉദാ: weight := aCat[4]. സ്ട്രിംഗുകളെ പോലെ, ഇൻഡക്സുകൾ ഘടകാംശങ്ങൾക്കിടയിലായിരിക്കും, ശ്രേണി വ്യക്തമാക്കുന്നതി ലൂടെ ഒരു ലിസ്റ്റിൻറെ ഒരു ഭാഗം ലഭിക്കും, ഉദാ. aCat[2:4] പട്ടിക നൽകുന്നു ["tabby",2002].സ്ട്രിംഗുകളിൽ നിന്ന് വ്യത്യസ്തമായി, ഒരു ശ്രേണി ഉപയോഗിച്ചുള്ള എൽവാല്യൂ (lvalue) ആകരുത്.

ബാംഗ്-സിൻറാക്സ്, ഉദാ. every write(!aCat), ഒരു വരിയിൽ ഓരോന്നും നാല് വരികൾ പ്രിൻറ് ചെയ്യും.

ഐക്കണിൽ സ്റ്റാക്ക് പോലുള്ള പ്രവർത്തനങ്ങൾ, push ഒപ്പം pop എന്നിവ സ്റ്റാക്കുകളും ക്യൂകളും അടിസ്ഥാനമാക്കി യുള്ളവയെ അനുവദിക്കുന്നു.

ചിഹ്നങ്ങളും ടേബിളുകളും തുടങ്ങിയ പ്രവർത്തനങ്ങൾ ഐക്കൺ ഉൾപ്പെടുത്തിയിട്ടുണ്ട് (ഹാഷുകൾ, സഹകരണ അറേകൾ, നിഘണ്ടുക്കൾ മുതലായവ):

symbols := table(0)
 symbols["there"] := 1
 symbols["here"] := 2

ഈ കോഡ് ഒരു ടേബിളിനെ സൃഷ്ടിക്കുന്നു. ഇത് അജ്ഞാത കീയുടെ സഹജമായ വിലയായിട്ടാണ് പൂജ്യം ഉപയോഗിയ്ക്കുന്നത്. ഇത് "അവിടെ", "ഇവിടെ" എന്നീ കീകൾ ഉണ്ട്, കൂടാതെ 1, 2 എന്നീ മൂല്യങ്ങളുമായി അതിലേക്ക് രണ്ടു ഇനങ്ങൾ കൂട്ടിച്ചേർക്കുന്നു.

സ്ട്രിംഗ് സ്കാനിംഗ്

[തിരുത്തുക]

ഐക്കണിൻറെ ശക്തിമത്തായ ഒരു സവിശേഷതയാണ് സ്ട്രിംഗ് സ്കാനിംഗ്. സ്കാൻ സ്ട്രിംഗ് ഓപ്പറേറ്റർ ? നിലവിലെ സ്ട്രിംഗ് സ്കാനിംഗ് പരിതഃസ്ഥിതി സംരക്ഷിക്കുകയും പുതിയ സ്ട്രിംഗ് സ്കാനിംഗ് പരിസ്ഥിതി സൃഷ്ടിക്കുകയും ചെയ്യുന്നു. സ്ട്രിംഗ് സ്കാനിംഗ് പരിസ്ഥിതിയിൽ രണ്ട് കീവേഡ് വേരിയബിളുകൾ അടങ്ങിയിരിക്കുന്നു,&subject ഉം &pos. &subject എന്നത് സ്ട്രിംഗ് സ്കാൻ ചെയ്യുന്നു, &pos കർസർ ആണ്, അല്ലെങ്കിൽ സബജക്ട് സ്ട്രിങ്ങിനുള്ളിലെ നിലവിലെ സ്ഥാനത്തെയാണ്. ഉദാഹരണത്തിന്,

s := "this is a string"
  s ? write("subject=[",&subject,"] pos=[",&pos,"]")

ഇത് സാക്ഷ്യപ്പെടുത്തുന്നു

subject=[this is a string] pos=[1]

സ്ട്രിംഗ് സ്കാൻ ചെയ്യപ്പെടുന്നതിന് വേണ്ടി അന്തർനിർമ്മിതവും ഉപയോക്തൃ നിർവ്വചിത പ്രവർത്തനങ്ങളും ഉപയോഗിക്കാൻ കഴിയും. അന്തർനിർമ്മിതമായ നിരവധി ഫംഗ്ഷനുകൾ സ്ഥിരമായിരിക്കും&subject &pos(ഉദാഹരണത്തിന്,find ഫംഗ്ഷൻ). ഇനിപ്പറയുന്നവ, ഉദാഹരണമായി, സ്ട്രിങുകൾക്കു ള്ളിൽ "വാക്കുകൾ" എല്ലാ ശൂന്യമായ അതിർത്തികൾ നിർണ്ണയിച്ച് എഴുതുകയും ചെയ്യുന്നു.

s := "this is a string"
  s ? {                               # Establish string scanning environment
      while not pos(0) do  {          # Test for end of string
          tab(many(' '))              # Skip past any blanks
          word := tab(upto(' ') | 0)  # the next word is up to the next blank -or- the end of the line
          write(word)                 # write the word
      }
  }

ജനറേറ്ററുകളുടെ ഭാഷയുടെയും സ്ട്രിംഗ് സ്കാനിംഗിൻറെയും സംയോജനം കൂടുതൽ സങ്കീർണ്ണമായ ഉദാഹരണമാണ്.

procedure main()
     s := "Mon Dec 8"
     s ? write(Mdate() | "not a valid date")
 end
 # Define a matching function that returns
 # a string that matches a day month dayofmonth
 procedure Mdate()
 # Define some initial values
 static dates
 static days
 initial {
        days := ["Mon","Tue","Wed","Thr","Fri","Sat","Sun"]
        dates := ["Jan","Feb","Mar","Apr","May","Jun",
                  "Jul","Aug","Sep","Oct","Nov","Dec"]
 }
 every suspend   (retval <-  tab(match(!days)) ||     # Match a day
                             =" " ||                  # Followed by a blank
                             tab(match(!dates)) ||    # Followed by the month
                             =" " ||                  # Followed by a blank
                             matchdigits(2)           # Followed by at least 2 digits
                 ) &
                 (=" " | pos(0) ) &                   # Either a blank or the end of the string
                 retval                               # And finally return the string
 end
 # Matching function that returns a string of n digits
 procedure matchdigits(n)
     suspend (v := tab(many(&digits)) & *v <= n) & v
 end

expr1 & expr2 & expr3 എന്ന ശൈലി അവസാനത്തെ പദപ്രയോഗത്തിൻറെ മൂല്യം നൽകുന്നു.

ഇതും കൂടി കാണുക

[തിരുത്തുക]

അവലംബം

[തിരുത്തുക]

The definitive work is The Icon Programming Language (third edition) by Griswold and Griswold, ISBN 1-57398-001-3. It is out of print but can be downloaded in PDF form.

Icon also has co-expressions, providing non-local exits for program execution. Please see The Icon Programming language and also Shamim Mohamed's article Archived 2018-08-16 at the Wayback Machine. Co-expressions in Icon. (This topic should probably be expanded.)