鍍金池/ 問答/HTML/ JS代碼執(zhí)行,會不會出現(xiàn)Function A()的代碼執(zhí)行一半,又去執(zhí)行Func

JS代碼執(zhí)行,會不會出現(xiàn)Function A()的代碼執(zhí)行一半,又去執(zhí)行Function B()的代碼?

如題,我們有一個如下的業(yè)務(wù)需求

var x=[];

function A(){
處理X
}

function B(){
也處理X
}

我現(xiàn)在擔心,因為function A和B都在處理X,如果運行時出現(xiàn)交叉,就會導致一些代碼邏輯問題。
在數(shù)據(jù)庫中,一般是通過鎖表的形式,防止X被兩個操作同時修改。
但是在JS中,不知道有什么方法可以避免這種情況?
或者說,JS的代碼運行方式,根本就不會出現(xiàn)這種情況,肯定是完整的代碼塊運行完,才會運行下一個代碼塊?

多謝

回答
編輯回答
離觴

不會的,單線程不會出現(xiàn)

2018年1月23日 17:54
編輯回答
孤酒

沒有同時這概念,代碼都會被執(zhí)行,但不一定有結(jié)果(感覺你問的是這個)。比如function里面有異步方法的話,會出現(xiàn)看似A執(zhí)行到某一部分執(zhí)行B然后又執(zhí)行A。

var x = [];

function A() {
    setTimeout(() => {
        x[0] = 'A'
        setTimeout(() => { console.log('A', x) }, 0)
    }, 0)
}

function B() {
    setTimeout(() => {
        x[0] = 'B'
    }, 0)
}

A();
B();

解決方式就是異步流程控制的問題,搜一下一大堆。

2018年1月9日 02:40