1.C#中关于字典(Dictionary)的使用
2.单片机c源码中uchar temp,key其中的key是什么意思
3.vueä¸keyçåç
C#中关于字典(Dictionary)的使用
常用的取值方法有2种:
方法1:先判断是否存在,如果存在再进行取值
if(aDictionary.ContainsKey(key)) { var value = Dictionary[key]; }
方法2:使用 TryGetValue
int value; aDictionary.TryGetValue(key, out value);
项目中,如果只是要取值,推荐使用TryGetValue来获取。
原因:
方法1中ContainsKey执行了一次方法,同花顺 涨速 指标源码Dictionary[key]再次执行了一次方法,账无忧源码整个取值过程调用了2次方法。而方法2的TryGetValue只调用了一次方法。当然并不是调用的方法越多越耗性能,看源码后就能理解。
下面看看具体的源码
方法1:
方法2:
通过源码可以看到,这几个方法都获取值都要通过FindEntry(key)来实现
可以看出通过key来获取HashCode,然后通过equal比对值,字典存储中会给key一个对应的源码熊教程hashcode,如果数据过多,那么hashCode也可能重复,所以需要进行比较。时间主要花费在这上面。鱼胶溯源码
那么结论显而易见,如果只是取值,直接用TryGetValue花费更小,更快速,微友源码更安全,找不到value时返回false;
在通过一个测试代码来验证时间的花费:
查找不存在的值时花费时间几乎相同
查找的值存在时,可以看出时间接近2倍
另外在提一下关于Keys的,因为在字典中键值对是成对存储的,使用keys会单独拿出所有的key来组成一个关于Key的数组,会产生额外的CG,如果不是要单独对keys进行处理,推荐少用这个。
用Unity自带的Profile来进行测试
调用Keys方法时
未调用Keys方法
单片机c源码中uchar temp,key其中的key是什么意思
根据电路的排布,temp和key分别代表行和列,行、列都确定后,就可以定位是那个按键响应了~
按键按下后,都会进入key4x4()的函数,先用temp来区分出是哪一行(列),再用key来区分具体为那一列(行),从而确定动作按键的具体位置;
vueä¸keyçåç
ä¸ãKeyæ¯ä»ä¹
å¼å§ä¹åï¼æ们å è¿å两个å®é å·¥ä½åºæ¯
å½æ们å¨ä½¿ç¨v-foræ¶ï¼éè¦ç»åå å ä¸key
<ul><liv-for="iteminitems":key="item.id">...</li></ul>ç¨+newDate()çæçæ¶é´æ³ä½ä¸ºkeyï¼æå¨å¼ºå¶è§¦åéæ°æ¸²æ
<Comp:key="+newDate()"/>é£ä¹è¿èåçé»è¾æ¯ä»ä¹ï¼keyçä½ç¨åæ¯ä»ä¹ï¼ä¸å¥è¯æ¥è®²keyæ¯ç»æ¯ä¸ä¸ªvnodeçå¯ä¸idï¼ä¹æ¯diffçä¸ç§ä¼åçç¥ï¼å¯ä»¥æ ¹æ®keyï¼æ´åç¡®ï¼æ´å¿«çæ¾å°å¯¹åºçvnodeèç¹
åºæ¯èåçé»è¾å½æ们å¨ä½¿ç¨v-foræ¶ï¼éè¦ç»åå å ä¸key
å¦æä¸ç¨keyï¼Vueä¼éç¨å°±å°å¤å°ååï¼æå°åelementç移å¨ï¼å¹¶ä¸ä¼å°è¯å°½æ大ç¨åº¦å¨åéå½çå°æ¹å¯¹ç¸åç±»åçelementï¼åpatchæè reuseã
å¦æ使ç¨äºkeyï¼Vueä¼æ ¹æ®keysç顺åºè®°å½elementï¼æ¾ç»æ¥æäºkeyçelementå¦æä¸ååºç°çè¯ï¼ä¼è¢«ç´æ¥removeæè destoryedç¨+newDate()çæçæ¶é´æ³ä½ä¸ºkeyï¼æå¨å¼ºå¶è§¦åéæ°æ¸²æ
å½æ¥ææ°å¼çrerenderä½ä¸ºkeyæ¶ï¼æ¥æäºæ°keyçCompåºç°äºï¼é£ä¹æ§keyCompä¼è¢«ç§»é¤ï¼æ°keyComp触å渲æ
äºã设置keyä¸ä¸è®¾ç½®keyåºå«ä¸¾ä¸ªä¾åï¼å建ä¸ä¸ªå®ä¾ï¼2ç§åå¾itemsæ°ç»æå ¥æ°æ®
<body><divid="demo"><pv-for="iteminitems":key="item">{ { item}}</p></div><scriptsrc="../../dist/vue.js"></script><script>//å建å®ä¾constapp=newVue({ el:'#demo',data:{ items:['a','b','c','d','e']},mounted(){ setTimeout(()=>{ this.items.splice(2,0,'f')//},);},});</script></body>å¨ä¸ä½¿ç¨keyçæ åµï¼vueä¼è¿è¡è¿æ ·çæä½ï¼
åæä¸æ´ä½æµç¨ï¼
æ¯è¾Aï¼Aï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾Bï¼Bï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾Cï¼Fï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼æ°æ®ä¸åï¼åçdomæä½
æ¯è¾Dï¼Cï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼æ°æ®ä¸åï¼åçdomæä½
æ¯è¾Eï¼Dï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼æ°æ®ä¸åï¼åçdomæä½
循ç¯ç»æï¼å°Eæå ¥å°DOMä¸ä¸å ±åçäº3次æ´æ°ï¼1次æå ¥æä½
å¨ä½¿ç¨keyçæ åµï¼vueä¼è¿è¡è¿æ ·çæä½ï¼
æ¯è¾Aï¼Aï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾Bï¼Bï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾Cï¼Fï¼ä¸ç¸åç±»åçèç¹
æ¯è¾EãEï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾DãDï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
æ¯è¾CãCï¼ç¸åç±»åçèç¹ï¼è¿è¡patchï¼ä½æ°æ®ç¸åï¼ä¸åçdomæä½
循ç¯ç»æï¼å°Fæå ¥å°Cä¹åä¸å ±åçäº0次æ´æ°ï¼1次æå ¥æä½éè¿ä¸é¢ä¸¤ä¸ªå°ä¾åï¼å¯è§è®¾ç½®keyè½å¤å¤§å¤§åå°å¯¹é¡µé¢çDOMæä½ï¼æé«äºdiffæç
设置keyå¼ä¸å®è½æé«diffæçåï¼å ¶å®ä¸ç¶ï¼ææ¡£ä¸ä¹æ确表示å½Vue.jsç¨v-foræ£å¨æ´æ°å·²æ¸²æè¿çå ç´ å表æ¶ï¼å®é»è®¤ç¨âå°±å°å¤ç¨âçç¥ãå¦ææ°æ®é¡¹ç顺åºè¢«æ¹åï¼Vueå°ä¸ä¼ç§»å¨DOMå ç´ æ¥å¹é æ°æ®é¡¹ç顺åºï¼èæ¯ç®åå¤ç¨æ¤å¤æ¯ä¸ªå ç´ ï¼å¹¶ä¸ç¡®ä¿å®å¨ç¹å®ç´¢å¼ä¸æ¾ç¤ºå·²è¢«æ¸²æè¿çæ¯ä¸ªå ç´ è¿ä¸ªé»è®¤ç模å¼æ¯é«æçï¼ä½æ¯åªéç¨äºä¸ä¾èµåç»ä»¶ç¶ææ临æ¶DOMç¶æ(ä¾å¦ï¼è¡¨åè¾å ¥å¼)çå表渲æè¾åºå»ºè®®å°½å¯è½å¨ä½¿ç¨?v-for?æ¶æä¾?keyï¼é¤ééåè¾åºçDOMå 容é常ç®åï¼æè æ¯å»æä¾èµé»è®¤è¡ä¸ºä»¥è·åæ§è½ä¸çæå
ä¸ãåçåææºç ä½ç½®ï¼core/vdom/patch.jséå¤ææ¯å¦ä¸ºåä¸ä¸ªkeyï¼é¦å å¤æçæ¯keyå¼æ¯å¦ç¸çå¦æ没æ设置keyï¼é£ä¹key为undefinedï¼è¿æ¶åundefinedæ¯æçäºundefined
functionsameVnode(a,b){ return(a.key===b.key&&((a.tag===b.tag&&a.isComment===b.isComment&&isDef(a.data)===isDef(b.data)&&sameInputType(a,b))||(isTrue(a.isAsyncPlaceholder)&&a.asyncFactory===b.asyncFactory&&isUndef(b.asyncFactory.error))))}updateChildrenæ¹æ³ä¸ä¼å¯¹æ°æ§vnodeè¿è¡diffï¼ç¶åå°æ¯å¯¹åºçç»æç¨æ¥æ´æ°çå®çDOM
functionupdateChildren(parentElm,oldCh,newCh,insertedVnodeQueue,removeOnly){ ...while(oldStartIdx<=oldEndIdx&&newStartIdx<=newEndIdx){ if(isUndef(oldStartVnode)){ ...}elseif(isUndef(oldEndVnode)){ ...}elseif(sameVnode(oldStartVnode,newStartVnode)){ ...}elseif(sameVnode(oldEndVnode,newEndVnode)){ ...}elseif(sameVnode(oldStartVnode,newEndVnode)){ //Vnodemovedright...}elseif(sameVnode(oldEndVnode,newStartVnode)){ //Vnodemovedleft...}else{ if(isUndef(oldKeyToIdx))oldKeyToIdx=createKeyToOldIdx(oldCh,oldStartIdx,oldEndIdx)idxInOld=isDef(newStartVnode.key)?oldKeyToIdx[newStartVnode.key]:findIdxInOld(newStartVnode,oldCh,oldStartIdx,oldEndIdx)if(isUndef(idxInOld)){ //NewelementcreateElm(newStartVnode,insertedVnodeQueue,parentElm,oldStartVnode.elm,false,newCh,newStartIdx)}else{ vnodeToMove=oldCh[idxInOld]if(sameVnode(vnodeToMove,newStartVnode)){ patchVnode(vnodeToMove,newStartVnode,insertedVnodeQueue,newCh,newStartIdx)oldCh[idxInOld]=undefinedcanMove&&nodeOps.insertBefore(parentElm,vnodeToMove.elm,oldStartVnode.elm)}else{ //samekeybutdifferentelement.treatasnewelementcreateElm(newStartVnode,insertedVnodeQueue,parentElm,oldStartVnode.elm,false,newCh,newStartIdx)}}newStartVnode=newCh[++newStartIdx]}}...}åæï¼/post/2024-11-26 15:25
2024-11-26 15:20
2024-11-26 14:24
2024-11-26 14:06
2024-11-26 13:25
2024-11-26 13:18