snmpCleanupEx 函式 (winsnmp.h)
[SNMP 可用於需求一節中指定的作業系統。 它在後續版本中可能會變更或無法使用。 請改用 Windows 遠端系統管理,這是 WS-Man 的 Microsoft 實作。
SnmpCleanupEx函式會在 Windows SNMP (WinSNMP) 應用程式內沒有未完成的SnmpStartup或SnmpStartupEx呼叫時執行清除。 否則,會遞減內部參考計數,指出 對 SnmpStartupEx 的目前未處理成功呼叫數目。
如果已安裝 Windows Server 2003 Service Pack 1 (SP1) 或更新版本,則應該使用這個函式,而不是 SnmpCleanup 。 SnmpCleanupEx 可支援在相同應用程式中使用 WinSNMP 的多個獨立軟體模組。
Syntax
SNMPAPI_STATUS SNMPAPI_CALL SnmpCleanupEx();
傳回值
如果函式成功,傳回值會SNMPAPI_SUCCESS。 在 WinSNMP 應用程式成功重新叫用對應的 SnmpStartupEx 函式,而且 SnmpStartup 或 SnmpStartupEx沒有額外的未完成呼叫之前,相同應用程式內對 WinSNMP 函式的任何其他呼叫都會傳回SNMPAPI_FAILURE,且擴充的錯誤碼為 SNMPAPI_NOT_INITIALIZED。
如果函式失敗,傳回值會SNMPAPI_FAILURE,但 WinSNMP 應用程式不需要重試 對 SnmpCleanupEx的呼叫。 若要取得擴充的錯誤資訊,請呼叫SnmpGetLastError在其會話參數中指定Null值。 SnmpGetLastError 函式可以傳回下列其中一個錯誤。
傳回碼 | 描述 |
---|---|
|
記憶體配置期間發生錯誤。 |
|
SnmpStartupEx函式未順利完成,或發生未知或未定義的錯誤。 |
備註
在 WinSNMP 應用程式呼叫 SnmpCleanupEx之前,它應該針對每個會話呼叫 SnmpClose 函式一次,因為 對 SnmpCreateSession 函 式的呼叫而開啟。
當 WinSNMP 應用程式呼叫SnmpCleanupEx函式時,如果SnmpStartup 或 SnmpStartupEx沒有未完成的呼叫,實作就會解除配置配置給應用程式的所有資源。 不過,建議 WinSNMP 應用程式使用對應至資源的 WinSNMP 函式釋放實作配置給它的特定資源。 如需釋放個別資源的其他資訊,請參閱 SnmpFreeEntity、 SnmpFreeVbl、 SnmpFreeDescriptor、 SnmpFreeCoNtext和 SnmpFreePdu。
如果 WinSNMP 應用程式必須執行緊急結束,而且它會呼叫 SnmpCleanupEx 而不釋放個別資源,而且不會針對每個開啟的會話呼叫 SnmpClose ,則實作會解除配置配置給 WinSNMP 應用程式的所有資源。 不過,若要在實作中啟用這項功能,應用程式仍必須呼叫 SnmpCleanupEx。
當應用程式 DLL 正在卸載時,不得呼叫SnmpCleanupEx。
規格需求
最低支援的用戶端 | Windows 2000 Professional [僅限傳統型應用程式] |
最低支援的伺服器 | Windows 2000 Server [僅限桌面應用程式] |
目標平台 | Windows |
標頭 | winsnmp.h |
程式庫 | Wsnmp32.lib |
Dll | Wsnmp32.dll |