词条 | inet_ntoa() |
释义 | 函数简介linux下: 函数声明:char *inet_ntoa (struct in_addr); 返回点分十进制的字符串在静态内存中的指针。 所在头文件:<arpa/inet.h> //end linux 下 函数功能:将网络地址转换成“.”点隔的字符串格式。 所需库: winsock.h 也可以使用: 头文件 Winsock2.h lib Ws2_32.lib dll Ws2_32.dll即在程序开头写: #include <WINSOCK2.h> #pragma comment(lib,"WS2_32.LIB") 函数原型: char FAR* PASCAL FAR inet_ntoa( struct in_addr in); MSDN上本函数的原型描述为:unsigned long inet_addr( __in const char *cp); in:一个表示Internet主机地址的结构。 注释: 本函数将一个用in参数所表示的Internet地址结构转换成以“.” 间隔的诸如“a.b.c.d”的字符串形式。请注意inet_ntoa()返回的字符串存放在WINDOWS套接口实现所分配的内存中。应用程序不应假设该内存是如何分配的。在同一个线程的下一个WINDOWS套接口调用前,数据将保证是有效。 返回值: 若无错误发生,inet_ntoa()返回一个字符指针。否则的话,返回NULL。其中的数据应在下一个WINDOWS套接口调用前复制出来。 相关函数:inet_addr(). 程序示例程序示例1: 下面这个例子来自MSDN: #include <winsock2.h> #include <stdio.h> #include <windows.h> #pragma comment(lib, "wininet.lib") // link with Ws2_32.lib int __cdecl main(int argc, char **argv) { //----------------------------------------- // Declare and initialize variables WSADATA wsaData; int iResult; unsigned long ulAddr = INADDR_NONE; // Validate the parameters if (argc != 2) { printf("usage: %s <IPv4 address>\", argv[0]); printf(" inetaddr converts a string containing an\"); printf(" IPv4 address in one of the supported formats\"); printf(" to a unsigned long representing an IN_ADDR\"); printf(" %s 192.168.16.34\", argv[0]); return 1; } // Initialize Winsock iResult = WSAStartup(MAKEWORD(2, 2), &wsaData); if (iResult != 0) { printf("WSAStartup failed: %d\", iResult); return 1; } //-------------------------------- // Call inet_addr(). If the call succeeds, // the result variable will hold a IN_ADDR ulAddr = inet_addr(argv[1]); if ( ulAddr == INADDR_NONE ) { printf("inet_addr failed and returned INADDR_NONE\"); WSACleanup(); return 1; } if (ulAddr == INADDR_ANY) { printf("inet_addr failed and returned INADDR_ANY\"); WSACleanup(); return 1; } printf("inet_addr returned success\"); // Retrieve each address and print out the hex bytes // for(i=0, ptr= (Char*) &ulAddr; i < 4; i++, ptr++) { WSACleanup(); return 0; } 程序示例2: #include <stdio.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <string.h> int main(int argc, char *argv[]) { struct in_addr addr1,addr2; ulong l1,l2; l1= inet_addr("192.168.0.74"); l2 = inet_addr("211.100.21.179"); memcpy(&addr1, &l1, 4); memcpy(&addr2, &l2, 4); printf("%s : %s\", inet_ntoa(addr1), inet_ntoa(addr2)); //注意这一句的运行结果 printf("%s\", inet_ntoa(addr1)); printf("%s\", inet_ntoa(addr2)); return 0; } 实际运行结果如下: 192.168.0.74 : 192.168.0.74 //从这里可以看出,printf里的inet_ntoa只运行了一次。 192.168.0.74 211.100.21.179 inet_ntoa返回一个char *,而这个char *的空间是在inet_ntoa里面静态分配的,所以inet_ntoa后面的调用会覆盖上一次的调用。第一句printf的结果只能说明在printf里面的可变参数的求值是从右到左的,仅此而已。 程序示例3: 将示例2修改一下,使其运行在VC++6.0下: #include <stdio.h> #include <string.h> #include <WINSOCK2.h> #pragma comment(lib,"WS2_32.LIB") int main(int argc, char *argv[]) { struct in_addr addr1,addr2; u_long l1,l2; l1 = inet_addr("192.168.0.74"); l2 = inet_addr("211.100.21.179"); memcpy(&addr1, &l1, 4); memcpy(&addr2, &l2, 4); printf("%s : %s\", inet_ntoa(addr1), inet_ntoa(addr2)); printf("%s\", inet_ntoa(addr1)); printf("%s\", inet_ntoa(addr2)); return 0; } 程序示例4: 将示例1修改一下,使其运行在VC2008下: #include <winsock2.h> #include <stdio.h> #include <windows.h> #pragma comment(lib,"WS2_32.lib") #include <Windows.h> // link with Ws2_32.lib int __cdecl main(int argc, char **argv) { //----------------------------------------- // Declare and initialize variables WSADATA wsaData; int iResult; unsigned long ulAddr = INADDR_NONE; // Validate the parameters if (argc != 2) { printf("usage: %s <IPv4 address>\", argv[0]); printf(" inetaddr converts a string containing an\"); printf(" IPv4 address in one of the supported formats\"); printf(" to a unsigned long representing an IN_ADDR\"); printf(" %s 192.168.16.34\", argv[0]);system("pause"); return 1; }// Initialize Winsock iResult = WSAStartup(MAKEWORD(2, 2), &wsaData); if (iResult != 0) { printf("WSAStartup failed: %d\", iResult);system("pause"); return 1; }//-------------------------------- // Call inet_addr(). If the call succeeds, // the result variable will hold a IN_ADDR ulAddr = inet_addr(argv[1]); if ( ulAddr == INADDR_NONE ) { printf("inet_addr failed and returned INADDR_NONE\"); WSACleanup();system("pause"); return 1; } if (ulAddr == INADDR_ANY) { printf("inet_addr failed and returned INADDR_ANY\"); WSACleanup();system("pause"); return 1; } printf("inet_addr returned success\"); // Retrieve each address and print out the hex bytes // for(i=0, ptr= (Char*) &ulAddr; i < 4; i++, ptr++) { WSACleanup(); system("pause"); return 0; } |
随便看 |
|
百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。