- 相關推薦
運算將會怎樣支持前端javascript
下面我就個人觀點猜測一下,并行運算將會怎樣支持前端javascript的.
1 不太可能的進化
顯示線程的支持
如果在Javascript中支持顯示線程,那么可能是一種災難,目前的瀏覽器解析Javascript并執行都是在瀏覽器的ui線程中工作的.
比如你可以在Javascript中運行while(true),這時瀏覽器界面就會停止響應.或者通過我之前的文章(編譯Javascript引擎,為JavaScript提供睡眠功能:http://www.cnblogs.com/ioriwellings/archive/2010/08/16/1800416.html)了解UI界面被阻塞的過程.
另外如果顯示支持線程必然也會支持線程間數據同步的同步原語功能,那就會出現這樣的問題:
在一個函數中獲取鎖,而在另一個函數中釋放鎖,但是如果另一個函數出錯怎么辦,或者另一個函數是從另一個文件中引用的,又碰巧那個文件由于某些原因(網絡問題,編碼問題)沒有加載進來,這時就會發生死鎖.
所以根據上面的一些原因,在JavaScript支持顯示線程還不太現實.
2 有可能的進化
隱式的并行支持
類似于openMP的宏指令,
下面代碼聲明并行運算FOR循環:
復制代碼 代碼如下:
#pragma omp parallel for
for (i = 0; i < N; i++)
a[i] = 2 * i;
這種方式可以避免前面遇到的各種麻煩,并行的運算被托管于Javascript引擎內部,所以Javascript引擎有更多的空間處理優化這些并行運算,比如在內部調用openMP,Intel TBB的并行功能.
所以我推測這種方式將會很可能被采用.
3 處理并行異常
由于Javascript代碼被隱式托管于并行線程處理,所以你可能不會馬上得到某個線程的異常狀態,而是要等到全部的線程運行結束后才會知道某些代碼出現異常.
4 調試器的進化
會產生支持線程感知的Javascript調試器,能夠分析每個線程中的信息,并且能夠凍結/恢復某個線程的運行.
當然了,類似于firebug這樣的用Javascript腳本寫的調試器也將會有更大的提升,但是我想更理想的還是本地應用程序的調試器將會成為主流,比如:visual studio.
5 結語
并行運算將會影響前臺Javascript的執行性能,很多用Javascript寫的前臺效果,Javascript游戲的性能將得到改變與提升. 可是我會看到javascript的這種轉變嗎?
如果實在等不到,還是可以編譯現有的js引擎,并添加并行運算接口,然后自已發布瀏覽器,讓客戶下載,多核的功能還是可能利用到的.
但是還要兼容現在javascript規范,不然其它瀏覽器將不能識別你的代碼,所以就需要在js引擎內部對原有串行代碼分析,而且要準確,將可以轉換為并行的代碼進行優化.我想這個任務還是很堅巨的.
【運算將會怎樣支持前端javascript】相關文章:
javascript分析運算符用法08-07
對javascript的理解08-08
常用的JavaScript模式09-22
Javascript的this用法簡述08-15
JavaScript學習筆記08-24
JavaScript 基礎教學09-29
JavaScript的課堂講解09-03
JavaScript常用方法匯總10-25
JavaScript數組常用方法介紹09-04
JavaScript中的with關鍵字07-24