getservbyname()

getservbyname(),所屬一款電腦編程,返回對應於給定服務名和協定名的相關服務信息。

簡述

返回對應於給定服務名協定名的相關服務信息
#include <windows.h>
struct servent FAR * PASCAL FAR getservbyname(const char
Far * name, const char FAR *proto);
name:一個指向服務名的指針
proto: 指向協定名的指針(可選)。如果這個指針為空,getservbyname()返回第一個name與s_name或者某一個s_aliases匹配的服務條目。否則getservbyname()對name和proto都進行匹配

注釋

getservbyname()返回與給定服務名對應的包含名字和服務號信息的servent結構指針。結構的聲明如下:
struct servent {
char FAR * s_name;
char Far * FAR * s_aliases;
short s_port;
char FAR * s_proto;
};
結構的成員有:
成員用途
s_name 正規的服務名。
s_aliases 一個以空指針結尾的可選服務名佇列。
s_port 連線該服務時需要用到的連線埠號,返回的連線埠號是以網路位元組順序排列的。
s_proto 連線該服務時用到的協定名。
返回的指針指向一個由Windows Sockets實現分配的結構。應用程式不應該試圖修改這個結構或者釋放它的任何部分。此外,每一執行緒僅有一份這個結構的拷貝,所以應用程式應該在發出其他Windows Scokets API調用前,把自己所需的信息拷貝下來。

返回值

如果沒有錯誤發生,getservbyname()返回如上所述的一個指向servent結構的指針,否則,返回一個空指針。應用程式可以通過WSAGetLastError()來得到一個特定的錯誤代碼。
錯誤代碼:
WSANOTINTIALISED在套用這個API前,必須成功地調用WSAStartup()。
WSAENTDOWN Windows Sockets實現檢測到了網路子系統的錯誤。
WSAHOST_NOT_FOUND 沒有找到授權應答主機。
WSANO_DATA 有效的名字,但沒有關於請求類型的數據記錄。
WSAEINPROGRESS 一個阻塞的Windows Sockets操作正在進行。
WSAEINTR 阻塞調用被WSACancelBlockingCall()取消了.
參見: WSAAsyncGetServByName(), getservbyport()

相關詞條

相關搜尋

熱門詞條

聯絡我們