Це можливо, якщо доступ до змінної a
, скажімо, двома веб-працівниками через SharedArrayBuffer, а також якийсь основний сценарій. Можливість невелика, але цілком можливо , що , коли код компілюється в машинний код, веб - робочі оновити змінну a
як раз вчасно , так що умови a==1
, a==2
і a==3
задоволені.
Це може бути приклад стану перегонів у багатопотоковому середовищі, що надається веб-працівниками та SharedArrayBuffer в JavaScript.
Ось основна реалізація вище:
main.js
// Main Thread
const worker = new Worker('worker.js')
const modifiers = [new Worker('modifier.js'), new Worker('modifier.js')] // Let's use 2 workers
const sab = new SharedArrayBuffer(1)
modifiers.forEach(m => m.postMessage(sab))
worker.postMessage(sab)
робітник.js
let array
Object.defineProperty(self, 'a', {
get() {
return array[0]
}
});
addEventListener('message', ({data}) => {
array = new Uint8Array(data)
let count = 0
do {
var res = a == 1 && a == 2 && a == 3
++count
} while(res == false) // just for clarity. !res is fine
console.log(`It happened after ${count} iterations`)
console.log('You should\'ve never seen this')
})
modifier.js
addEventListener('message' , ({data}) => {
setInterval( () => {
new Uint8Array(data)[0] = Math.floor(Math.random()*3) + 1
})
})
У моєму MacBook Air це відбувається після приблизно 10 мільярдів ітерацій з першої спроби:
Друга спроба:
Як я вже говорив, шанси будуть низькими, але якщо буде достатньо часу, це вдарить за умовою.
Порада. Якщо у вашій системі знадобиться занадто довго Спробуйте лише a == 1 && a == 2
змінити Math.random()*3
на Math.random()*2
. Якщо все більше і більше додавати до списку, випадаєте шанси нанести удар.