0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

分享對OMCI模塊進行重構(gòu)時的實踐經(jīng)驗

工程師鄧生 ? 來源:博客園 ? 作者:clover_toeic ? 2022-09-15 16:45 ? 次閱讀

本文分享對該模塊進行重構(gòu)時的實踐經(jīng)驗, 具體的重構(gòu)手段可參考《代碼大全2》或《重構(gòu):改善既有代碼的設(shè)計》,本文不再班門弄斧,而側(cè)重重構(gòu)時一些粗淺的“方法論”,旨在提高重構(gòu)效率。

小編未采用重量級的重構(gòu)工具,僅用到Source Insight的”Smart Rename”功能。也未使用CUnit等單元測試工具,而是通過在線調(diào)測和自動化測試保證代碼的正確性。

一 背景

MDU系列產(chǎn)品從他處接手,OMCI模塊相關(guān)人員含作者在內(nèi)不過三五人。除新增功能的開發(fā)外,大量時間花費在處理遺留故障上。但該模塊代碼龐雜且可讀性差,導(dǎo)致大家僅了解其“大概輪廓”,難以放心地使用和維護。

此外,忙碌容易使人迷失方向。主要的時間精力花費在故障處理上時,自然無暇考慮整改代碼,從而陷入四處救火、疲于奔命的尷尬境地。

二 目標

重構(gòu)的主要目的在于改善既有代碼的設(shè)計,而不是修改缺陷、新增功能等。

重構(gòu)可以是修改變量名、重新安排目錄這樣簡單的物理重構(gòu),也可以是抽取子函數(shù)、精簡冗余設(shè)計這樣稍許復(fù)雜的邏輯重構(gòu)。但均不改變現(xiàn)有代碼的功能。

重構(gòu)可以將意大利面條式的雜亂代碼整理為千層餅式的整潔代碼。整潔的代碼更加健壯,因其便于建立完善的測試防護網(wǎng)。同時,新手老人均可放心地修改。

期望重構(gòu)之后,代碼邏輯一目了然,擴展和修改非常方便,出現(xiàn)故障時能迅速定位和修復(fù)。前人摔跤過的地方后人不再栽倒,前人思考出的成果后人可直接借用??傊?,高度人性化,極大解放人力和腦力。

最初的想法是,通過重構(gòu)部分流程和代碼(代碼先行),建立測試防護體系,生成階段報告,展現(xiàn)代碼質(zhì)量(實例加數(shù)據(jù))和故障收斂曲線。借助這樣的報告,可望獲得領(lǐng)導(dǎo)層的支持和宣貫,也有利于績效考核。

三 實踐

具體實踐時,作者并未進行純粹的“重構(gòu)”,還兼做缺陷修改,并增加自動化測試等輔助功能。原則上,對既有代碼注重重構(gòu),對新增代碼注重復(fù)用。

3.1 代碼研讀

OMCI模塊代碼龐雜,分支眾多,上手困難(據(jù)稱半年勉強入門,一年才能熟練)。若不能有效掌握現(xiàn)有代碼,后續(xù)難免被迫付出時間健康而又得不到項目認同(事實上,模塊內(nèi)發(fā)現(xiàn)的遺留故障源源不斷)。反之,若能全面掌握現(xiàn)有代碼,后續(xù)才可能通過反向工程、系統(tǒng)/代碼恢復(fù)和重構(gòu)等手段,將模塊改造得更易開發(fā)和維護,最終解放編碼者自己。

為提高代碼研讀效率,可采用分工閱讀和代碼注釋的方法。

分工閱讀”是指將模塊分為若干塊子功能(如協(xié)議解析、告警、統(tǒng)計、二層、語音等),組內(nèi)每人負責(zé)一塊或幾塊,不定期地交流和輪值。

代碼注釋”是指在學(xué)習(xí)代碼過程中,隨手注釋代碼(大至流程、函數(shù),小至代碼行),功能、意圖、技巧、缺陷、疑問等均可(凡經(jīng)過思考的地方都是可加注釋之處)。其中“疑問”既可咨詢兄弟產(chǎn)品同一模塊的同事再轉(zhuǎn)換為功能或意圖,也可由其他注釋者解答。

