Javascript的并行運算實現代碼
更新時間:2010年11月19日 21:22:06 作者:
隨著多核cpu的普級,并發(fā)/并行多線程運算在主流的編程語言越來越流行,而在目前Javascript實現中還看不到在語言方面支持多線程,現在Javascript如此流行,真希望今后會在語言的層面有很大的變化.
下面我就個人觀點猜測一下,并行運算將會怎樣支持前端javascript的.
1 不太可能的進化
顯示線程的支持
如果在Javascript中支持顯示線程,那么可能是一種災難,目前的瀏覽器解析Javascript并執(zhí)行都是在瀏覽器的ui線程中工作的.
比如你可以在Javascript中運行while(true),這時瀏覽器界面就會停止響應.或者通過我之前的文章(編譯Javascript引擎,為JavaScript提供睡眠功能:http://www.cnblogs.com/ioriwellings/archive/2010/08/16/1800416.html)了解UI界面被阻塞的過程.
另外如果顯示支持線程必然也會支持線程間數據同步的同步原語功能,那就會出現這樣的問題:
在一個函數中獲取鎖,而在另一個函數中釋放鎖,但是如果另一個函數出錯怎么辦,或者另一個函數是從另一個文件中引用的,又碰巧那個文件由于某些原因(網絡問題,編碼問題)沒有加載進來,這時就會發(fā)生死鎖.
所以根據上面的一些原因,在JavaScript支持顯示線程還不太現實.
2 有可能的進化
隱式的并行支持
類似于openMP的宏指令,
下面代碼聲明并行運算FOR循環(huán):
#pragma omp parallel for
for (i = 0; i < N; i++)
a[i] = 2 * i;
這種方式可以避免前面遇到的各種麻煩,并行的運算被托管于Javascript引擎內部,所以Javascript引擎有更多的空間處理優(yōu)化這些并行運算,比如在內部調用openMP,Intel TBB的并行功能.
所以我推測這種方式將會很可能被采用.
3 處理并行異常
由于Javascript代碼被隱式托管于并行線程處理,所以你可能不會馬上得到某個線程的異常狀態(tài),而是要等到全部的線程運行結束后才會知道某些代碼出現異常.
4 調試器的進化
會產生支持線程感知的Javascript調試器,能夠分析每個線程中的信息,并且能夠凍結/恢復某個線程的運行.
當然了,類似于firebug這樣的用Javascript腳本寫的調試器也將會有更大的提升,但是我想更理想的還是本地應用程序的調試器將會成為主流,比如:visual studio.
5 結語
并行運算將會影響前臺Javascript的執(zhí)行性能,很多用Javascript寫的前臺效果,Javascript游戲的性能將得到改變與提升. 可是我會看到javascript的這種轉變嗎?
如果實在等不到,還是可以編譯現有的js引擎,并添加并行運算接口,然后自已發(fā)布瀏覽器,讓客戶下載,多核的功能還是可能利用到的.
但是還要兼容現在javascript規(guī)范,不然其它瀏覽器將不能識別你的代碼,所以就需要在js引擎內部對原有串行代碼分析,而且要準確,將可以轉換為并行的代碼進行優(yōu)化.我想這個任務還是很堅巨的.
1 不太可能的進化
顯示線程的支持
如果在Javascript中支持顯示線程,那么可能是一種災難,目前的瀏覽器解析Javascript并執(zhí)行都是在瀏覽器的ui線程中工作的.
比如你可以在Javascript中運行while(true),這時瀏覽器界面就會停止響應.或者通過我之前的文章(編譯Javascript引擎,為JavaScript提供睡眠功能:http://www.cnblogs.com/ioriwellings/archive/2010/08/16/1800416.html)了解UI界面被阻塞的過程.
另外如果顯示支持線程必然也會支持線程間數據同步的同步原語功能,那就會出現這樣的問題:
在一個函數中獲取鎖,而在另一個函數中釋放鎖,但是如果另一個函數出錯怎么辦,或者另一個函數是從另一個文件中引用的,又碰巧那個文件由于某些原因(網絡問題,編碼問題)沒有加載進來,這時就會發(fā)生死鎖.
所以根據上面的一些原因,在JavaScript支持顯示線程還不太現實.
2 有可能的進化
隱式的并行支持
類似于openMP的宏指令,
下面代碼聲明并行運算FOR循環(huán):
復制代碼 代碼如下:
#pragma omp parallel for
for (i = 0; i < N; i++)
a[i] = 2 * i;
這種方式可以避免前面遇到的各種麻煩,并行的運算被托管于Javascript引擎內部,所以Javascript引擎有更多的空間處理優(yōu)化這些并行運算,比如在內部調用openMP,Intel TBB的并行功能.
所以我推測這種方式將會很可能被采用.
3 處理并行異常
由于Javascript代碼被隱式托管于并行線程處理,所以你可能不會馬上得到某個線程的異常狀態(tài),而是要等到全部的線程運行結束后才會知道某些代碼出現異常.
4 調試器的進化
會產生支持線程感知的Javascript調試器,能夠分析每個線程中的信息,并且能夠凍結/恢復某個線程的運行.
當然了,類似于firebug這樣的用Javascript腳本寫的調試器也將會有更大的提升,但是我想更理想的還是本地應用程序的調試器將會成為主流,比如:visual studio.
5 結語
并行運算將會影響前臺Javascript的執(zhí)行性能,很多用Javascript寫的前臺效果,Javascript游戲的性能將得到改變與提升. 可是我會看到javascript的這種轉變嗎?
如果實在等不到,還是可以編譯現有的js引擎,并添加并行運算接口,然后自已發(fā)布瀏覽器,讓客戶下載,多核的功能還是可能利用到的.
但是還要兼容現在javascript規(guī)范,不然其它瀏覽器將不能識別你的代碼,所以就需要在js引擎內部對原有串行代碼分析,而且要準確,將可以轉換為并行的代碼進行優(yōu)化.我想這個任務還是很堅巨的.
您可能感興趣的文章:
- js實現多個倒計時并行 js拼團倒計時
- 利用Chrome DevTools直接調試Node.js和JavaScript的方法詳解(并行)
- headjs實現網站并行加載但順序執(zhí)行JS
- 深入理解JavaScript中的并行處理
- 前端 javascript 實現文件下載的示例
- Javascript前端下載后臺傳來的文件流代碼實例
- JavaScript實現多文件下載方法解析
- 原生js實現文件上傳、下載、封裝等實例方法
- JavaScript實現文件下載并重命名代碼實例
- vue實現在線預覽pdf文件和下載(pdf.js)
- 使用 JavaScript 創(chuàng)建并下載文件(模擬點擊)
- node.js express框架實現文件上傳與下載功能實例詳解
- JavaScript 中如何實現大文件并行下載
相關文章
javascript函數報Uncaught?ReferenceError:?XXX?is?not?define
本文主要介紹了javascript函數報Uncaught?ReferenceError:?XXX?is?not?defined,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-07-07