• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            S.l.e!ep.¢%

            像打了激速一樣,以四倍的速度運(yùn)轉(zhuǎn),開心的工作
            簡(jiǎn)單、開放、平等的公司文化;尊重個(gè)性、自由與個(gè)人價(jià)值;
            posts - 1098, comments - 335, trackbacks - 0, articles - 1
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            摘自《Windows驅(qū)動(dòng)開發(fā)技術(shù)詳解》
            1.
            機(jī)構(gòu)化異常處理(try-except塊)

            ????? 結(jié)構(gòu)化異常處理( SHE, Structured Exception Handling )是微軟編譯器提供的獨(dú)特處理機(jī)制,這種處理方式能在一定程度上在出現(xiàn)錯(cuò)誤的情況下,避免程序崩潰。先說(shuō)明兩個(gè)概念。

            (1) 異常:異常的概念類似于中斷的概念,當(dāng)程序中某中錯(cuò)誤觸發(fā)一個(gè)異常,操作系統(tǒng)會(huì)尋找處理這個(gè)異常的處理函數(shù)。如果程序提供異常處理函數(shù),則進(jìn)入該函數(shù),否則由操作系統(tǒng)提供的默認(rèn)異常處理函數(shù)處理。在內(nèi)核模式下,操作系統(tǒng)默認(rèn)處理錯(cuò)誤的方法是直接讓系統(tǒng)藍(lán)屏,并在藍(lán)屏上簡(jiǎn)單描述出錯(cuò)的信息。

            (2) 回卷:程序執(zhí)行到某個(gè)地方出現(xiàn)異常錯(cuò)誤時(shí),系統(tǒng)會(huì)尋找出錯(cuò)點(diǎn)是否處于一個(gè) try{} 塊中,并進(jìn)入 try 塊提供的異常處理代碼。如果當(dāng)前 try 塊沒(méi)有提供異常處理,則會(huì)向更外一層的 try 塊尋找異常處理代碼,直到最外層 try 塊也沒(méi)有提供異常處理代碼,則交由操作系統(tǒng)處理。這種向更外一層尋找異常處理的機(jī)制,被稱為回卷。

            一般處理異常,是通過(guò) try-except 塊來(lái)處理的。

            __try

            {

            //your normal code

            }

            __except(filter_value)

            {

            ?????? //your operate code

            }

            在被 __try{} 包圍的塊中,如果出現(xiàn)異常,會(huì)根據(jù) filter_value 的數(shù)值,判斷是否需要在 __except{} 塊中處理。 filter_value 的數(shù)組會(huì)有三種可能。

            (1)??????????????? EXCEPTION_EXECUTE_HANDLE ,該數(shù)值為 1 。進(jìn)入到 __except 進(jìn)行錯(cuò)誤處理,處理完后不再回到 __try{} 塊中,轉(zhuǎn)而繼續(xù)執(zhí)行下面的代碼。

            (2)??????????????? EXCEPTION_CONTINUE_SEARCH ,該數(shù)值為 0 。不進(jìn)入 __except 塊中的異常處理,而是向上一層回卷。如果已經(jīng)是最外層,則向操作系統(tǒng)請(qǐng)求異常處理函數(shù)。

            (3)??????????????? EXCEPTION_CONTINUE_EXECUTION ,該數(shù)值為 -1 。重復(fù)先去錯(cuò)誤的指令,這個(gè)在驅(qū)動(dòng)程序中很少用到。

            下面一段代碼是用來(lái)檢測(cè)某段內(nèi)存是否可讀寫,這段代碼通過(guò) try-except 來(lái)探測(cè)指針的地址是否可寫。

            VOID ProbeTest()

            {

            ?????? PVOID pBad = NULL;

            ?????? KdPrint((“Enter ProbeTest\n”));

            ?????? __try

            {

            ?????? KdPrint((“Enter __try block\n”));

            ?????? // 判斷空指針是否可寫,顯然會(huì)導(dǎo)致異常

            ?????? ProbeForWrite(pBad, 100, 4);

            ?????? // 由于在上面引發(fā)異常,所以下面語(yǔ)句不會(huì)被執(zhí)行

            ?????? KdPrint((“Leave __try block\n”));

            }

            __except(EXCEPTION_EXCUTE_HANDLE)

            {

            ?????? KdPrint((“Catch the exception\n”));

            ?????? KdPrint((“The program will keep going\n”));

            }

            // 該語(yǔ)句會(huì)被執(zhí)行

            KdPrint((“Leave ProbeTest\n”));

            }

            ????? 除了處理異常之外, DDK 還提供了一些函數(shù)用來(lái)觸發(fā)異常。如表 1 所示:

            1 觸發(fā)異常函數(shù)

            函數(shù)

            描述

            ExRaiseStatus

            用指定狀態(tài)代碼觸發(fā)異常

            ExRaiseAccessViolatioin

            觸發(fā) STATUS_ACCESS_VILOATION 異常

            ExRaiseDatatypeMisalignment

            觸發(fā) STATUS_DATATYPE_MISALIGNMENT 異常

            ?

            2. 結(jié)構(gòu)化異常處理( try-finally 塊)

            ????? 結(jié)構(gòu)化異常處理還有另外一種使用方法,就是利用 try-finally 塊,強(qiáng)迫函數(shù)在退出前執(zhí)行一段代碼。

            NTSTATUS TryFinallyTest()

            {

            NTSTATUS status? = STATUS_SECCESS;

            __try

            {

            ?????? //your normal code

            ?????? return status;

            }

            __finally

            {

            ?????? // 程序退出前必然運(yùn)行到此

            ?????? KdPrint((“Enter finally block\n”));

            }

            }

            ????? 上面代碼的 __try{} 塊中,無(wú)論運(yùn)行什么代碼(即使是 return 語(yǔ)句或者觸發(fā)異常),在程序退出前都會(huì)運(yùn)行 __finally{} 塊中的代碼。這樣的目的是,在退出前需要運(yùn)行一些資源回收的工作,而資源回收代碼的最佳位置就是放在這個(gè)塊中。

            ????? 此外,使用 try-finally 塊還可以在某種程度上簡(jiǎn)化代碼。比較下面兩段代碼,其中地一段是沒(méi)有使用 try-finally 塊的代碼,而第二段是使用了 try-finally 。可以看出,第二段代碼比第一段代碼清晰明了。

            第一段代碼:

            VOID FooTest()

            {

            ?????? NTSTATUS status = STATUS_SUCCESS;

            ?????? // 執(zhí)行操作 1

            ?????? status = Foo1();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? // 回收資源

            ????????????? return status;

            }

            ?

            // 執(zhí)行操作 2

            ?????? status = Foo2();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? // 回收資源

            ????????????? return status;

            }

            ?

            // 執(zhí)行操作 n

            ?????? status = FooN();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? // 回收資源

            ????????????? return status;

            }

            ?

            return status;

            }

            第二段代碼:

            VOID FooTest()

            {

            ?????? NTSTATUS status = STATUS_SUCCESS;

            ?????? __try

            {

            ?????? // 執(zhí)行操作 1

            ?????? status = Foo1();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? return status;

            }

            ?

            // 執(zhí)行操作 1

            ?????? status = Foo2();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? return status;

            }

            ?

            // 執(zhí)行操作 n

            ?????? status = Foo1();

            ?????? // 判斷操作是否成功

            ?????? if (!NT_SUCCESS(status))

            ?????? {

            ????????????? return status;

            }

            }

            __finally

            {

            ?????? // 回收資源

            }

            return status;

            }

            国产精品视频久久久| 色8激情欧美成人久久综合电| 久久WWW免费人成一看片| 国产成人无码精品久久久性色| 久久久久国产精品嫩草影院| 久久精品国产亚洲欧美| 久久久久国产成人精品亚洲午夜| 久久这里有精品| 久久91综合国产91久久精品| 中文字幕精品无码久久久久久3D日动漫 | 一级女性全黄久久生活片免费| 久久狠狠爱亚洲综合影院| 精品久久久久国产免费| 免费精品国产日韩热久久| 国产精品久久波多野结衣| 久久亚洲精品无码VA大香大香| 国产成人香蕉久久久久| 精品久久久久中文字幕日本| 久久亚洲国产精品成人AV秋霞 | 亚洲AV日韩AV天堂久久| 伊人久久大香线蕉综合热线| 久久精品草草草| 1000部精品久久久久久久久| 波多野结衣AV无码久久一区| 欧洲性大片xxxxx久久久| 精品久久久久久无码中文字幕| 久久国产精品无码HDAV| 三上悠亚久久精品| 日韩精品久久久久久久电影蜜臀 | 狠狠色丁香婷综合久久| 久久香综合精品久久伊人| 婷婷久久久亚洲欧洲日产国码AV| 97视频久久久| 人妻少妇久久中文字幕| 久久99国内精品自在现线| 久久久久亚洲av无码专区导航| 人妻精品久久无码专区精东影业| 狠狠88综合久久久久综合网 | 久久国产精品波多野结衣AV| 草草久久久无码国产专区| 99久久伊人精品综合观看|