這樣做的好處是:避免重復(fù)鉆研;經(jīng)驗積累;可供量化。

代碼可取產(chǎn)品最新版本,建立服務(wù)器公共代碼目錄(SVN管理更好)。注釋時不要覆蓋其他人的注釋即可。

建議注釋統(tǒng)一格式,便于識別和檢索,形如”//>”。以下示出一個代碼注釋實例:

1caseOMCI_ME_ATTRIBUTE_2://Operationalstate
2if(attr.attr.ucOperationState!=0&&attr.attr.ucAdminState!=1)//xywang0618>BUG:shouldbeucOperationState!
3{
4returnOMCI_FUNC_RETURN_OUT_OF_RANGE;
5}
6break;

3.2 可讀性

首先,規(guī)范變量、函數(shù)等命名。具體方法不再贅述。

其次,注釋到位,尤其是全局變量和通用函數(shù)。舉例如下:

1/******************************************************************************
2*函數(shù)名稱:ByteArray2StrSeq
3*功能說明:掩碼字節(jié)數(shù)組字符串化
4該數(shù)組元素為掩碼字節(jié),將其所有值為1的比特位置轉(zhuǎn)換為指定格式的字符串
5*輸入參數(shù):pucByteArray:掩碼字節(jié)數(shù)組
6ucByteNum:掩碼字節(jié)數(shù)組待轉(zhuǎn)換的有效字節(jié)數(shù)目
7ucBaseVal:掩碼字符串起始字節(jié)對應(yīng)的數(shù)值
8 *輸出參數(shù): pStrSeq :掩碼字符串,以','、'-'間隔
9形如0xD7(0b'11010111)--->"0-1,3,5-7"
10*返回值: pStr :pStrSeq的指針備份,可用于strlen等鏈式表達式
11*用法示例:INT8UaucByteArray[8]={0xD7,0x8F,0xF5,0x73};
12CHARszSeq[64]={0};
13ByteArray2StrSeq(aucByteArray,4,0,szSeq);
14---->"0-1,3,5-8,12-19,21,23,25-27,30-31"
15memset(szSeq,0,sizeof(szSeq));
16ByteArray2StrSeq(aucByteArray,4,1,szSeq);
17---->"1-2,4,6-9,13-20,22,24,26-28,31-32"
18*注意事項:因本函數(shù)內(nèi)含strcat,故調(diào)用前應(yīng)按需初始化pStrSeq
19******************************************************************************/
20CHAR*ByteArray2StrSeq(INT8U*pucByteArray,INT8UucByteNum,INT8UucBaseVal,CHAR*pStrSeq);

最后,整改晦澀難懂的代碼。主要有兩種手段:

1) 改寫方法

以PON光路檢測為例,底層接口提供的光功率單位為0.1uW,OMCI協(xié)議Test消息上報的光功率單位為0.002dBuW,而Ani-G功率屬性單位則為0.002dBmW。

原有代碼轉(zhuǎn)換如下(為突出重點有所改編):

1INT16SwRxPower=GetRxPowerInDot1uW();//接收光功率
2if(wRxPower

可見,原實現(xiàn)中轉(zhuǎn)換關(guān)系非?;逎y懂。其實借助1dBuW=10*lg(1uW)和1dBuW-1dBmW=30dB兩個公式,經(jīng)過簡單的數(shù)學(xué)推導(dǎo)即可得到更簡潔易懂的表達(為突出重點有所改編):

1INT16SwRxPower=GetRxPowerInDot1uW();//接收光功率
2//Test單位0.002dBuW,底層單位0.1uW,轉(zhuǎn)換關(guān)系T=(10*lg(B*0.1))/0.002=5000*(lgB-1)
3wRxPower=(INT16S)(5000*(log10((DOUBLE)wRxPower)-1));
4
5//Ani-G功率屬性單位0.002dBmW,Test結(jié)果單位0.002dBuW
6//轉(zhuǎn)換關(guān)系A(chǔ)(dBmW)*0.002+30=T(dBuW)*0.002,即A=T-15000
7INT16SwAniRxPwr=wRxPower-15000;

注意,原實現(xiàn)中誤認為Ani-G功率屬性與Test結(jié)果的單位相同,新實現(xiàn)已修正該錯誤。

2) 封裝函數(shù)

