字符串转换成地址

inet_addr():


功能是将一个点分十进制的IP转换成一个长整数型数(u_long类型)

原型in_addr_t inet_addr(const char *cp);

参数:字符串,一个点分十进制的IP地址

返回值

如果正确执行将返回一个无符号长整数型数。如果传入的字符串不是一个合法的IP地址,将返回INADDR_NONE。

头文件:Winsock2.h.

arpa/inet.h(Linux)

inet_ntop()


Linux下inet_pton和inet_ntop这2个IP地址转换函数,可以在将IP地址在“点分十进制”和“整数”之间转换。而且,这2个函数能够处理ipv4和ipv6。算是比较新的函数了。

inet_ntop函数原型如下[将“整数” -> “点分十进制”]

1
2
3
4
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
const  char  *inet_ntop( int  af,  const  void  *src,  char  *dst, socklen_t cnt);

这个函数转换网络二进制结构到ASCII类型的地址,参数的作用和inet_pton相同,只是多了一个参数socklen_t cnt,他是所指向缓存区dst的大小,避免溢出,如果缓存区太小无法存储地址的值,则返回一个空指针,并将errno置为ENOSPC。

inet_ntoa()

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#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\n" , inet_ntoa(addr1), inet_ntoa(addr2));  //注意这一句的运行结果
printf ( "%s\n" , inet_ntoa(addr1));
printf ( "%s\n" , inet_ntoa(addr2));
return  0;
}

实际运行结果如下:

192.168.0.74 : 192.168.0.74 //从这里可以看出,printf里的inet_ntoa(addr2)先于inet_ntoa(addr1)执行。

192.168.0.74

211.100.21.179

    inet_ntoa返回一个char *,而这个char *的空间是在inet_ntoa里面静态分配的,所以inet_ntoa后面的调用会覆盖上一次的调用。第一句printf的结果只能说明在printf里面的可变参数的求值是从右到左的,仅此而已。

inet_aton()

inet_aton()是一个改进的方法来将一个字符串IP地址转换为一个32位的网络序列IP地址。

2函数概要如下

1
2
3
头文件:#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

完整描述:

1
int  inet_aton( const  char  *string,  struct  in_addr*addr);

参数描述:

1 输入参数string包含ASCII表示的IP地址。

2 输出参数addr是将要用新的IP地址更新的结构。

返回值:

如果这个函数成功,函数的返回值非零,如果输入地址不正确则会返回零。使用这个函数并没有错误码存放在errno中,所以它的值会被忽略。



——————————————————————————————————————————————

1
2
3
struct  in_addr {
     in_addr_t s_addr;
};

结构体in_addr 用来表示一个32位的IPv4地址.

in_addr_t 一般为 32位的unsigned int,其字节顺序为网络顺序(network byte ordered),即该无符号整数采用大端字节序[1]。.

其中每8位代表一个IP地址位中的一个数值.

例如192.168.3.144记为0xc0a80390,其中 c0 为192 ,a8 为 168, 03 为 3 , 90 为 144

打印的时候可以调用inet_ntoa()函数将其转换为char *类型.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
struct in_addr
{
     union
     {
         struct
         {
             u_char s_b1,s_b2,s_b3,s_b4;
         } S_un_b;  //An IPv4 address formatted as four u_chars.
         struct
         {
             u_short s_w1,s_w2;
         } S_un_w;  //An IPv4 address formatted as two u_shorts
        u_long S_addr; //An IPv4 address formatted as a u_long
     } S_un;
#define s_addr S_un.S_addr
};

http://www.360doc.com/content/14/1113/16/16170632_424847785.shtml


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值