当前位置: 首页 > Web前端 > HTML

【JavaScript周报#399】JavaScript引擎基础(上):形态学和内联缓存

时间:2023-03-28 20:01:35 HTML

馃コ娆㈣繋鎰熷叴瓒g殑鏈嬪弸锛屼竴璧锋潵鍋氱偣鏈夋剰涔夌殑浜嬫儏鍚э紒鏈枃璇戣€咃細閬撻亾閲屾垜鎺ㄥ嚭浜嗕竴涓瘡鍛ㄤ竴娆$殑缈昏瘧椤圭洰锛屼粨搴撳湴鍧€锛岃闂湴鍧€杩樻槸寰堢己蹇楀悓閬撳悎鐨勬湅鍙嬶紝绾睘涓汉鍏磋叮锛屽綋鐒跺鎻愰珮鑻辫鍜屽墠绔妧鑳戒篃鏈夊府鍔╋紝瑕佹眰锛氳嫳鏂囪繕涓嶉敊铔í鐨勶紝鐔熺粌浣跨敤github锛屾湁姣呭姏锛岃唉铏氾紝鍋氫簨璐熻矗銆傛兂鍙備笌鐨勬湅鍙嬪彲浠ョ淇x鎴栬€呯粰浠撳簱鍙慽ssue娑堟伅銆傛垜鐨勫崥瀹篃鏈夊叿浣撶殑涓汉鑱旂郴鏂瑰紡锛歞aodaolee.cn鏈枃浠嬬粛浜嗕竴浜汮avaScript寮曟搸閫氱敤鐨勫叧閿熀纭€鐭ヨ瘑鈥斺€斾笉浠呬粎鏄疺8銆備綔涓篔avaScript寮€鍙戜汉鍛橈紝娣卞叆浜嗚ВJavaScript寮曟搸鐨勫伐浣滃師鐞嗗皢鏈夊姪浜庢偍缂栧啓鏇村ソ鐨勪唬鐮併€侸avaScript寮曟搸绠¢亾JavaScript浠g爜鐢辫В鏋愭簮浠g爜骞跺皢鍏惰浆鎹负鎶借薄璇硶鏍?AST)鐨凧avaScript寮曟搸杩愯銆傚熀浜庤繖涓狝ST锛岃В閲婂櫒鎵ц鑷繁鐨勪换鍔″苟鐢熸垚瀛楄妭鐮併€傚搰锛佸紩鎿庡疄闄呬笂姝e湪鎵ц浣犳鏃剁紪鍐欑殑JavaScript浠g爜銆備负浜嗕娇鍏惰繍琛屽緱鏇村揩锛屽彲浠ュ皢瀛楄妭鐮佷笌鏁版嵁鍒嗘瀽涓€璧峰彂閫佸埌浼樺寲缂栬瘧鍣ㄣ€備紭鍖栫紪璇戝櫒鏍规嵁杩欎簺鏁版嵁鍋氬嚭鍐崇瓥锛岀劧鍚庣敓鎴愰珮搴︿紭鍖栫殑鏈哄櫒浠g爜銆傚鏋滃湪鎵ц杩囩▼涓嚭鐜伴棶棰橈紝浼樺寲缂栬瘧鍣ㄥ皢鍙栨秷浼樺寲骞惰繑鍥炵粰瑙i噴鍣ㄣ€侸avaScript寮曟搸涓殑瑙i噴鍣?缂栬瘧鍣ㄧ閬撶幇鍦紝璁╂垜浠湅涓€涓嬬閬撲腑瀹為檯杩愯JavaScript浠g爜鐨勯儴鍒嗭紝涔熷氨鏄唬鐮佽瑙i噴鍜屼紭鍖栫殑鍦版柟銆備竴鑸兘浼氭湁涓€涓敱瑙i噴鍣ㄥ拰浼樺寲缂栬瘧鍣ㄧ粍鎴愮殑娴佹按绾裤€傝В閲婂櫒蹇€熺敓鎴愭湭浼樺寲鐨勫瓧鑺傜爜锛岀劧鍚庝紭鍖栫紪璇戝櫒閫氳繃绋嶉暱鐨勯€昏緫鐢熸垚鏈€缁堥珮搴︿紭鍖栫殑鏈哄櫒鐮併€傝繖鏉$閬撳熀鏈笂灏辨槸V8锛圕hrome鍜孨ode.js涓娇鐢ㄧ殑JavaScript寮曟搸锛夌殑宸ヤ綔鏂瑰紡锛歏8涓殑瑙i噴鍣ㄧО涓篒gnition锛岃礋璐g敓鎴愬拰鎵ц瀛楄妭鐮併€傚綋瀛楄妭鐮佽繍琛屾椂锛屽畠浼氭敹闆嗗垎鏋愭暟鎹紝杩欎簺鏁版嵁鍙敤浜庣◢鍚庡姞閫熸墽琛屻€傚綋涓€涓嚱鏁拌繍琛屾椂锛岀敓鎴愮殑瀛楄妭鐮佸拰鍒嗘瀽鏁版嵁琚紶閫掔粰鎴戜滑鐨勪紭鍖栫紪璇戝櫒TurboFan锛屽畠鏍规嵁鍒嗘瀽鏁版嵁鐢熸垚楂樺害浼樺寲鐨勬満鍣ㄤ唬鐮併€傚湪Firefox鍜孲piderNode涓娇鐢ㄧ殑MozillaJavaScript寮曟搸SpiderMonkey鐨勫仛娉曠暐鏈変笉鍚屻€備粬浠病鏈変竴涓紝鑰屾槸涓や釜浼樺寲缂栬瘧鍣細Baseline缂栬瘧鍣ㄥ拰IonMonkey缂栬瘧鍣ㄣ€傚綋瑙i噴鍣ㄩ拡瀵瑰熀绾跨紪璇戝櫒杩涜浼樺寲鏃讹紝瀹冧細杈撳嚭涓€浜涗紭鍖栧悗鐨勪唬鐮併€傜粨鍚堣繍琛屼唬鐮佹椂鏀堕泦鐨勫垎鏋愭暟鎹紝IonicMonkeyCompiler鍙互鐢熸垚楂樺害浼樺寲鐨勪唬鐮併€傚鏋滀紭鍖栦腑閫斿け璐ワ紝ionicmonkey缂栬瘧鍣ㄥ皢鍥為€€鍒板熀鍑嗕唬鐮併€傚井杞湪Edge鍜孨ode-ChakraCore涓娇鐢ㄧ殑JavaScript寮曟搸Chakra涔熷甫鏈変袱涓紭鍖栫紪璇戝櫒锛氫竴涓畝鍗曠紪璇戝櫒锛圫impleJIT锛夊拰涓€涓畬鏁寸紪璇戝櫒锛團ullJIT锛夈€傝В閲婂櫒浼樺寲涓哄嵆鏃剁紪璇戝櫒鈥斺€斿叾涓璊IT浠h〃鍗虫椂缂栬瘧鍣紝瀹冧細鐢熸垚涓€浜涗紭鍖栫殑浠g爜銆傜劧鍚庣粨鍚堝垎鏋愭暟鎹紝鍏ㄨ韩缂栬瘧鍣ㄥ彲浠ョ敓鎴愭洿浼樺寲鐨勪唬鐮併€侸avaScriptCore(JSC)鏄嫻鏋滃叕鍙稿湪Safari鍜孯eactNative涓娇鐢ㄧ殑JavaScript寮曟搸锛屽畠閫氳繃涓夌涓嶅悓鐨勪紭鍖栫紪璇戝櫒灏嗗叾鍙戞尌鍒颁簡鏋佽嚧锛氫綆绾цВ閲婂櫒锛圠LInt锛宭ow-level-Interprete锛夈€佷紭鍖栧埌鍩虹嚎缂栬瘧鍣紙Baselinecompiler)锛岀劧鍚庝紭鍖栧埌鏁版嵁娴佸浘缂栬瘧鍣紙DFG锛孌ataFlowGraph锛夛紝DFG缂栬瘧鍣ㄥ彲浠ヤ紭鍖栧埌瓒呰交閲忕骇缂栬瘧鍣紙FTL锛孎asterThanLight锛夈€傞偅涓轰粈涔堟湁浜涘巶鍟嗙殑寮曟搸姣斿叾浠栦紭鍖栫紪璇戝櫒澶氬憿锛熷綋鐒讹紝杩欎簺閮芥槸鏉冭 鍙栬垗銆傝В閲婂櫒鍙互蹇€熺敓鎴愬瓧鑺傜爜锛屼絾瀛楄妭鐮佺殑鏁堢巼寰€寰€涓嶆槸寰堥珮銆傚彟涓€鏂归潰锛屼紭鍖栫紪璇戝櫒鐨勬墽琛屾椂闂存洿闀匡紝浣嗘渶缁堜細鐢熸垚鏇撮珮鏁堢殑鏈哄櫒浠g爜銆備竴浜涘紩鎿庝細閫夋嫨娣诲姞澶氫釜鍏锋湁涓嶅悓鏃堕棿/鏁堢巼鐨勪紭鍖栫紪璇戝櫒锛屼互澧炲姞澶嶆潅鎬т负浠d环鏉ユ坊鍔犳洿缁嗙矑搴︾殑鎺у埗銆傛澶栵紝鍐呭瓨涔熸槸鏉冭 寮曟搸鏁伴噺鍜屽伐浣滄祦绋嬫椂瑕佽€冭檻鐨勪竴涓師鍥犮€傜浉鍏虫枃绔犺鐪嬪彟涓€绡囨枃绔狅紙鏈炕璇戯紝缈昏瘧鍚庤创鍑洪摼鎺ワ級銆傚埌鐩墠涓烘锛屾垜浠凡缁忎粙缁嶄簡姣忎釜JavaScript寮曟搸鐨勮В閲婂櫒鍜屼紭鍖栫紪璇戝櫒绠¢亾涔嬮棿鐨勫樊寮傘€傞櫎浜嗚繖浜涘樊寮備箣澶栵紝鍦ㄨ緝楂樺眰娆′笂锛屾墍鏈塉avaScript寮曟搸閮藉叿鏈夌浉鍚岀殑鏋舵瀯锛氭湁涓€涓В鏋愬櫒鍜屾煇绉嶈В閲婂櫒/缂栬瘧鍣ㄧ閬撱€侸avaScript瀵硅薄妯″瀷鏀惧ぇ浜嗕唬鐮佺殑鍐呴儴缁撴瀯锛屼互鏌ョ湅JavaScript寮曟搸杩樻湁鍝簺鍏卞悓鐐广€傚儚杩欎釜闂锛孞avaScript寮曟搸鏄浣曞疄鐜癑avaScript瀵硅薄妯″瀷鐨勶紝瀹冧滑浣跨敤浜嗗摢浜涙妧宸ф潵鍔犻€熻闂甁avaScript瀵硅薄鐨勫睘鎬э紵ECMAScript瑙勮寖鏈川涓婂皢鎵€鏈夊璞″畾涔変负瀛楀吀锛氬瓧绗︿覆閿槧灏勫埌灞炴€у睘鎬с€傞櫎浜哰[Value]]鏈韩锛岃鑼冭繕瀹氫箟浜嗕互涓嬪睘鎬э細[[Writable]]灞炴€ц〃绀烘槸鍚﹀彲浠ラ噸鍐橻[Enumerable]]灞炴€ц〃绀烘槸鍚﹀彲浠ユ灇涓綶[Configurable]]琛ㄧず鏄惁attributecanbedeleted[[xx]]杩欑鍙屾嫭鍙风鍙风湅璧锋潵寰堟椂楂︼紝浣嗗畠纭疄鏄竴绉嶈鑼冿紝琛ㄧず涓嶇洿鎺ユ毚闇茬粰JavaScript鐨勫睘鎬х殑鏂瑰紡銆傛偍鍙互浣跨敤Object.getOwnPropertyDescriptorAPI涓篔avaScript涓殑浠讳綍缁欏畾瀵硅薄鍜屽睘鎬ц幏鍙栬繖浜涘€硷細constobject={foo:42};Object.getOwnPropertyDescriptor(object,'foo');//鈫抺value:42,writable:true,enumerable:true,configurable:true}OK锛丣avaScript灏辨槸杩欐牱瀹氫箟瀵硅薄鐨勶紝閭d箞鏁扮粍鍛紵鎮ㄥ彲浠ュ皢鏁扮粍瑙嗕负瀵硅薄鐨勭壒渚嬨€備竴涓尯鍒槸鏁扮粍瀵规暟缁勭储寮曟湁鐗规畩澶勭悊銆傝繖閲屾墍璇寸殑鏁扮粍绱㈠紩鏄疎CMAScript瑙勮寖涓殑涓€涓壒娈婃湳璇€侸avaScript涓暟缁勭殑闀垮害闄愬埗涓?鲁虏鈭?銆傛暟缁勭殑绱㈠紩鏄繖涓檺鍒跺唴鐨勪换浣曟湁鏁堢储寮曪紝鍗充粠0鍒?鲁虏鈭?鐨勪换浣曟暣鏁般€傚彟涓€涓尯鍒槸鏁扮粍鏈変竴涓暱搴﹀睘鎬э細constarray=['a','b'];array.length;//鈫?array[2]='c';array.length;//鈫?鍦ㄦ湰渚嬩腑锛屽垱寤虹殑鏁扮粍闀垮害涓?銆傜劧鍚庢垜浠皢鍙︿竴涓厓绱犲垎閰嶇粰绱㈠紩2锛岄暱搴︿細鑷姩鏇存柊銆侸avaScript浠ョ被浼间簬瀵硅薄鐨勬柟寮忓畾涔夋暟缁勩€備緥濡傦紝鎵€鏈夐敭锛屽寘鎷暟缁勭储寮曪紝閮芥槑纭〃绀轰负瀛楃涓层€傛暟缁勪腑鐨勭涓€涓厓绱犲瓨鍌ㄥ湪閿€?鈥濅笅銆俵ength灞炴€у彧鏄竴涓伆濂戒笉鍙灇涓句笖涓嶅彲閰嶇疆鐨勫睘鎬с€傚綋鍏冪礌娣诲姞鍒版暟缁勬椂锛孞avaScript浼氳嚜鍔ㄦ洿鏂伴暱搴﹀睘鎬х殑[[Value]]锛氫紭鍖栧睘鎬ц闂埌鐩墠涓烘锛屾垜浠煡閬撲簡瀵硅薄鏄浣曞湪JavaScript涓畾涔夌殑锛岀幇鍦ㄨ鎴戜滑娣卞叆浜嗚ВJavaScript寮曟搸濡備綍鏈夋晥鍦板鐞嗗璞°€傜旱瑙侸avaScript绋嬪簭锛岃闂睘鎬ф槸鏈€甯歌鐨勬搷浣滐紝鍥犳JavaScript寮曟搸蹇€熻闂睘鎬ф槸鑷冲叧閲嶈鐨勩€俢onstobject={foo:'bar',baz:'qux',};//鍦ㄨ繖閲岋紝鎴戜滑姝e湪璁块棶`object`涓婄殑灞炴€foo`:doSomething(object.foo);//^^^^^^^^^^Shape锛堝舰鐘讹級鍦↗avaScript绋嬪簭涓紝澶氫釜瀵硅薄鎷ユ湁鐩稿悓鐨勫睘鎬ч敭鏄緢甯歌鐨勶紝骞朵笖杩欎簺瀵硅薄鍏锋湁鐩稿悓鐨勫舰鐘讹細constobject1={x:1,y:2};constobject2={x:3,y:4};//`object1`鍜宍object2`鐨勯暱搴︾浉鍚屻€傝闂叿鏈夌浉鍚屽舰鐘剁殑瀵硅薄鐨勭浉鍚屽睘鎬т篃寰堝父瑙侊細//^^^^^^^^}constobject1={x:1,y:2};constobject2={x:3,y:4};logX锛堝璞?锛夛紱logX锛堝璞?锛夛紱浠庤繖閲屽彲浠ョ湅鍑猴紝JavaScript寮曟搸鍙互鏍规嵁瀵硅薄鐨勫舰鐘舵潵浼樺寲瀵硅薄灞炴€ц闂紝杩欏氨鏄畠鐨勫伐浣滃師鐞嗐€傚亣璁炬垜浠湁涓€涓叿鏈夊睘鎬鍜寉鐨勫璞★紝瀹冧娇鐢ㄦ垜浠箣鍓嶈璁虹殑瀛楀吀鏁版嵁缁撴瀯锛氬寘鍚綔涓哄瓧绗︿覆鐨勯敭锛屽苟涓旇繖浜涢敭鎸囧悜瀹冧滑鍚勮嚜鐨勫睘鎬э細濡傛灉浣犳兂璁块棶涓€涓睘鎬э紝姣斿object.y锛孞avaScript寮曟搸鍦↗SObject涓煡鎵鹃敭'y'锛屽姞杞界浉搴旂殑灞炴€э紝骞惰繑鍥瀃[Value]]銆備絾鏄繖浜涘睘鎬у瓨鍌ㄥ湪鍐呭瓨涓殑浠€涔堝湴鏂瑰憿锛熸垜浠簲璇ュ皢瀹冧滑瀛樺偍涓篔SObject鐨勪竴閮ㄥ垎鍚楋紵濡傛灉鎴戜滑灏嗘潵瑕佺粡甯哥湅鍒拌繖绉嶇粨鏋勭殑瀵硅薄锛岄偅涔堝皢杩欑瀹屾暣鐨勫瓧鍏告牸寮忓瓨鍌ㄥ湪JSObject涓婂皢鏄竴绉嶆氮璐癸紝鍥犱负瀵逛簬鍏锋湁鐩稿悓褰㈢姸鐨勬墍鏈夊璞★紝灞炴€у悕绉伴兘浼氶噸澶嶏紒杩欎細瀵艰嚧澶ч噺閲嶅鍜屼笉蹇呰鐨勫唴瀛樹娇鐢ㄣ€傛鏃讹紝鏈変竴涓紭鍖栨柟妗堬細寮曟搸鍗曠嫭瀛樺偍鐗╀綋鐨勫舰鐘躲€傚紩鎿庡寘鎷墍鏈夊睘鎬у悕绉板拰灞炴€у€硷紝闄や簡瀹冧滑鐨刐[Value]]銆係hape鍖呭惈JSObject鍐呴儴鍊肩殑鍋忕Щ閲忥紝浠ヤ究JavaScript寮曟搸鐭ラ亾鍦ㄥ摢閲屽彲浠ユ壘鍒拌繖浜涘€笺€傛瘡涓叿鏈夌浉鍚屽舰鐘剁殑JSObject閮芥寚鍚戣繖涓猄hape瀹炰緥銆傜幇鍦ㄦ瘡涓狫SObject鍙渶瑕佸瓨鍌ㄥ璞$殑鍞竴鍊笺€傚綋鎴戜滑鏈夊涓璞℃椂锛岃繖绉嶆柟娉曞緢鏈夋晥銆備笉绠℃湁澶氬皯鐗╀綋锛屽彧瑕佸畠浠殑褰㈢姸鐩稿悓锛屾垜浠彧闇€瑕佸瓨鍌ㄤ竴娆″舰鐘跺拰灞炴€т俊鎭紒鎵€鏈塉avaScript寮曟搸閮戒娇鐢⊿hapes浣滀负浼樺寲锛屼絾瀹冧滑骞朵笉閮界О瀹冧滑涓哄舰鐘讹細瀛︽湳璁烘枃绉板畠浠负闅愯棌绫伙紙娣锋穯w.r.t.JavaScript绫伙級V8绉板畠浠负Maps锛堟贩娣唚.r.t.JavaScript鍦板浘锛塁hakra绉板畠浠负绫诲瀷锛堟贩娣唚.r.t.JavaScript鐨勫姩鎬乼yping鍜宼ypeof)JavaScriptCore绉板畠浠负structsSpiderMonkey绉板畠浠负morphs鍦ㄦ湰鏂囦腑鎴戜滑灏嗙户缁娇鐢ㄦ湳璇€攎orphs銆傝浆鎹㈤摼鍜屾爲濡傛灉鎮ㄦ湁涓€涓叿鏈夌壒瀹氬舰鐘剁殑瀵硅薄锛岀劧鍚庡悜鍏舵坊鍔犱竴涓睘鎬э紝浼氬彂鐢熶粈涔堟儏鍐碉紵JavaScript寮曟搸濡備綍鎵惧埌鏂扮殑褰㈢姸锛熷父閲忓璞?{};瀵硅薄.x=5;瀵硅薄.y=6;杩欎簺褰㈢姸鍦↗avaScript寮曟搸涓舰鎴愪簡涓€涓墍璋撶殑杞崲閾撅紝璇风湅涓嬮潰鐨勪緥瀛愶細瀵硅薄鏈€鍒濇病鏈夊睘鎬э紝鎵€浠ュ畠鎸囧悜涓€涓┖鐨凷hape銆備互涓嬭鍙ュ皢鍊间负5鐨勫睘鎬р€渪鈥濇坊鍔犲埌姝ゅ璞★紝鍥犳JavaScript寮曟搸灏嗚浆鎹负鍖呭惈灞炴€р€渪鈥濈殑Shape锛屽苟灏嗗€?娣诲姞鍒扮涓€涓亸绉婚噺0澶勭殑JSObject銆傛帴涓嬫潵锛屼笅涓€琛屾坊鍔犲睘鎬р€測鈥濓紝寮曟搸鍒囨崲鍒板彟涓€涓寘鍚€渪鈥濆拰鈥測鈥濈殑Shape锛屽苟灏嗗€?闄勫姞鍒癑SObject锛堝亸绉婚噺1锛夈€傛敞鎰忥細娣诲姞灞炴€х殑椤哄簭浼氬奖鍝嶅舰鐘躲€備緥濡傦紝{x:4,y:5}浜х敓鐨勫舰鐘朵笌{y:5,x:4}涓嶅悓銆傛垜浠笉闇€瑕佷负姣忎釜Shape瀛樺偍瀹屾暣鐨勫睘鎬ц〃銆傜浉鍙嶏紝姣忎釜Shape鍙渶瑕佺煡閬撳畠寮曞叆鐨勬柊灞炴€с€備緥濡傦紝鍦ㄨ繖绉嶆儏鍐典笅锛屾垜浠笉蹇呭湪鏈€鍚庝竴涓猄hape涓瓨鍌ㄦ湁鍏斥€渪鈥濈殑淇℃伅锛屽洜涓哄畠鍙互鍦ㄩ摼鐨勫ご閮ㄦ壘鍒般€備负浜嗘纭В鏋愶紝姣忎釜Shape閮介摼鎺ュ洖鍏跺厛鍓嶇殑褰㈢姸锛氬鏋滄偍鍦↗avaScript浠g爜涓紪鍐檕.x锛孞avaScript寮曟搸浼氶€氳繃閬嶅巻杞崲閾炬潵鏌ユ壘灞炴€р€渪鈥濓紝鐩村埌鎵惧埌寮曞叆灞炴€р€渪鈥濈殑Shape銆傞偅涔堬紝濡傛灉鏃犳硶鍒涘缓杞崲閾句細鎬庢牱锛熶緥濡傦紝濡傛灉鎮ㄦ湁涓や釜绌哄璞★紝骞朵负姣忎釜瀵硅薄娣诲姞涓嶅悓鐨勫睘鎬т細鎬庢牱锛焎onstobject1={};object1.x=5;constobject2={};object2.y=6;鍦ㄨ繖绉嶆儏鍐典笅锛屾垜浠繀椤讳娇鐢ㄥ垎鏀€屼笉鏄摼鏉ユ渶缁堝緱鍒颁竴涓浆鎹㈡爲锛氬涓婃墍绀猴紝鎴戜滑鍒涘缓涓€涓┖瀵硅薄a锛岀劧鍚庝负鍏舵坊鍔犱竴涓睘鎬р€渪鈥濄€傛垜浠渶缁堝緱鍒颁竴涓寘鍚崟涓€煎拰涓や釜褰㈢姸鐨凧SObject锛氫竴涓┖褰㈢姸鍜屼竴涓彧鏈夊睘鎬鐨勫舰鐘躲€傜浜屼釜绀轰緥涔熶互涓€涓┖瀵硅薄b寮€濮嬶紝鐒跺悗娣诲姞涓€涓笉鍚岀殑灞炴€р€測鈥濄€傛垜浠渶缁堝緱鍒颁袱涓猄hape閾撅紝鎬诲叡涓変釜Shapes銆傝繖鏄惁鎰忓懗鐫€鎴戜滑蹇呴』浠庝竴涓┖鐨凷hape寮€濮嬫墽琛岋紵涓嶃€傚紩鎿庡宸茬粡鍖呭惈灞炴€х殑瀵硅薄搴旂敤涓€浜涗紭鍖栥€傝鍙傞槄姝ょず渚嬶紝璇ョず渚嬩粠绌哄璞″瓧闈㈤噺娣诲姞x骞跺叿鏈夊凡鍖呭惈x鐨勫璞″瓧闈㈤噺锛歝onstobject1={};瀵硅薄1.x=5锛沜onstobject2={x:6};鍦╫bject1涓紝鎴戜滑浠庝竴涓┖鐨凷hape寮€濮嬶紝瀵逛竴涓寘鍚玿鐨凷hape杩涜杞崲锛屽湪object2涓紝鐩存帴鐢熸垚涓€涓竴寮€濮嬪氨宸茬粡鏈墄鐨勫璞°€傚寘鍚睘鎬р€渪鈥濈殑瀵硅薄鏂囧瓧浠庡寘鍚€渪鈥濈殑Shape寮€濮嬫墽琛岋紝璺宠繃绌篠hape锛佽繖灏辨槸V8鍜孲piderMonkey鎵€鍋氱殑銆傝繖绉嶄紭鍖栫缉鐭簡杞崲閾惧苟鎻愰珮浜嗘瀯寤哄璞$殑鏁堢巼銆備互涓嬫槸鍏锋湁鈥渪鈥濄€佲€測鈥濆拰鈥渮鈥濆睘鎬х殑3D鐐瑰璞$ず渚嬶細constpoint={};point.x=4;point.y=5;point.z=6;姝e鎴戜滑鎵€鐭ワ紝杩欎細鍦ㄥ唴瀛樹腑鍒涘缓涓€涓璞★紝鍏朵腑鍖呭惈3涓猄hapes锛堥櫎浜嗙┖Shape锛夈€傚鏋滄偍鍦ㄧ▼搴忎腑缂栧啓point.x锛孞avaScript寮曟搸灏嗛伒寰摼琛細浠庡簳閮ㄧ殑Shape寮€濮嬶紝鍒伴《閮ㄥ紩鍏モ€渪鈥濈殑Shape缁撴潫銆傚鏋滄垜浠粡甯歌繖鏍峰仛锛屾晥鐜囦細寰堟參锛屽挨鍏舵槸褰撳璞℃湁寰堝灞炴€ф椂銆傛壘鍒颁竴涓睘鎬х殑鏃堕棿鏄疧(n)锛屽嵆涓€涓璞″湪灞炴€ф暟閲忎笂鏄嚎鎬х殑銆備负浜嗗姞蹇睘鎬ф悳绱紝JavaScript寮曟搸娣诲姞浜嗕竴涓猄hapeTable鏁版嵁缁撴瀯銆傛ShapeTable鏄竴涓瓧鍏革紝灏嗗睘鎬ч敭鏄犲皠鍒板紩鍏ョ粰瀹氬睘鎬х殑鍚勪釜褰㈢姸銆傜幇鍦紝鎴戜滑鍥炲埌浜嗗瓧鍏告煡鎵撅紝杩欐槸鎴戜滑寮€濮嬫坊鍔犲舰鐘朵箣鍓嶇殑浣嶇疆锛佹樉鐒惰鏌ユ壘寰堝寰堝娆★紒杩欎釜鏃跺€欐€庝箞鍔烇紵Shape鍚敤浜嗗彟涓€绉嶇О涓哄唴鑱旂紦瀛樼殑浼樺寲銆傚唴鑱旂紦瀛橈紙IC锛夊舰鐘惰儗鍚庣殑涓昏閫昏緫鏄唴鑱旂紦瀛橈紙IC锛夈€侷C鏄JavaScript璺戝緱蹇殑鍏抽敭锛丣avaScript寮曟搸浣跨敤IC鏉ヨ浣忔湁鍏冲湪浣曞鏌ユ壘瀵硅薄灞炴€х殑淇℃伅锛屼互鍑忓皯鏄傝吹鐨勬煡鎵炬鏁般€傝繖鏄竴涓猤etX鍑芥暟锛屽畠鎺ュ彈涓€涓璞″弬鏁板苟浠庝腑鍔犺浇灞炴€锛歠unctiongetX(o){returno.x;}濡傛灉鎴戜滑鍦↗SC涓繍琛岃繖涓嚱鏁帮紝瀹冧細鐢熸垚浠ヤ笅瀛楄妭鐮侊細(arg1)鍔犺浇灞炴€р€渪鈥濆苟灏嗙粨鏋滃瓨鍌ㄥ湪loc0涓€傜浜屾潯鎸囦护杩斿洖鎴戜滑瀛樺偍鍒發oc0鐨勫唴瀹广€侸SC杩樺湪get_by_id鎸囦护涓祵鍏ヤ簡涓€涓唴鑱旂紦瀛橈紝瀹冪敱涓や釜鏈垵濮嬪寲鐨勬Ы缁勬垚锛氱幇鍦ㄥ亣璁炬垜浠皢涓€涓璞x:'a'}浼犻€掔粰getX銆傛濡傛垜浠墍鐭ワ紝杩欎釜瀵硅薄鏈変竴涓甫鏈夊睘鎬р€渪鈥濈殑Shape锛岃€岄偅涓猄hape瀛樺偍浜嗛偅涓睘鎬鐨勫亸绉婚噺鍜屽睘鎬с€傜涓€娆℃墽琛岃鍑芥暟鏃讹紝get_by_id鎸囦护鏌ユ壘灞炴€?x'锛屽彂鐜拌鍊煎瓨鍌ㄥ湪鍋忕Щ閲?澶勶細get_by_id鎸囦护涓祵鍏ョ殑IC璁颁綇鎵惧埌璇ュ睘鎬х殑褰㈢姸鍜屽亸绉婚噺锛氱敤浜庡悗缁繍琛屾椂锛孖C鍙渶瑕佹瘮杈僑hape灏卞彲浠ヤ簡锛屽鏋滃拰涔嬪墠涓€鏍凤紝灏变粠鍐呭瓨鐨刼ffset涓姞杞藉€笺€傚叿浣撴潵璇达紝濡傛灉JavaScript寮曟搸鐪嬪埌涓€涓璞″叿鏈塈C鍏堝墠璁板綍鐨凷hape锛屽畠灏变笉鍐嶉渶瑕佽闂睘鎬т俊鎭€斺€旂浉鍙嶏紝鍙互瀹屽叏璺宠繃鏄傝吹鐨勫睘鎬т俊鎭煡鎵俱€傝繖姣旀瘡娆℃煡鎵惧睘鎬ц蹇緱澶氥€傞珮鏁堝湴瀛樺偍鏁扮粍瀵逛簬鏁扮粍锛岄€氬父浼氬皢浣滀负绱㈠紩鐨勫睘鎬у瓨鍌ㄥ埌鏁扮粍涓紝鑰屾绫诲睘鎬х殑鍊肩О涓烘暟缁勫厓绱犮€傚湪姣忎釜鏁扮粍涓瓨鍌ㄦ瘡涓暟缁勫厓绱犵殑灞炴€т細娴垂鍐呭瓨銆傜浉鍙嶏紝JavaScript寮曟搸浣跨敤鏁扮粍绱㈠紩灞炴€ф搷浣滐紙褰撳彲鍐欍€佸彲鏋氫妇鍜屽彲閰嶇疆鏃讹級骞跺皢鏁扮粍鍏冪礌涓庡叾浠栧懡鍚嶅睘鎬у垎寮€瀛樺偍銆傛垜浠潵鐪嬭繖涓緥瀛愶細constarray=['#jsconfeu',];寮曟搸瀛樺偍涓€涓暱搴︿负1鐨勬暟缁勶紝骞舵寚鍚戜竴涓叿鏈夊亸绉婚噺鍜屸€滈暱搴︹€濆睘鎬х殑Shape銆傝繖涓庢垜浠箣鍓嶇湅鍒扮殑缁撴瀯闈炲父鐩镐技锛屼絾鏄暟缁勫€煎瓨鍌ㄥ湪鍝噷鍛紵姣忎釜鏁扮粍閮芥湁涓€涓崟鐙殑鍏冪礌鍚庡瀛樺偍锛屽叾涓寘鍚墍鏈夋暟缁勭储寮曠殑灞炴€у€笺€侸avaScript寮曟搸涓嶅繀涓烘暟缁勫厓绱犲瓨鍌ㄤ换浣曞睘鎬э紝鍥犱负瀹冧滑閫氬父鏄彲鍐欍€佸彲鏋氫妇鍜屽彲閰嶇疆鐨勩€備絾鏄湪寮傚父鎯呭喌涓嬩細鍙戠敓浠€涔堬紵濡傛灉鏇存敼鏁扮粍鍏冪礌鐨刟ttribute灞炴€ф€庝箞鍔烇紵//姘歌繙涓嶈杩欐牱鍋氾紒constarray=Object.defineProperty([],'0',{value:'鍝︿笉!!1',鍙啓:false,鍙灇涓?false,鍙厤缃?false,});涓婇潰鐨勪唬鐮佺墖娈靛畾涔変簡涓€涓悕涓衡€?鈥濈殑灞炴€э紙鎭板ソ鏄竴涓暟缁勭储寮曪級锛屼絾灏嗗叾灞炴€ц缃负闈為粯璁ゅ€笺€傚湪杩欑杈圭紭鎯呭喌涓嬶紝JavaScript寮曟搸灏嗘暣涓悗澶囧瓨鍌ㄥ厓绱犺〃绀轰负瀛楀吀鏄犲皠鏁扮粍绱㈠紩鍒板睘鎬у睘鎬с€傚嵆浣垮彧鏈変竴涓暟缁勫厓绱犲叿鏈夐潪榛樿灞炴€э紝鏁翠釜鏁扮粍鐨勫悗澶囧瓨鍌ㄤ篃浼氳繘鍏ヨ繖绉嶇紦鎱笖浣庢晥鐨勬ā寮忋€傝鍔″繀閬垮厤鍦ㄦ暟缁勭储寮曚笂浣跨敤Object.defineProperty锛佹渶鍚庯紝鎴戜滑浜嗚В浜咼avaScript寮曟搸濡備綍瀛樺偍瀵硅薄鍜屾暟缁勶紝浠ュ強褰㈢姸鍜孖C濡備綍甯姪浼樺寲瀹冧滑鐨勫父瑙佹搷浣溿€傚熀浜庤繖浜涚煡璇嗭紝鎴戜滑纭畾浜嗕竴浜涙湁鍔╀簬鎻愰珮鎬ц兘鐨勬湁鐢↗avaScript缂栫爜鎶€宸э細濮嬬粓浠ョ浉鍚岀殑鏂瑰紡鍒濆鍖栨偍鐨勫璞★紝瀹冧滑涓嶄細浠ヤ笉鍚岀殑褰㈢姸缁撴潫銆備笉瑕佸紕涔辨暟缁勫厓绱犵殑灞炴€с€傜浉鍏宠祫鏂橨avaScriptenginefundamentals:ShapesandInlineCaches缈昏瘧璁″垝鍘熸枃