程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> C++入門知識 >> S_OK與S_FALSE,E_FAIL,s_oks_falsee_fail

S_OK與S_FALSE,E_FAIL,s_oks_falsee_fail

編輯:C++入門知識

S_OK與S_FALSE,E_FAIL,s_oks_falsee_fail


S_OK是COM服務器返回正確

S_FALSE是COM服務器返回錯誤,不過這個錯誤是可以不處理的,不影響程序正常運行。只是結果不是想要的

E_FAIL是必須處理的錯誤。

 

//
// Success codes
//
#define S_OK                                   ((HRESULT)0L)
#define S_FALSE                                ((HRESULT)1L)

 

 

// macros
#define SUCCEEDED(hr)   (((HRESULT)(hr)) >= 0)
#define FAILED(hr)      (((HRESULT)(hr)) < 0)

#define E_FAIL                           _HRESULT_TYPEDEF_(0x80004005L)


C語言SUCCEEDED函數

SUCCEEDED
先看下這個宏的定義(WinError.h):
//
// Generic test for success on any status value (non-negative numbers
// indicate success).
//

#define SUCCEEDED(hr) ((HRESULT)(hr) >= 0)

從這裡可以看出,它就是把hr轉換成HRESULT類型,然後做了下是否大於0的判斷。注釋中也說明:但值為非負數時表示成功。
也就是說,只要HRESULT是大於等於0的值,它就認為是成功的。

HRESULT
再來看下HRESULT的定義(winnt.h):
// Component Object Model defines, and macros

#ifndef _HRESULT_DEFINED
#define _HRESULT_DEFINED
typedef LONG HRESULT;

#endif // !_HRESULT_DEFINED

哦,原來HRESULT就是一個Long型的整數。
在MSDN中,可以查到更加詳細的資料:

如上圖,HRESULT是一個4字節的Long型,總共32位。其中:
第31位是s位,即符號位,因為HRESUlT格式規定所有成功都是正的整數,失敗的值都是負數
第30位是r位,是保留位,但n位(28位)沒有設置時,它必須是0;如果n位使用了,則和s位一起來標識NTSTATUS的值。
第29位是c位,表示Custom,即自定義位,如果是微軟定義的返回值,則該位為0;如果是自定義的,則該位為1.
第28位是n位,表示NTSTATUS,值為0的話可以把NTSTATUS值映射為一個HRESULT值。
第27位是x位,保留位,必須為0.
第26位到第16位是Facility,用11位來表示錯誤來源,比如
FACILITY_WINDOWS 表示來自Windows子系統
第15位到第1位是Code位,用來保存錯誤值。

從這裡可以看出,只有最後面的2個字節是用來表示返回值的其它的都是輔助信息,它主要用於COM函數的返回值。

常見HRESULT值
Name Description Value
S_OK 操作成功 0x00000000
S_FALSE 操作成功,但是有問題 0x00000001L
E_ABORT 操作中止 0x80004004
E_ACCESSDENIED 拒絕訪問 0x80070005
E_FAIL 未知錯誤 0x80004005

注意:除了S_OK外,還有一個S_FALSE,它也屬於成功。
所以,微軟為了方便大家使用,專門提供了SUCCEEDED宏和FAILED宏來方便大家做判斷。
到這裡,大家明白了吧:SUCCEEDED宏是用來判斷COM中的函數執行是否成功用的,失敗為負數,成功為0和正數。...余下全文>>
 

電腦玩生化危機5出現這個e_fail:xliveinitialize怎辦?

xlive初始化失敗?你把游戲目錄裡的xlive刪了在試試看。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved