下面我就個人觀點猜測一下,並行運算將會怎樣支持前端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引擎內部對原有串行代碼分析,而且要准確,將可以轉換為並行的代碼進行優化.我想這個任務還是很堅巨的.