共用方式為


notifyRouteChange 函式 (iphlpapi.h)

NotifyRouteChange函式會在 IPv4 路由表中發生變更時,將通知傳送給呼叫端。

語法

IPHLPAPI_DLL_LINKAGE DWORD NotifyRouteChange(
  [out] PHANDLE      Handle,
  [in]  LPOVERLAPPED overlapped
);

參數

[out] Handle

HANDLE變數的指標,接收要用於非同步通知的控制碼。

[in] overlapped

重迭結構的指標,可通知呼叫者路由表中的任何變更。

傳回值

如果函式成功,如果呼叫端指定Handle重迭參數的Null,則傳回值會NO_ERROR。 如果呼叫端指定非Null 參數,則成功傳回值會ERROR_IO_PENDING。 如果函式失敗,請使用 FormatMessage 取得傳回錯誤的訊息字串。

傳回碼 描述
ERROR_CANCELLED
正在取消註冊內容,因此會立即取消呼叫。
ERROR_INVALID_PARAMETER
傳遞了一個無效的參數。 如果 Handle重迭 參數都不是 Null,但呼叫進程無法寫入輸入參數指定的記憶體,就會傳回此錯誤。 如果用戶端已經提出變更通知要求,也會傳回此錯誤,因此此重複的要求將會失敗。
ERROR_NOT_ENOUGH_MEMORY
記憶體不足,無法完成作業。
ERROR_NOT_SUPPORTED
這個錯誤會在 Windows 版本傳回,其中不支援此函式,例如 Windows 98/95 和 Windows NT 4.0。

備註


NotifyRouteChange 函式可以透過兩種方式呼叫:

  • 同步方法
  • 非同步方法

如果呼叫端指定Handle重迭參數的Null則 NotifyRouteChange的呼叫是同步的,而且會封鎖直到發生 IPv4 路由表變更為止。 在此情況下,如果發生變更, NotifyRouteChange 函式會完成以指出已發生變更。

如果以同步方式呼叫 NotifyRouteChange 函式,則會在下一個 IPv4 路由變更上傳送通知,直到應用程式終止為止。

如果呼叫端指定控制碼變數和 OVERLAPPED 結構,則呼叫端可以使用傳回的控制碼搭配 OVERLAPPED 結構來接收 IPv4 路由表變更的非同步通知。 如需使用控制碼和 OVERLAPPED 結構來接收通知的相關資訊,請參閱下列主題:

如果應用程式收到通知,而且需要下一次變更的通知,則必須再次呼叫 NotifyRouteChange 函式。

CancelIPChangeNotify函式會取消 IP 位址的通知,並透過成功呼叫NotifyAddrChangeNotifyRouteChange函式來路由傳送先前要求的變更。

一旦應用程式收到變更的通知,應用程式就可以呼叫GetIpForwardTable 或 GetIpForwardTable2函式來擷取 IPv4 路由表,以判斷已變更的專案。 如果應用程式收到通知,而且需要通知下一次變更,則必須再次呼叫 NotifyRouteChange 函式。

如果以非同步方式呼叫 NotifyRouteChange 函式,則會在下一個 IPv4 路由變更上傳送通知,直到應用程式呼叫 CancelIPChangeNotify 函式或應用程式終止以取消通知為止。 如果應用程式終止,系統會自動取消通知的註冊。 仍然建議應用程式在終止之前明確取消任何通知。

任何通知的註冊都不會在系統關閉或重新開機之間保存。

在 Windows Vista 和更新版本上, NotifyRouteChange2 函式可用來註冊,以通知本機電腦上的 IPv6 路由表變更。

範例

下列範例會等候 IP 路由表中發生變更。

#include <winsock2.h>
#include <iphlpapi.h>
#include <stdio.h>
#include <windows.h>

#pragma comment(lib, "iphlpapi.lib")
#pragma comment(lib, "ws2_32.lib")

void main()
{
  OVERLAPPED overlap;
  DWORD ret;
    
  HANDLE hand = NULL;
  overlap.hEvent = WSACreateEvent();

  ret = NotifyRouteChange(&hand, &overlap);

  if (ret != NO_ERROR)
  {
    if (WSAGetLastError() != WSA_IO_PENDING)
    {
      printf("NotifyRouteChange error...%d\n", WSAGetLastError());            
      return;
    }
  }

  if ( WaitForSingleObject(overlap.hEvent, INFINITE) == WAIT_OBJECT_0 )
    printf("Routing table changed..\n");
}

需求

   
最低支援的用戶端 Windows 2000 Professional [僅限傳統型應用程式]
最低支援的伺服器 Windows 2000 Server [僅限桌面應用程式]
目標平台 Windows
標頭 iphlpapi.h
程式庫 Iphlpapi.lib
Dll Iphlpapi.dll

另請參閱

CancelIPChangeNotify

GetIpForwardTable

GetIpForwardTable2

GetOverlappedResult

IP 協助程式函式參考

NotifyAddrChange

重疊