JCSP - JCSP

JCSP жүзеге асыру болып табылады Кезектес процестерді байланыстыру (CSP) үшін Java бағдарламалау тілі.[1]

Дегенмен CSP математикалық жүйе, JCSP терең математикалық шеберлікті қажет етпейді, оның орнына бағдарламашылар қарапайым ережелерді сақтау арқылы өзін-өзі басқаратын бағдарламалық жасақтамаға қол жеткізе алады.

Шолу

Көп ағынды бағдарламалардың сынақтан өтпеуінің төрт әдісі бар:[1]

  • жарыс шарттары - ортақ айнымалылар анықталмаған күйге ие болуы мүмкін, себебі бірнеше ағындар оларға бір уақытта жеткілікті құлыптаусыз қол жеткізеді;
  • тығырық - екі немесе одан да көп жіптер құлыптарды немесе басқа ресурстарды қайшылықты жолмен алуға тырысқанда тығырыққа тіреледі;
  • тікелей эфир - тығырыққа ұқсас, бірақ нәтижесінде CPU уақытының шексіз босқа шығуы;
  • аштық - бір немесе бірнеше ағындар бағдарламалық жасақтама алгоритмдерінің жоспарланған нәтижелеріне қауіп төндіретін кез-келген жұмысты аяқтай алмайды.

Әдетте, бұл төрт қауіптің жоқтығын қатаң тестілеу арқылы дәлелдеу мүмкін емес. Қатаң тестілеу қажет болғанымен, бұл жеткіліксіз. Оның орнына осы төрт қауіпті көрсететін дизайн болуы керек. CSP мұны математиканың көмегімен жасауға мүмкіндік береді, ал JCSP оны Java бағдарламаларында прагматикалық түрде жасауға мүмкіндік береді.

Математикадағы негіздің артықшылығы - дұрыс мінез-құлықтың әдеттегіден гөрі күшті кепілдемелері болуы мүмкін осы жағдай үшін даму. Бақытымызға орай, JCSP пайдаланушыларды өздері математикалық тәсілді қабылдауға мәжбүрлемейді, бірақ оларға кітапхананың негізін қалайтын математикадан пайда табуға мүмкіндік береді.

CSP мерзімі екенін ескеріңіз процесс мәні үшін синоним ретінде қолданылады жіп Java тілімен айтқанда; а процесс in CSP - бұл сыртқы әлеммен оқиғалар арқылы өзара әрекеттесетін және ол жұмыс істейтін деректер құрылымын қоршайтын белсенді компонент.

Деректердің инкапсуляциясы бір ағынға байланысты (per процесс әдетте, ағындар арасында деректерді бөлуге тәуелділік жоқ. Керісінше, жіптер арасындағы байланыс анықталған байланыс нүктелері мен кездесу арқылы жүзеге асады. Пайдасы, әр ағынды жобалау кезінде «бір ағынды» тұлға ретінде қарастыруға болады, бұл әзірлеушіні Java-ны қайда және қай жерде пайдалану керек екендігі туралы белгісіздіктерден сақтайды. синхрондалған кілт сөз, сонымен бірге нәсілдік жағдайлардан босатуға кепілдік береді. JCSP аралық байланыстарды тығырықтан шығатындай етіп жобалаудың нақты қағидаларын қарастырады.

Стандартты Java API-дегі кейбір кластар арасында айқын ұқсастық бар (java.util.concrent), ал кейбіреулері JCSP-де. JCSP арна сыныптары ұқсас Бөгеу кезегі. Бір маңызды айырмашылық бар: JCSP сонымен бірге Балама кірістер арасында таңдау жасауға мүмкіндік беретін сынып; бұл мүмкіндік стандартты Java API-де жоқ. Альтернатива - бұл CSP нақты әлемдегі оқиғаларды модельдеу үшін қолданатын негізгі ұғымдардың бірі.

Балама өзінің кеңістігін толық математикалық талдау арқылы дұрыс жұмыс істейтіндігі дәлелденді, бұл оның ешқашан тығырыққа тірелуіне жол бермейді.[2] Осылайша, ол JCSP-тің математикалық негізіне тәуелділігін көрсетеді.

Желілік деңгей

Себебі TCP розеткаларды CSP мағынасында бұғаттайтын арналар ретінде жасауға болады, JCSP процестерін бірнеше компьютерлерде таратуға болады. Бұған TCP көмегімен арналарды CSP семантикасымен қамтамасыз ететін JCSP Net кеңейтуі арқылы қол жеткізіледі. CSP композициялық болғандықтан, процедуралардың бірге орналасуы немесе бөлінуі маңызды емес. Айырмашылық тек салыстырмалы өнімділікте. Мысалы, бір серверде қосымшаны әзірлеуге болады, содан кейін өнімділікті оңтайландыру мақсатында сол қосымшаның көп процессорлы нұсқасын салыстыру.

Басқа нұсқалар

Робот басылымы

JCSP re - бұл шамамен 2008 жылы жасалған JCSP пакеттерінің өте төмендетілген нұсқасы Напье университеті Профессор Джон Керридж, Алекс Панайотопулос және Патрик Лисмордың Эдинбург. Робототехника орталарына арналған JCSP-ге және мобильді ортаға арналған JCSP-ке арналған зерттеулер Эдинбургтағы Напиер университетінің белсенді зерттеу бағыты болып табылады. 'JCSP re' бағдарламасын енгізу роботтар үшін бірдей бағдарламалық жасақтама жасауға мүмкіндік береді. Нақтырақ айтқанда, осы зерттеуге бағытталған роботтар Lego Mindstorms NXTs өйткені олар танымалды басқара алады LeJOS Java бастапқы кодын орындайтын NXJ виртуалды машинасы.[3]

Басқа тілдерден JCSP қолдану

JCSP мәні бойынша таза Java API болып табылады (дегенмен, зерттеудің баламасы бар C-CSP JVM кеңейту). Осылайша, ол негізінен параллель үшін өте қолайлы Скала және Groovy қосымшалар, сонымен қатар Java.

Сондықтан JCSP Scala-ға балама ұсына алады актер моделі. JCSP синхрондалған байланысты қолданады, ал актерлер буферлік (асинхронды) байланысты қолданады, олардың әрқайсысы белгілі бір жағдайларда өздерінің артықшылықтарына ие. JCSP өз арналарын буферге алуға мүмкіндік береді, сондықтан актер моделін оңай еліктей алады; керісінше дұрыс емес.

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ а б Абхиджит Белапуркар (2005 ж. 21 маусым). «Java бағдарламашыларына арналған CSP». IBM developerWorks. Алынған 2007-04-20.
  2. ^ Питер Уэлч, Джереми Мартин (2000). «Бір уақытта жасалған Java жүйелерін ресми талдау». Байланыс процесінің архитектуралары 2000 ж.
  3. ^ Джон Керридж, Алекс Панайтопулос, Патрик Лисмор. «JCSPre: LEGO NXT роботтарын басқаруға арналған робот басылымы». Ілеспе жүйелердің инженерлік сериясы 66-том: Процесс архитектуралары 2008 ж. IOS баспасөз кітаптары: 255–270. дои:10.3233/978-1-58603-907-3-255. Түпнұсқадан мұрағатталған 2010-04-18.CS1 maint: авторлар параметрін қолданады (сілтеме) CS1 maint: BOT: түпнұсқа-url күйі белгісіз (сілтеме)

Сыртқы сілтемелер