精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

【熱點推薦】在JavaScript中使用C程序

開發 前端
每一門語言都有各自的優缺點。將不同語言的優勢相互結合,可以程序變得更優雅、更完美。

JavaScript 是個靈活的腳本語言,能方便的處理業務邏輯。當需要傳輸通信時,我們大多選擇 JSON 或 XML 格式。

但在數據長度非常苛刻的情況下,文本協議的效率就非常低了,這時不得不使用二進制格式。

去年的今天,在折騰一個 前后端結合的 WAF 時,就遇到了這個麻煩。

因為前端腳本需要采集不少數據,而最終是隱寫在某個 cookie 里的,因此可用的長度非常有限,只有幾十個字節。

如果不假思索就用 JSON 的話,光一個標記字段 {"enableXX": true} 就占去了一半長度。然而在二進制里,標記 true 或 false 不過是 1 個比特的事,可以節省上百倍的空間。

同時,數據還要經過校驗、加密等環節,只有使用二進制格式,才能方便的調用這些算法。

優雅實現

不過,JavaScript 并不支持二進制。

這里的「不支持」不是說「無法實現」,而是無法「優雅實現」。語言的發明,就是用來優雅解決問題的。即使沒有語言,人類也可以用機器指令來編寫程序。

如果非要用 JavaScript 操作二進制,最終就類似這樣:

var flags = +enableXX1 << 16 | +enableXX2 << 15 | ...

雖然能實現,但很丑陋。各種硬編碼、各種位運算。

然而,對于先天支持二進制的語言,看起來就十分優雅:

  1. union { 
  2.     struct { 
  3.         int enableXX1: 1
  4.         int enableXX2: 1
  5.         ... 
  6.     }; 
  7.     int16_t value; 
  8. } flags; 
  9.  
  10. flags.enableXX1 = enableXX1; 
  11. flags.enableXX2 = enableXX2; 

開發者只需定義一個描述即可。使用時,字段偏移多少、如何讀寫,這些細節完全不用關心。

為了能達到類似效果,起先封裝了一個 JS 版的結構體:

  1. // 最初方案:封裝一個 JS 結構體 
  2. var s = new Struct([ 
  3.     {name: 'month', bit: 4, signed: false}, 
  4.     ... 
  5. ]); 
  6. s.set('month'12); 
  7. s.get('month'); 

將細節進行了隱藏,看起來就優雅多了。

優雅但不***

但是,這總感覺不是最***的。結構體這種東西,本該由語言提供,如今卻要用額外的代碼實現,而且還是在運行期間。

另外,后端解碼是用 C 實現的,所以得維護兩套代碼。一旦數據結構或者算法變了,得同時更新 JS 和 C,很麻煩。

于是琢磨,能否共用一套 C 代碼,同時用于前端和后端?

也就是說,需要能將 C 編譯成 JS 來運行。

認識 emscripten

能將 C 編譯成 JS 的工具有不少,最專業的要數 emscripten

