Dynamická detekce a léčení časově závislých chyb nad daty v prostředí Java
but.jazyk | čeština (Czech) | |
but.program | Informační technologie | cs |
but.result | práce byla úspěšně obhájena | cs |
dc.contributor.advisor | Vojnar, Tomáš | cs |
dc.contributor.author | Letko, Zdeněk | cs |
dc.contributor.referee | Kolář, Dušan | cs |
dc.date.created | cs | |
dc.description.abstract | Hledání chyb plynoucích ze souběžného zpracovávání výpočtů je obtížné. Proto se tato diplomová práce zabývá detekcí a léčením časově závislých chyb nad daty a chyb plynoucích z nesprávné atomicity operací v prostředí Java. Práce prezentuje dva různé algoritmy pro detekci. Jedním z nich je nový algoritmus nazvaný AtomRace, který detekuje časově závislé chyby nad daty jako speciální případ nesprávné atomicity operací. Následné léčení detekovaných chyb je založeno na potlačení opakování chyby, buď zavedením přídavné synchronizace, nebo legálním ovlivňováním plánovače Javy, za účelem vynucení správné atomicity operací. Navržená architektura, která pracuje souběžně se sledovaným programem, využívá ke sledování a ovlivňování výpočtu techniku instrumentace na úrovni Java bytecode. Architektura a algoritmy byly implementovány a otestovány v několika případových studiích. | cs |
dc.description.abstract | Finding concurrency bugs in complex software is difficult. As a contribution to coping with this problem the thesis proposes an architecture for a fully automated dynamic detection and healing of data races and atomicity violations in Java. Two distinct algorithms for detecting of data races are presented. One of them is a novel algorithm called AtomRace which detects data races as a special case of atomicity violations. The healing is based on suppressing a recurrence of the detected problem and can be performed by introducing an additional synchronization or by legally influencing the Java scheduler. Basically forces certain parts of the code to be executed atomically. The proposed architecture uses bytecode instrumentation to be able to track and influence the execution. The architecture and algorithms were implemented and tested on multiple case studies. | en |
dc.description.mark | A | cs |
dc.identifier.citation | LETKO, Z. Dynamická detekce a léčení časově závislých chyb nad daty v prostředí Java [online]. Brno: Vysoké učení technické v Brně. Fakulta informačních technologií. . | cs |
dc.identifier.other | 25231 | cs |
dc.identifier.uri | http://hdl.handle.net/11012/53232 | |
dc.language.iso | cs | cs |
dc.publisher | Vysoké učení technické v Brně. Fakulta informačních technologií | cs |
dc.rights | Standardní licenční smlouva - přístup k plnému textu bez omezení | cs |
dc.subject | formální verifikace | cs |
dc.subject | testování softwaru | cs |
dc.subject | dynamická analýza | cs |
dc.subject | statická analýza | cs |
dc.subject | časově závislé chyby | cs |
dc.subject | chyby v atomicitě operací | cs |
dc.subject | automatické léčení | cs |
dc.subject | vícevláknové programy | cs |
dc.subject | Java | cs |
dc.subject | formal verification | en |
dc.subject | software testing | en |
dc.subject | dynamic analysis | en |
dc.subject | static analysis | en |
dc.subject | data races | en |
dc.subject | atomicity violation | en |
dc.subject | automatic healing | en |
dc.subject | multi-threaded programs | en |
dc.subject | Java | en |
dc.title | Dynamická detekce a léčení časově závislých chyb nad daty v prostředí Java | cs |
dc.title.alternative | Dynamic Data Race Detection and Self-Healing in Java Programs | en |
dc.type | Text | cs |
dc.type.driver | masterThesis | en |
dc.type.evskp | diplomová práce | cs |
dcterms.modified | 2020-05-09-23:40:42 | cs |
eprints.affiliatedInstitution.faculty | Fakulta informačních technologií | cs |
sync.item.dbid | 25231 | en |
sync.item.dbtype | ZP | en |
sync.item.insts | 2025.03.26 15:05:36 | en |
sync.item.modts | 2025.01.16 00:20:36 | en |
thesis.discipline | Inteligentní systémy | cs |
thesis.grantor | Vysoké učení technické v Brně. Fakulta informačních technologií. Ústav inteligentních systémů | cs |
thesis.level | Inženýrský | cs |
thesis.name | Ing. | cs |