以實體屬性的掩碼校驗為例,原有代碼如下:

1/*掩碼初校驗*/
2if((OMCIMETYPE_SET==vpIn->omci_header.ucmsgtype)
3||(OMCIMETYPE_GET==vpIn->omci_header.ucmsgtype))
4{
5wMask=W(response.omcimsg.auccontent[0],response.omcimsg.auccontent[1]);
6usSupportMask=(1<omci_header.wmeclass,vpIn->omci_header.wmeid,vpIn->omci_header.ucmsgtype,wMask,usSupportMask);
11}
12}

對usSupportMask賦值及判斷的語句(第6~7行),用于校驗掩碼是否越界。為更具可讀性,將其封裝為如下函數(shù):

1/******************************************************************************
2*函數(shù)名稱:OmciIsMaskOutOfLimit
3*功能說明:判斷實體屬性掩碼是否越界(比特1數(shù)目超過屬性數(shù)目)
4*輸入?yún)?shù):INT16UwMeMask:實體掩碼
5*INT8UucAttrNum:屬性數(shù)目
6*輸出參數(shù):NA
7*返回值:BOOL
8******************************************************************************/
9BOOLOmciIsMaskOutOfLimit(INT16UwMeMask,INT8UucAttrNum)
10{
11//wMeMask:mmmmmmmmmmm0m000
12//wInvertMask:00000000000iiiii
13INT8UwInvertMask=(1<

封裝后的函數(shù)名恰當(dāng)?shù)仄鸬健白悦枋觥钡淖饔谩?/p>

3.3 在線調(diào)測工程

該產(chǎn)品作為嵌入式終端,需要在Linux系統(tǒng)中編譯打包版本,然后將其下載到目標單板上運行。這種交叉編譯方式對于單個模塊的調(diào)試而言,效率無疑比較低下。

為提高調(diào)測效率,在Linux服務(wù)器搭建在線調(diào)測工程。即提取OMCI模塊代碼,稍作改造后直接在服務(wù)器上編譯和運行。這樣就可避免每次修改代碼都要重啟單板升級大版本,調(diào)測效率極高。

為使模塊可獨立運行,需要編寫模擬接口以屏蔽底層調(diào)用,并裁減暫不必要的特性(如線程和通信)等。

3.4 模擬數(shù)據(jù)庫

OMCI模塊使用某內(nèi)存數(shù)據(jù)庫來管理需要持久化的實體信息,但該數(shù)據(jù)庫代碼內(nèi)調(diào)用了大量平臺相關(guān)的接口,不利于實現(xiàn)模塊的在線調(diào)測。因此,作者研讀源代碼后編寫了一個模擬數(shù)據(jù)庫。該庫仿照模塊使用的幾個原庫接口及行為,模擬接口內(nèi)部校驗均增加錯誤信息打印,以便于排障。

此外,在數(shù)據(jù)庫接口原語的基礎(chǔ)上二次封裝統(tǒng)一接口,一舉消除模塊內(nèi)數(shù)據(jù)庫操作代碼的凌亂和重復(fù)。

3.5 自動化測試

沒有測試保護網(wǎng)的重構(gòu),無異于沒有血源的外科手術(shù)。

首先,公共接口和函數(shù)均提供有相應(yīng)的測試函數(shù),兼做示例和用例。如:

1//StartofByteArray2StrSeqTest//
2VOIDByteArray2StrSeqTest(VOID)
3{
4 //ByteArray2StrSeq函數(shù)算法不甚優(yōu)美和嚴謹,應(yīng)多加測試驗證,如有可能盡量優(yōu)化。
5INT8UucTestIndex=1;
6INT8UpucByteArray[]={0xD7,0x8F,0xF5,0x73,0xB7,0xF0,0x00,0xE8,0x2C,0x3B};
7CHARpStrSeq[50]={0};
8
9//TimeConsumed(x86_gcc3.2.3_glibc2.2.5):72us
10memset(pStrSeq,0,sizeof(pStrSeq));
11ByteArray2StrSeq(pucByteArray,4,1,pStrSeq);
12printf("[%s]Result:%s,pStrSeq=%s!
",__FUNCTION__,ucTestIndex++,
13strcmp(pStrSeq,"1-2,4,6-9,13-20,22,24,26-28,31-32")?"ERROR":"OK",pStrSeq);
14
15//TimeConsumed(x86_gcc3.2.3_glibc2.2.5):7us
16memset(pStrSeq,0,sizeof(pStrSeq));
17ByteArray2StrSeq(pucByteArray,4,0,pStrSeq);
18printf("[%s]Result:%s,pStrSeq=%s!!!
",__FUNCTION__,ucTestIndex++,
19strcmp(pStrSeq,"0-1,3,5-8,12-19,21,23,25-27,30-31")?"ERROR":"OK",pStrSeq);
20
21//TimeConsumed(x86_gcc3.2.3_glibc2.2.5):4us
22memset(pStrSeq,0,sizeof(pStrSeq));
23ByteArray2StrSeq(&pucByteArray[4],2,1,pStrSeq);
24printf("[%s]Result:%s,pStrSeq=%s!
",__FUNCTION__,ucTestIndex++,
25strcmp(pStrSeq,"1,3-4,6-12")?"ERROR":"OK",pStrSeq);
26
27//TimeConsumed(x86_gcc3.2.3_glibc2.2.5):4us
28memset(pStrSeq,0,sizeof(pStrSeq));
29ByteArray2StrSeq(&pucByteArray[6],2,1,pStrSeq);
30printf("[%s]Result:%s,pStrSeq=%s!
",__FUNCTION__,ucTestIndex++,
31strcmp(pStrSeq,"9-11,13")?"ERROR":"OK",pStrSeq);
32
33//TimeConsumed(x86_gcc3.2.3_glibc2.2.5):5us
34memset(pStrSeq,0,sizeof(pStrSeq));
35ByteArray2StrSeq(&pucByteArray[8],2,1,pStrSeq);
36printf("[%s]Result:%s,pStrSeq=%s!
",__FUNCTION__,ucTestIndex++,
37strcmp(pStrSeq,"3,5-6,11-13,15-16")?"ERROR":"OK",pStrSeq);
38}
39//EndofByteArray2StrSeqTest//

此外,模塊內(nèi)還增加自動化測試功能(TestSuite),可用來驗證批量或單個實體的配置和查詢操作。批量測試結(jié)果統(tǒng)計如下(省略各實體的具體測試結(jié)果):

c28ca3e8-2ac9-11ed-ba43-dac502259ad0.jpg

在上述測試結(jié)果中,F(xiàn)ailed TestCase(s)最為關(guān)鍵,表示失敗的用例數(shù)目。此外,UnCompared TestCase(s)表示未做比較的條目數(shù),如獲取時間等易變屬性的實體,無法預(yù)置恰當(dāng)?shù)钠谕Y(jié)果,因此未做比較。測試過程中的打印信息可保存為日志文件,然后在打印日志中搜索Failure關(guān)鍵字,即可獲知哪些配置失敗。

