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