Talaan ng mga Nilalaman:
Kahulugan - Ano ang ibig sabihin ng Atomic?
Ang Atomic ay isang toolkit ng variable na java.util.concurrent.atomic na mga klase ng pakete, na tumutulong sa pagsulat ng lock at mga paghihintay na walang algorithm sa wikang Java. Ang isang algorithm na nangangailangan lamang ng mga bahagyang mga thread para sa patuloy na pag-unlad ay walang lock. Sa isang algorithm na walang paghihintay, ang lahat ng mga thread ay patuloy na sumusulong, kahit na sa mga kaso ng pagkabigo ng thread o pagkaantala. Ang mga naka-lock at wait-free algorithm ay kilala rin bilang mga nonblock na algorithm. Ang mga pag-unblock ng algorithm ay ginagamit para sa proseso at pag-iskedyul ng thread sa operating system at mga antas ng virtual na Java virtual.
Ipinapaliwanag ng Techopedia ang Atomic
Ang lahat ng mga java.util.concurrent.atomic na mga klase ng pakete ay mayroong prefix na "atomic" sa kanilang mga pangalan. Mayroong iba't ibang mga uri ng mga variable na atom na magagamit sa pakete ng java.util.concurrent.atomic, kasama ang:
- AtomicBoolean
- AtomicInteger
- AtomicIntegerArray
- AtomicIntegerFieldUpdater
- AtomicLong
- AtomicLongArray
- AtomicLongFieldUpdater
- AtomicReference
Ang isang halimbawa ay isang senaryo kung saan may hawak na kandila ang thread A. Ang A ay lamang ma-access at gumawa ng mga pagbabago sa mga variable na protektado ng lock na ito. Kung ang thread B ay humahawak sa lock na ito pagkatapos ng A, pagkatapos lamang ang B ay maaaring makita ang mga pagbabago ng A sa mga variable na protektado ng partikular na lock. Ang pangunahing problema sa pag-lock ay nangyayari kapag sinubukan ng B na makakuha ng isang lock na hawak ng A. Sa kasong ito, naharang ang B na maghintay hanggang magamit ang lock. Ang mga pag-unblock ng algorithm ay lutasin ang problemang ito.
Ang pangunahing layunin sa likod ng pagtatayo ng mga klase ng atomic ay upang ipatupad ang mga hindi pagblock ng mga istruktura ng data at ang kanilang mga kaugnay na klase sa imprastruktura Ang mga klase ng atom ay hindi nagsisilbing mga kapalit para sa java.lang.Integer at mga kaugnay na klase. Karamihan sa mga klase ng java.util.concurrent na pakete ay gumagamit ng mga variable na atomic sa halip na pag-synchronize, alinman nang direkta o hindi tuwiran. Ginagamit din ang mga variable na atom upang makamit ang mas mataas na throughput, na nangangahulugang mas mataas na pagganap ng server ng aplikasyon.