當(dāng)大量修改當(dāng)前代碼時,借助上述自動化測試功能,可迅速獲知修改結(jié)果的影響。在開發(fā)新功能時,可先設(shè)計好測試用例和期望結(jié)果,然后按照“測試驅(qū)動開發(fā)”的模式來編碼,提高編碼效率和正確率。

3.6 直搗核心

傳統(tǒng)的重構(gòu)步驟是先容易后困難,先外圍后核心。而作者反其道而行之,首先重構(gòu)核心公共的代碼。這樣做的好處是:

1) 便于梳理頭文件包含關(guān)系

在線調(diào)測工程中最初只保留最為公共的代碼文件(如日志功能),重構(gòu)并調(diào)測通過后再逐步添加其他單一功能的目標代碼。該過程中會按需拆分和/或組合文件,減少頭文件的嵌套和交叉引用。

2) 避免重復(fù)工作甚至返工

公共代碼重構(gòu)后并封裝后,對較外圍的應(yīng)用代碼重構(gòu)時會更容易消除冗余。若先重構(gòu)好外圍代碼,很可能發(fā)現(xiàn)某些邏輯可以統(tǒng)一到公共代碼內(nèi),從而導(dǎo)致大面積返工;而若先著手重構(gòu)公共代碼,則通過研讀外圍代碼對其的使用方式,很容易及早甄別這些冗余性。

