struct in_addr 结构体

struct in_addr 结构体:

struct in_addr {

in_addr_t s_addr;

};

表示一个32位的IPv4地址。

in_addr_t一般为32位的unsigned int,其字节顺序为网络字节序,即该无符号数采用大端字节序。其中每8位表示一个IP地址中的一个数值。

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

头文件为:#include <arpa/inet.h>

inet——ntoa()函数用于将一个十进制网络字节序转换为点分十进制IP格式的字符串。

函数原型为:char*inet_ntoa(struct in_addr in);

头文件为:arpa/inet.h

网络字节序和主机字节序比较容易混乱(大端表示和小端表示)。

网络字节序采用大端表示,就是数据的高位要存放到低地址。

而大多数主机字节序采用小端表示(也有采用大端表示的主机字节序),就是数据的低位放到低地址。

比如无符号整型1338378,的二进制表示为:

数据的高位----------------------------》数据的地位

00000000  00010100  01101100  00001010

所以采用小端表示的主机字节序时,内存中存放的形式为:

低地址----------------------------------------》高地址

00001010  01101100  00010100  00000000

所以可以自己写个小程序来代替inet_ntoa()函数。

#include<stdio.h>

#include<stdlib.h>

#include<string.h>

void toStringIP(const unsigned int ip,char *stringIP);

int main()

{

   unsigned int ip=1338378;

   char* stringIP = (char*)malloc(16);

   memset(stringIP,0,16+1);

   toStringIP(ip,stringIP);

   puts(stringIP);

   return 0;

}

void toStringIP(const unsigned int ip,char *stringIP)

{

   unsigned int tempIP=ip;

   for(int i=0;i<3;i++)

   {

      unsigned char part=(char)tempIP;

      char temp[4];

      sprintf(temp,"%d.",part);

      strcat(stringIP,temp);

      tempIP=tempIP>>8;

   }

   unsigned char part=(char)tempIP;

   char temp[4];

   sprintf(temp,"%d",part);

   strcat(stringIP,temp);

}
时间: 2024-10-14 20:48:19

struct in_addr 结构体的相关文章

struct ifreq结构体与ip,子网掩码,网关等信息

总结一下,今天学习的关于通过socket,ioctl来获得ip,netmask等信息,其中很多内容参照了很多网上的信息,我会一一列出的 我用的这个函数,就是下面这个函数,其中的有一些全局变量,很好懂,也就不多做解释了一.下面对这个函数进行注解一下: int get_nic_IP_Address()//获取各网卡IP地址.子网掩码{ struct ifreq ifreq;  //声明一个struct ifreq结构体(这个结构体中有很多重要的参数,具体可以参照第二的补充)   int sock; 

struct socket结构体详解

在内核中为什么要有struct socket结构体呢?    struct socket结构体的作用是什么?    下面这个图,我觉得可以回答以上两个问题.      由这个图可知,内核中的进程可以通过使用struct socket结构体来访问linux内核中的网络系统中的传输层.网络层.数据链路层.也可以说struct socket是内核中的进程与内核中的网路系统的桥梁.   struct socket {      socket_state  state; // socket state  

struct list_head结构体及相关函数

struct list_head结构体是linux实现数据结构双向链表的基础.其定义: struct list_head { struct list_head *next, *prev; }; 可见链表里面的成员还是链表,每个链表都指向了前面和后面的链表. 一般将struct list_head作为一个成员,放到一个结构体中,其作用是可以从当前的结构体指针,获取到下一个链表元素的地址.一般用list_entry()来实现.具体按照下面的链接: http://www.cnblogs.com/bas

struct sk_buff结构体详解

struct sk_buff是linux网络系统中的核心结构体,linux网络中的所有数据包的封装以及解封装都是在这个结构体的基础上进行. struct sk_buff_head  {     struct sk_buff *next;     struct sk_buff *prev;          __u32 qlen;     spinlock_t lock; } struct sk_buff {     struct sk_buff *next;     struct sk_buff

struct ethhdr结构体详解

    在linux系统中,使用struct ethhdr结构体来表示以太网帧的头部.这个struct ethhdr结构体位于#include<linux/if_ether.h>之中. #define ETH_ALEN 6  //定义了以太网接口的MAC地址的长度为6个字节 #define ETH_HLAN 14  //定义了以太网帧的头长度为14个字节 #define ETH_ZLEN 60  //定义了以太网帧的最小长度为 ETH_ZLEN + ETH_FCS_LEN = 64个字节 #d

linux内核中的struct rlimit结构体详解

   在linux内核中,对一个进程获取系统资源的数量进行了限制.那么linux内核是如何实现这种对一个进程的各种资源的限制呢?    linux使用struct rlimit结构体来实现的,rlimit是 resource limit的缩写.    struct rlimit           {               unsigned int rlim_cur;  /* soft limit */               unsigned int rlim_max;  /* ha

typedef struct与struct定义结构体

今天在定义结构体的时候发现typedef struct与struct定义结构体有一些不同之处: 结构也是一种数据类型, 可以使用结构变量, 因此,  象其它 类型的变量一样, 在使用结构变量时要先对其定义. 定义结构变量的一般格式为: struct 结构名 { 类型  变量名; 类型  变量名; ... } 结构变量; 结构名是结构的标识符不是变量名. 另一种常用格式为: typedef struct 结构名 { 类型  变量名; 类型  变量名; ... } 结构别名; 另外注意:  在C中,

struct stat结构体简介

在使用这个结构体和方法时,需要引入: <sys/types.h> <sys/stat.h> struct stat这个结构体是用来描述一个linux系统文件系统中的文件属性的结构. 可以有两种方法来获取一个文件的属性: 1.通过路径: int stat(const char *path, struct stat *struct_stat); int lstat(const char *path,struct stat *struct_stat); 两个函数的第一个参数都是文件的路径

浅析struct device结构体

device结构体:设备驱动模型中的基础结构体之一 struct device { /*设备所依附的父设备 大多数情况下,这样的设备是某种总线或主控制器 如果该成员变量的值为NULL,表示当前设备是一个最顶端设备,通常这样的设备都不是你想得到的那个*/ struct device *parent; struct device_private *p; struct kobject kobj; const char *init_name; /* initial name of the device