emscripten 的使用方式很簡單,和傳統 C 編譯器差不多,只不過生成的是 JS 代碼。

  1. ./emcc hello.c -o hello.html 
  2. // hello.c 
  3. #include <stdio.h> 
  4. #include <time.h>  
  5.  
  6. int main() { 
  7.     time_t now; 
  8.     time(&now); 
  9.     printf("Hello World: %s", ctime(&now)); return 0

編譯之后即可運行:

很有趣吧~ 大家可以嘗試下,這里就不多介紹了。

實用缺陷

然而我們關心的不是有趣,而是實用。

事實上,即使一個 Hello World 編譯出來的 JS 也過萬行,多達數百 KB。就算壓縮再 GZIP,仍有幾十 KB。

同時 emscripten 使用了 asm.js 規范,內存訪問是通過 TypedArray 實現的。

這意味著 IE10 以下的用戶都無法運行。這也是不可接受的。

因此,我們得做如下改進:

  • 減少體積

  • 增加兼容

首先寄托 emscripten 本身,看看能不能通過設置參數,來達到我們的目的。

不過一番嘗試之后,并沒有成功。那只能自己動手實現了。

減少體積

為什么最終腳本會那么大,里面都放了些什么?分析了下內容,大致有這幾個部分:

  • 輔助功能

  • 接口模擬

  • 初始化操作

  • 運行時函數

  • 程序邏輯

輔助功能

比如字符串和二進制轉換、提供回調包裝等。這些基本都是用不著的,我們可以給自己寫個特殊的回調函數。

接口模擬

提供文件、終端、網絡、渲染等接口。之前見過用 emscripten 移植的客戶端游戲,看來模擬了不少接口。

初始化操作

全局內存、運行時、各種模塊的初始化。

運行時函數

純粹的 C 只能做簡單的計算,很多功能都依靠運行時函數。

不過,有些常用的函數,其背后的實現是及其復雜的。例如 malloc 和 free,對應的 JS 有近 2000 行!

程序邏輯

這才是 C 程序真正對應的 JS 代碼。因為編譯時經過 LLVM 的優化,邏輯可能變得面目全非了。

這部分代碼量不大,是我們真正想要的。

事實上,如果程序沒有用到一些特殊功能的話,把邏輯函數單獨摳出來,仍然是可以運行的!

考慮到我們的 C 程序非常簡單,所以簡單粗暴的提取出來,也是沒問題的。

C 程序對應的 JS 邏輯位于 // EMSCRIPTEN_START_FUNCS// EMSCRIPTEN_END_FUNCS 之間。過濾掉運行時函數,剩下的就是 100% 的邏輯代碼了。

增加兼容

接著解決內存訪問的兼容性問題。

首先了解下,為何要用 TypedArray。

emscripten 申請了一大塊 ArrayBuffer 來模擬內存,然后關聯了一些 HEAP 開頭的變量。

這些不同類型的 HEAP 共享同一塊內存,這樣就能高效的指針操作。

然而不支持 TypedArray 的瀏覽器,顯然無法運行。所以得提供個 polyfill 兼容下。

但經分析,這幾乎不可能實現 —— 因為 TypedArray 和數組一樣,是通過索引來訪問的:

  1. var buf = new UInt8Array(100); 
  2. buf[0] = 123;     // set 
  3. alert(buf[0]);    // get 

然而 [] 操作符在 JS 里是無法重寫的,因此難以將其變成 setter 和 getter。況且不支持 TypedArray 的都是低版本 IE,更不用考慮 ES6 的那些特征。

于是琢磨 IE 的私有接口。比如用 onpropertychange 事件來模擬 setter。不過這樣做效率極低,而且 getter 仍不易實現。

經過一番考慮,決定不用鉤子的方式,而是直接從源頭上解決 —— 修改語法!

我們用正則,找出源碼中的賦值操作:

  1. HEAP[index] = val; 

替換成:

  1. HEAP_SET(index, val); 

類似的,將讀取操作:

  1. HEAP[index] 

替換成:

  1. HEAP_GET(index) 

這樣,原先的索引操作,就變成函數調用了。我們就能接管內存的讀寫,并且沒有任何兼容性問題!

然后實現 8、16、32 位有無符號的版本。通過 JS 的 Array 來模擬,非常簡單。

麻煩的是模擬 Float32Float64 兩個類型。不過本次 C 程序中并未用到浮點,所以就暫不實現了。

到此,兼容性問題就解決了。

大功告成

解決了這些缺陷,我們就可以愉快的在 JS 中使用 C 邏輯了。

作為腳本,只需關心采集哪些數據。這樣 JS 代碼就非常的優雅:

數據的儲存、加密、編碼,這些底層數據操作,則通過 C 實現。

編譯時使用 -Os 參數優化體積。最終的 JS 混淆壓縮之后,還不到 2 KB,十分小巧精煉。

更***的是,我們只需維護一份代碼,即可同時編譯出前端和后端兩個版本。

于是,這個「前后端 WAF」開發就容易多了。

所有的數據結構和算法,都由 C 實現。前端編譯成 JS 代碼,后端編譯成 lua 模塊,供 nginx-lua 使用。

前后端的腳本,都只需關注業務功能即可,完全不用涉及數據層面的細節。

測試版

事實上,還有第三個版本 —— 本地版。

因為所有的 C 代碼都在一起,因此可以方便的編寫測試程序。

這樣就無需啟動 WebServer、打開瀏覽器來測試了。只需模擬一些數據,直接運行程序即可測試,非常輕量。

同時借助 IDE,調試起來更容易。

小結

每一門語言都有各自的優缺點。將不同語言的優勢相互結合,可以程序變得更優雅、更***。

 

責任編輯:王雪燕 來源: 博客園
相關推薦

2012-04-11 10:39:32

Eclipse

2011-05-17 16:20:46

C++

2011-03-30 10:41:11

C++數據庫

2017-03-01 20:31:35

程序員

2017-03-06 09:06:13

2011-06-30 10:50:39

Qt OpenCV

2010-04-21 17:50:59

共享庫bada

2023-10-04 07:25:59

JavaScriptpromises

2014-08-01 15:16:05

SwiftC語言

2009-09-22 12:17:59

ibmdwLotus

2015-04-17 16:44:22

swiftOC

2011-09-07 09:51:27

Javascript

2016-02-17 09:56:37

職業程序員

2011-05-12 18:14:29

算法

2012-08-20 10:43:50

IBMdW

2021-09-07 10:24:36

Vue應用程序Web Workers

2011-05-27 08:48:13

Android HTML

2013-10-09 11:15:49

Ubuntu應用程序

2009-06-19 13:45:53

Java應用程序Jfreechart

2020-03-11 09:15:25

微信asyncawait
點贊
收藏

51CTO技術棧公眾號

美女网站一区| 午夜小视频在线| 国语对白精品一区二区| 日韩区在线观看| 我的公把我弄高潮了视频| 四虎免费在线观看| 亚洲中字在线| 亚洲男人av在线| 成人免费在线观看视频网站| a级影片在线观看| av中文字幕不卡| 青青a在线精品免费观看| 美女福利视频网| 欧美区一区二区| 一区二区三区欧美日| 麻豆亚洲一区| 在线观看免费高清视频| 综合色一区二区| 91蜜桃免费观看视频| 国产精品欧美极品| 国产精品美乳在线观看| 久久久91视频| 日韩av免费大片| 亚洲精品在线电影| 污片在线免费看| 国产在线拍揄自揄拍视频| 国产亚洲精品福利| www日韩av| 在线观看免费观看在线| 国产日本精品| 欧美日本在线视频中文字字幕| jjzzjjzz欧美69巨大| 国产精品久久乐| 欧美日韩精品中文字幕| 在线国产精品网| 免费在线超碰| 成人av高清在线| 91夜夜揉人人捏人人添红杏| 免费看一级视频| 亚洲福利一区| 视频直播国产精品| 国产ts在线播放| 欧美1区二区| 91精品欧美福利在线观看| 欧美,日韩,国产在线| 99在线视频观看| 综合久久国产九一剧情麻豆| 日韩精品久久久毛片一区二区| 亚洲国产视频一区二区三区| 国产中文一区二区三区| 国产精品揄拍500视频| www.久久久久久久| 国产精品试看| 4p变态网欧美系列| 波多野结衣国产| 亚洲人成高清| 久久全球大尺度高清视频| 麻豆国产尤物av尤物在线观看| 国产一区三区在线播放| 精品视频久久久久久久| yjizz视频| 高清一区二区三区| 亚洲国产成人久久| www.男人天堂| 手机av在线网| 免费电影视频在线看| 亚洲视频狠狠干| 亚洲一区三区在线观看| 午夜免费福利在线观看| 国产欧美va欧美不卡在线| 欧美一区免费视频| 天堂成人在线| 国产区在线观看成人精品| 日韩久久久久久久久久久久久| 国产二区视频在线观看| 国产嫩草影院久久久久| 亚洲免费视频一区| 曰本三级在线| 午夜视频在线观看一区二区| 欧美一级黄色片视频| 成人国产一区| 欧美一区二区高清| 又黄又爽的网站| 色婷婷精品视频| 亚洲欧美日本精品| 中文字幕91视频| 亚洲一级高清| 97久久精品人人澡人人爽缅北| 911国产在线| 国产精品麻豆久久| 久久久久久久久久久免费| av大全在线观看| 麻豆精品视频在线观看| 97视频资源在线观看| 亚洲欧美综合一区二区| 国产亚洲成av人在线观看导航| 国产欧美日韩综合一区在线观看 | 精品黄色一级片| 久久精品国产69国产精品亚洲| 亚洲一级黄色录像| 精品久久不卡| 欧美大成色www永久网站婷| 亚洲精品视频久久久| 美女一区2区| 国产一区二区三区三区在线观看 | 日韩理论片网站| 免费网站永久免费观看| 亚洲国产成人二区| 色综合久久88色综合天天6| 成人免费在线观看视频网站| 亚洲精品黑牛一区二区三区| 国产丝袜一区视频在线观看 | 深夜视频一区二区| 日韩欧美亚洲综合| 亚洲精品永久视频| 日韩成人在线看| 亚洲成年人在线| 69精品无码成人久久久久久| 欧美二区不卡| 庆余年2免费日韩剧观看大牛| 波多野结衣黄色| 精品一区二区三区免费毛片爱| 国产精品一区视频网站| 香港三日本三级少妇66| 不卡的看片网站| 欧美一卡2卡3卡4卡无卡免费观看水多多 | 国产毛片av在线| 一个色综合网站| 日日摸天天爽天天爽视频| 久久国际精品| 亚洲国产精品一区二区三区| 国产大片免费看| 日韩精品91亚洲二区在线观看| 91嫩草在线视频| 日韩一级在线播放| 26uuu亚洲婷婷狠狠天堂| 正在播放一区二区三区| 中文字幕在线看片| 欧美成人a∨高清免费观看| 老司机深夜福利网站| 欧美视频四区| 国产在线精品成人一区二区三区| www精品国产| 国产精品传媒入口麻豆| 人妻熟女一二三区夜夜爱| 精品一区二区三区视频在线播放 | 亚洲乱码国产乱码精品精大量| 97欧美成人| 亚洲国产精品电影| 人妻少妇精品一区二区三区| 日本色综合中文字幕| 久久99精品久久久久久久久久| 国产一区久久精品| 欧美日韩中文在线观看| 日本xxxx裸体xxxx| 亚洲福利免费| 国产精品一区二区欧美| 91麻豆免费在线视频| 91精品办公室少妇高潮对白| 国产成人无码一区二区在线观看 | 亚洲成人999| 天天插天天操天天干| 成人av综合在线| 欧美日韩dvd| 欧美视频二区欧美影视| 久久深夜福利免费观看| 国产精品视频一二区| 中文成人av在线| 蜜臀久久99精品久久久酒店新书 | 久久综合中文色婷婷| 国产美女情趣调教h一区二区| 日韩欧美综合一区| 手机看片国产日韩| 麻豆成人综合网| 欧美日韩精品中文字幕一区二区| 另类图片综合电影| 日韩亚洲欧美中文三级| 久久久99精品| 91在线云播放| 大肉大捧一进一出好爽视频| 久草手机视频在线观看| 综合伊思人在钱三区| 欧洲亚洲免费视频| 日韩电影网址| 91福利在线播放| 国产又黄又粗视频| 久久福利一区| 日本精品二区| 精品一区二区三区在线观看视频| 久久精品国产亚洲精品2020| 精品一区二区无码| 亚洲欧洲精品一区二区三区不卡| 欧美一级特黄aaa| 亚洲一区二区| 成人羞羞视频免费| 日本欧美韩国| 中文字幕国产日韩| 成人黄色免费网| 亚洲欧美经典视频| 少妇精品无码一区二区三区| 视频一区二区中文字幕| 亚洲一区二区在| 欧美91在线| 青青草原成人在线视频| aⅴ在线视频男人的天堂 | 亚洲开心激情网| 中文字幕一区2区3区| 国产精品欧美一区喷水| 亚洲精品成人在线播放| 日韩一区二区免费看| 日本欧美精品久久久| 九九九九九九精品任你躁| 欧美一区第一页| 欧美96在线| 日韩经典中文字幕| 国产乱码精品一区二三区蜜臂 | 亚洲精品人成| 国产精品毛片视频| 国产精品igao视频| 污视频网站在线免费| 亚洲成人精品av| 亚洲欧美综合另类| 亚洲成在人线在线播放| 影音先锋男人看片资源| 久久99精品久久久久久久久久久久| 91.com在线| 第一社区sis001原创亚洲| 成人国产精品一区| 2018av在线| 欧美放荡办公室videos4k| а√天堂资源在线| 国产高清在线精品| 亚洲色图第一页| 国产污视频网站| 亚洲资源中文字幕| 波多野结衣一二三四区| 久久久99精品免费观看不卡| 韩国三级丰满少妇高潮| 老司机精品福利视频| mm131午夜| 香蕉精品久久| 国产欧美日韩综合一区在线观看| 电影在线观看一区二区| 欧美一性一乱一交一视频| 密臀av在线| 美女av一区二区三区| 成年人在线观看| 精品视频在线播放| 精品人妻一区二区三区麻豆91| 丰满岳妇乱一区二区三区| 久久亚洲国产成人精品性色| 中文字幕亚洲精品在线观看| 扒开伸进免费视频| 国产激情精品久久久第一区二区 | 亚洲欧美成人综合| 免费看欧美黑人毛片| 欧美a级在线| 一区二区在线不卡| 日韩综合一区| 亚洲精品高清国产一线久久| 在线观看欧美理论a影院| 99国产高清| av成人综合| 国产精品影片在线观看| 精品女同一区二区三区在线观看| 国产成人在线视频| 欧美一区久久久| 国产精品白丝jk喷水视频一区| 激情网站在线| 欧美乱大交xxxxx另类电影| 精品麻豆一区二区三区| 久久亚洲精品中文字幕冲田杏梨 | www在线观看免费视频| 国产精品一级片| 男女视频在线观看网站| 日韩大胆成人| 日韩欧美在线观看视频| 欧美黄色一级网站| 欧美日韩国产精品一区| 亚洲色图日韩精品| 中文字幕一区在线观看视频| www.97视频| 亚洲黄一区二区三区| 日本中文字幕免费观看| 欧美性猛交xxxx乱大交3| 中文字幕手机在线视频| 在线免费一区三区| 在线观看亚洲国产| 欧美日韩不卡一区| 日本高清视频www| 亚洲国产精品人久久电影| 免费av在线电影| 色偷偷偷综合中文字幕;dd| 欧美一级淫片aaaaaa| 伊人一区二区三区久久精品 | 亚洲第一网站男人都懂| 四虎精品成人影院观看地址| 国产亚洲欧洲在线| 视频二区在线| 欧美成人中文字幕在线| 丰乳肥臀在线| 国产精品久久久久久久av大片| 欧美视频免费看| 超碰在线97av| 色综合综合色| 亚洲欧美一二三| 亚洲精品1234| 少妇性饥渴无码a区免费| 狠狠色伊人亚洲综合成人| 免费黄色三级网站| 中文字幕免费不卡| 99久久婷婷国产综合| 午夜在线电影亚洲一区| 99免费在线视频| 亚洲第一精品久久忘忧草社区| 国产精品视频一区二区久久| 久久99久久亚洲国产| 免费在线国产视频| 午夜欧美大片免费观看| 欧洲一区在线| 欧美中日韩一区二区三区| 欧美1区3d| 中文字幕乱码人妻综合二区三区 | 欧美日韩夜夜| 久久天天东北熟女毛茸茸| 久久久精品网| 91日韩视频在线观看| 成人免费观看av| 亚洲精品自产拍| 国内爆初菊对白视频| 中文字幕日韩精品有码视频| 成人爽a毛片免费啪啪动漫| 国产97在线|日韩| 999精品视频在线观看| www 成人av com| 999国产精品视频| 久久国产亚洲精品无码| 蜜桃精品视频在线| 免费a级黄色片| 亚洲人成在线观看一区二区| 国产女主播喷水视频在线观看| 精品国产网站在线观看| 精品视频在线一区二区| 国产精品白丝jk喷水视频一区| 亚洲福利天堂| 久久久性生活视频| 国产成人亚洲精品狼色在线| x88av在线| 一区二区三区影院| 国产女人18毛片水18精| 中文字幕日韩精品在线| 搜成人激情视频| 久久综合狠狠综合久久综青草| 99精品国产福利在线观看免费 | 瑟瑟视频在线观看| 午夜精品免费在线| 99在线观看免费| 国内精品一区二区三区四区| 亚洲精品一二三**| 精品一区二区三区毛片| 国产在线精品不卡| 白丝女仆被免费网站| 一区二区三区四区亚洲| 国产后入清纯学生妹| 欧美另类在线播放| 中文字幕av一区二区三区四区| 亚洲一区二区高清视频| 高潮毛片无遮挡| 国产专区综合网| 国产大屁股喷水视频在线观看| 色呦呦一区二区三区| 精品久久久久中文慕人妻| 久久精品国产亚洲7777| 91精品一区| 国产av人人夜夜澡人人爽麻豆| 丁香婷婷深情五月亚洲| 国产黄色片在线免费观看| 欧美一区二区三区在线观看视频| 国产一区二区三区福利| 2021国产精品视频| 校花撩起jk露出白色内裤国产精品| 精品中文字幕av| 国产午夜亚洲精品不卡| 久久久久在线视频| 在线视频免费一区二区| 日韩另类视频| 国产福利片一区二区| 久久精品国产**网站演员| 久久精品一区二区三区四区五区| 91精品国产福利在线观看| 激情成人四房播| 99久久久精品免费观看国产| 亚洲综合激情在线| 无套内谢大学处破女www小说| 亚洲欧美一区二区三区国产精品 | 99色这里只有精品| 国模少妇一区二区三区| 久久久久亚洲av片无码下载蜜桃| 欧美精品一区二| 666av成人影院在线观看|