3) 迭代驗證

 在重構(gòu)后的公共代碼基礎(chǔ)上逐步疊加外圍代碼時,也在反復(fù)測試公共代碼的正確性和易用性。

4) 增強信心

先核心后外圍、逐步疊加驗證的過程可控,可增強大規(guī)模重構(gòu)時的信心,緩解壓力。反之,若先重構(gòu)好外圍代碼,等觸及核心時牽一發(fā)而動全身,壓力極大。

四 效果

在某產(chǎn)品代碼基礎(chǔ)上,進行OMCI模塊DB/LOG/實體存取/消息處理/性能統(tǒng)計等重構(gòu)。經(jīng)過三個多月的重構(gòu)后,模塊代碼復(fù)雜度大幅下降(某核心源文件平均復(fù)雜度降為原先1/4),代碼顯著精簡(據(jù)不完全統(tǒng)計已精簡萬余行),同時更具可讀性。新增代碼的過程中,編寫大量工具類宏和函數(shù),并增加OMCI自動化測試、內(nèi)存檢測等實用功能。

通過LineCount和Source Monitor度量某功能代碼重構(gòu)效果,如下表所示:

c2a812d6-2ac9-11ed-ba43-dac502259ad0.png

注:為便于統(tǒng)計比較,合并SNdbplat.c與SNdbplatSpecial.c為SNdbplat&Special.c。

此外,重構(gòu)過程中積累的通用框架、代碼及經(jīng)驗,可進一步應(yīng)用到新的項目中。




審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Linux系統(tǒng)
    +關(guān)注

    關(guān)注

    4

    文章

    587

    瀏覽量

    27182
  • PON
    PON
    +關(guān)注

    關(guān)注

    1

    文章

    129

    瀏覽量

    43459
  • svn
    svn
    +關(guān)注

    關(guān)注

    0

    文章

    26

    瀏覽量

    8614

原文標題:我的代碼重構(gòu)經(jīng)驗

文章出處:【微信號:技術(shù)讓夢想更偉大,微信公眾號:技術(shù)讓夢想更偉大】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    TFT適配LVGL實踐分享

    1前言說明本章通過FRDM-MCXN947開發(fā)板與正點原子的TFTLCD進行實踐1.2模塊介紹硬件:FRDM-MCXN947開發(fā)板:該開發(fā)板具有豐富的接口詳細可參考NXP官方
    的頭像 發(fā)表于 09-04 08:06 ?1218次閱讀
    TFT適配LVGL<b class='flag-5'>實踐</b>分享

    飛凌嵌入式旗下教育品牌ElfBoard亮相全國大學(xué)生嵌入式競賽總決賽現(xiàn)場

    ElfBoard作為嵌入式教育市場的新生力量,憑借母公司飛凌嵌入式多年深耕企業(yè)級嵌入式板卡的經(jīng)驗亮相全國嵌賽總決賽現(xiàn)場,希望將企業(yè)的實踐經(jīng)驗與高校的理論研究相結(jié)合,共同推動產(chǎn)學(xué)研結(jié)合,加速技術(shù)成果的轉(zhuǎn)化。
    的頭像 發(fā)表于 08-15 09:39 ?521次閱讀
    飛凌嵌入式旗下教育品牌ElfBoard亮相全國大學(xué)生嵌入式競賽總決賽現(xiàn)場

    重構(gòu):改善既有代碼的設(shè)計」實戰(zhàn)篇

    代碼層面的整理,它更是一種軟件開發(fā)的哲學(xué),強調(diào)持續(xù)改進和適應(yīng)變化的重要性。 ? ? 書中通過詳細的案例分析和代碼示例,將理論與實踐巧妙地融合在一起。我尤其贊賞作者 如何將復(fù)雜的重構(gòu)任務(wù)拆解成一系列的小步驟 ,每一步都
    的頭像 發(fā)表于 08-14 10:42 ?124次閱讀
    「<b class='flag-5'>重構(gòu)</b>:改善既有代碼的設(shè)計」實戰(zhàn)篇

    振弦采集儀的工程安全監(jiān)測實踐與案例分析

    振弦采集儀的工程安全監(jiān)測實踐與案例分析 振弦采集儀是一種常用的工程安全監(jiān)測儀器,通過測量被監(jiān)測結(jié)構(gòu)的振動頻率與振型,可以實時監(jiān)測結(jié)構(gòu)的安全狀況。本文將結(jié)合實踐經(jīng)驗和案例分析,探討振弦采集儀在工程安全
    的頭像 發(fā)表于 07-01 11:01 ?125次閱讀
    振弦采集儀的工程安全監(jiān)測<b class='flag-5'>實踐</b>與案例分析

    什么是RAG,RAG學(xué)習(xí)和實踐經(jīng)驗

    高級的RAG能很大程度優(yōu)化原始RAG的問題,在索引、檢索和生成上都有更多精細的優(yōu)化,主要的優(yōu)化點會集中在索引、向量模型優(yōu)化、檢索后處理等模塊進行優(yōu)化
    的頭像 發(fā)表于 04-24 09:17 ?504次閱讀
    什么是RAG,RAG學(xué)習(xí)和<b class='flag-5'>實踐經(jīng)驗</b>

    誠邁科技走進華為,分享在鴻蒙生態(tài)領(lǐng)域的實踐經(jīng)驗和行業(yè)見解

    近日,華為以“千帆競渡,智匯江海”為主題,打造企業(yè)生態(tài)賦能系列專場活動,圍繞“企業(yè)全球戰(zhàn)略布局、高效經(jīng)營管理、構(gòu)建鴻蒙生態(tài)系統(tǒng)戰(zhàn)略、華為云端云協(xié)同戰(zhàn)略”等一系列議題深度探討。
    的頭像 發(fā)表于 04-18 09:43 ?328次閱讀

    中科曙光憑借技術(shù)優(yōu)勢以及實踐經(jīng)驗獲頒“核心參編單位”證書

    近日,中國人工智能產(chǎn)業(yè)發(fā)展聯(lián)盟面向參編單位頒發(fā)證書。中科曙光憑借技術(shù)優(yōu)勢以及實踐經(jīng)驗,全程參編《面向訓(xùn)練任務(wù)的人工智能通用技術(shù)要求》標準(以下簡稱“標準”),獲頒“核心參編單位”證書。
    的頭像 發(fā)表于 03-25 11:05 ?431次閱讀

    交換芯片的構(gòu)建過程

    交換芯片的構(gòu)建過程是一個復(fù)雜而精細的技術(shù)活動,它涉及多個模塊的設(shè)計和集成。這一過程不僅要求工程師們對芯片的結(jié)構(gòu)和功能有深入的理解,還需要他們具備高超的技術(shù)能力和豐富的實踐經(jīng)驗。
    的頭像 發(fā)表于 03-22 16:21 ?617次閱讀

    模擬前端設(shè)計工作內(nèi)容

    模擬前端設(shè)計是電子工程領(lǐng)域中的一個關(guān)鍵環(huán)節(jié),它涉及到將真實世界的模擬信號轉(zhuǎn)換為數(shù)字信號,以供數(shù)字系統(tǒng)進行處理和分析。這一工作內(nèi)容既復(fù)雜又精細,需要設(shè)計師具備深厚的電子工程知識和實踐經(jīng)驗
    的頭像 發(fā)表于 03-16 15:06 ?614次閱讀

    氣密性檢測儀的使用方法,測試原理、安裝步驟與實踐經(jīng)驗技巧分享

    氣密性檢測對產(chǎn)品質(zhì)量來說是關(guān)鍵一環(huán),檢測設(shè)備就是氣密性檢測儀,在新能源、生活家電、汽車配件、消費電子、醫(yī)療器械、安防照明、閥門管道、線材連接器等諸多行業(yè)中有著廣泛應(yīng)用。它能模擬真實工作環(huán)境,鑒定產(chǎn)品在各種氣壓下的密封防水性能。iPhone智能手機由于其出色的IP68防護等級,無懼雨水天氣掌握了氣密性檢測設(shè)備的使用方法,就能全面保證產(chǎn)品質(zhì)量,同時也能提高生產(chǎn)效
    的頭像 發(fā)表于 03-07 08:28 ?911次閱讀
    氣密性檢測儀的使用方法,測試原理、安裝步驟與<b class='flag-5'>實踐經(jīng)驗</b>技巧分享

    訊維集中電源控制器:案例研究與實踐經(jīng)驗分享

    集中電源控制器在實踐中的應(yīng)用非常廣泛,以下是一些案例研究與實踐經(jīng)驗分享: 數(shù)據(jù)中心應(yīng)用案例:在數(shù)據(jù)中心中,集中電源控制器可以實現(xiàn)對服務(wù)器、網(wǎng)絡(luò)設(shè)備和存儲設(shè)備等關(guān)鍵基礎(chǔ)設(shè)施的電源集中管理和監(jiān)控。通過
    的頭像 發(fā)表于 01-30 14:59 ?436次閱讀
    訊維集中電源控制器:案例研究與<b class='flag-5'>實踐經(jīng)驗</b>分享

    為什么要進行模塊測試?光模塊測試方案

    為什么要進行模塊測試?光模塊測試方案 光模塊測試是指對光模塊進行一系列測試,以確保其性能和質(zhì)量
    的頭像 發(fā)表于 01-19 11:15 ?923次閱讀

    K8S落地實踐經(jīng)驗分享

    k8s 即 Kubernetes,是一個開源的容器編排引擎,用來對容器化應(yīng)用進行自動化部署、 擴縮和管理。
    的頭像 發(fā)表于 01-02 11:45 ?902次閱讀
    K8S落地<b class='flag-5'>實踐經(jīng)驗</b>分享

    既然有電阻分壓,還需要這個5伏的電壓去干什么?

    許多同學(xué)會有這樣的學(xué)問,這主要是因為剛學(xué)習(xí)理論,實踐經(jīng)驗不足造成的。關(guān)鍵是我們需要這個5伏的電壓去干什么?
    的頭像 發(fā)表于 11-02 15:51 ?834次閱讀
    既然有電阻分壓,還需要這個5伏的電壓去干什么?

    1針完成!機器人輔助高效穿刺活檢

    李靜教授介紹,傳統(tǒng)的經(jīng)皮肺穿刺活檢術(shù)高度依賴術(shù)者的臨床實踐經(jīng)驗,考驗手術(shù)醫(yī)生對胸部解剖結(jié)構(gòu)的熟悉程度及三維重建想象能力,常需多次進行CT掃描以調(diào)整定位穿刺角度、深度。而對于小病灶、位置難以到達、病人呼吸配合差、術(shù)者經(jīng)驗不足者,有
    的頭像 發(fā)表于 10-08 17:24 ?688次閱讀
    1針完成!機器人輔助高效穿刺活檢