C socket 复习

inet_addr 将"数字+句点"的格式的IP地址转换到unsigned long中,返回值已经是按照网络字节顺序的
相反inet_ntoa把类型为struct in_addr的数据转化为"数字+句点"的形式的字符串
typedef u_int32_t in_addr_t;
struct in_addr
{
       in_addr_t s_addr;
};

本机字节顺序与网络字节顺序的转换
#include <arpa/inet.h>
htons  ------"host to network short"
htonl   -------"host to network long"
ntohs  -------"network to host short"
ntohl   -------"network to host long"
*注意:在你的数据放到网络上的时候,确信它是网络字节顺序
网络字节顺序(大端字节)和x86机器字节顺序(小端字节)
eg:0X3132  在x86上显示21  在网络传输中为12

inet_addr返回的整数形式是网络字节序,而inet_network返回的整数形式是主机字节序。他俩都有一个小缺陷,
那就是当IP是255.255.255.255时,这两个函数会认为这是个无效的IP地址,这是历史遗留问题,其实在目前大部
分的路由器上,这个255.255.255.255的IP都是有效的。
inet_aton函数和上面这俩个函数的区别就是在于他认为255.255.255.255是有效的,他不会冤枉这个看似特殊的IP地址。对了,inet_aton函数返回的是网络字节序的IP地址。

综上所述,应该使用inet_aton和inet_ntoa这一对函数。


资料:

#include  < sys / socket.h >
#include 
< netinet / in .h >
#include 
< arpa / inet.h >

typedef uint32_t in_addr_t;

int  inet_aton( const   char   * cp,  struct  in_addr  * inp);
in_addr_t inet_addr(
const   char   * cp);
in_addr_t inet_network(
const   char   * cp);
char   * inet_ntoa( struct  in_addr  in );
struct  in_addr inet_makeaddr( int  net,  int  host);
in_addr_t inet_lnaof(
struct  in_addr  in );
in_addr_t inet_netof(
struct  in_addr  in );


 

//  Internet address.
struct  in_addr {
        union {
                
struct  { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;
                
struct  { u_short s_w1,s_w2; } S_un_w;
                u_long S_addr; 
/*  port in network byte order  */
        } S_un;
#define  s_addr  S_un.S_addr
};
//  Socket address, internet style.
struct  sockaddr_in {         //  struct sockaddr的一种特殊形式
         short             sin_family;     /*  address family: AF_INET  */
        u_short        sin_port;        
/*  port in network byte order  */
        
struct  in_addr sin_addr;         /*  port in network byte order  */
        
char             sin_zero[ 8 ];     /*  8 byte pad  */
};
//  Structure used by kernel to store most addresses.
struct  sockaddr {
        u_short sa_family; 
/*  address family  */
        
char     sa_data[ 14 ];  /*  up to 14 bytes of direct address  */
};

struct  in_addr {
    unsigned 
long   int  s_addr;
}

 

 

C 语言常用 字符串转数字函数

atof(将字符串转换成浮点型数)
相关函数
     atoi,atol,strtod,strtol,strtoul
表头文件
     #include <stdlib.h>
定义函数
     double atof(const char *nptr);
函数说明
     atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。
返回值
     返回转换后的浮点型数。
附加说明
     atof()与使用strtod(nptr,(char**)NULL)结果相同。
范例
     /* 将字符串a 与字符串b转换成数字后相加*/
#include<stdlib.h>
main()
{
char *a=”-100.23”;
char *b=”200e-2”;
float c;
c=atof(a)+atof(b);
printf(“c=%.2f ”,c);
}
执行
     c=-98.23


    
atoi(将字符串转换成整型数)
相关函数
     atof,atol,atrtod,strtol,strtoul
表头文件
     #include<stdlib.h>
定义函数
     int atoi(const char *nptr);
函数说明
     atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换,并将结果返回。
返回值
     返回转换后的整型数。
附加说明
     atoi()与使用strtol(nptr,(char**)NULL,10);结果相同。
范例
     /* 将字符串a 与字符串b转换成数字后相加*/
#include<stdlib.h>
mian()
{
char a[]=”-100”;
char b[]=”456”;
int c;
c=atoi(a)+atoi(b);
printf(c=%d ”,c);
}
执行
     c=356


    
atol(将字符串转换成长整型数)
相关函数
     atof,atoi,strtod,strtol,strtoul
表头文件
     #include<stdlib.h>
定义函数
     long atol(const char *nptr);
函数说明
     atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('')才结束转换,并将结果返回。
返回值
     返回转换后的长整型数。
附加说明
     atol()与使用strtol(nptr,(char**)NULL,10);结果相同。
范例
     /*将字符串a与字符串b转换成数字后相加*/
#include<stdlib.h>
main()
{
char a[]=”1000000000”;
char b[]=” 234567890”;
long c;
c=atol(a)+atol(b);
printf(“c=%d ”,c);
}
执行
     c=1234567890


    
gcvt(将浮点型数转换为字符串,取四舍五入)
相关函数
     ecvt,fcvt,sprintf
表头文件
     #include<stdlib.h>
定义函数
     char *gcvt(double number,size_t ndigits,char *buf);
函数说明
     gcvt()用来将参数number转换成ASCII码字符串,参数ndigits表示显示的位数。gcvt()与ecvt()和fcvt()不同的地方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf指针所指的空间。
返回值
     返回一字符串指针,此地址即为buf指针。
附加说明
    
范例
     #include<stdlib.h>
main()
{
double a=123.45;
double b=-1234.56;
char *ptr;
int decpt,sign;
gcvt(a,5,ptr);
printf(“a value=%s ”,ptr);
ptr=gcvt(b,6,ptr);
printf(“b value=%s ”,ptr);
}
执行
     a value=123.45
b value=-1234.56


    
strtod(将字符串转换成浮点数)
相关函数
     atoi,atol,strtod,strtol,strtoul
表头文件
     #include<stdlib.h>
定义函数
     double strtod(const char *nptr,char **endptr);
函数说明
     strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时('')才结束转换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分。如123.456或123e-2。
返回值
     返回转换后的浮点型数。
附加说明
     参考atof()。
范例
     /*将字符串a,b,c 分别采用10,2,16 进制转换成数字*/
#include<stdlib.h>
mian()
{
char a[]=”1000000000”;
char b[]=”1000000000”;
char c[]=”ffff”;
printf(“a=%d ”,strtod(a,NULL,10));
printf(“b=%d ”,strtod(b,NULL,2));
printf(“c=%d ”,strtod(c,NULL,16));
}
执行
     a=1000000000
b=512
c=65535


    
strtol(将字符串转换成长整型数)
相关函数
     atof,atoi,atol,strtod,strtoul
表头文件
     #include<stdlib.h>
定义函数
     long int strtol(const char *nptr,char **endptr,int base);
函数说明
     strtol()会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如 base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用 16进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。
返回值
     返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。
附加说明
     ERANGE指定的转换字符串超出合法范围。
范例
     /* 将字符串a,b,c 分别采用10,2,16进制转换成数字*/
#include<stdlib.h>
main()
{
char a[]=”1000000000”;
char b[]=”1000000000”;
char c[]=”ffff”;
printf(“a=%d ”,strtol(a,NULL,10));
printf(“b=%d ”,strtol(b,NULL,2));
printf(“c=%d ”,strtol(c,NULL,16));
}
执行
     a=1000000000
b=512
c=65535


    
strtoul(将字符串转换成无符号长整型数)
相关函数
     atof,atoi,atol,strtod,strtol
表头文件
     #include<stdlib.h>
定义函数
     unsigned long int strtoul(const char *nptr,char **endptr,int base);
函数说明
     strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。
返回值
     返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。
附加说明
     ERANGE指定的转换字符串超出合法范围。
范例
     参考strtol()


    
toascii(将整型数转换成合法的ASCII 码字符)
相关函数
     isascii,toupper,tolower
表头文件
     #include<ctype.h>
定义函数
     int toascii(int c)
函数说明
     toascii()会将参数c转换成7位的unsigned char值,第八位则会被清除,此字符即会被转成ASCII码字符。
返回值
     将转换成功的ASCII码字符值返回。
范例
     #include<stdlib.h>
main()
{
int a=217;
char b;
printf(“before toascii () : a value =%d(%c) ”,a,a);
b=toascii(a);
printf(“after toascii() : a value =%d(%c) ”,b,b);
}
执行
     before toascii() : a value =217()
after toascii() : a value =89(Y)


    
tolower(将大写字母转换成小写字母)
相关函数
     isalpha,toupper
表头文件
     #include<stdlib.h>
定义函数
     int tolower(int c);
函数说明
     若参数c为大写字母则将该对应的小写字母返回。
返回值
     返回转换后的小写字母,若不须转换则将参数c值返回。
附加说明
    
范例
     /* 将s字符串内的大写字母转换成小写字母*/
#include<ctype.h>
main()
{
char s[]=”aBcDeFgH12345;!#$”;
int i;
printf(“before tolower() : %s ”,s);
for(i=0;I<sizeof(s);i++)
s=tolower(s);
printf(“after tolower() : %s ”,s);
}
执行
     before tolower() : aBcDeFgH12345;!#$
after tolower() : abcdefgh12345;!#$


    
toupper(将小写字母转换成大写字母)
相关函数
     isalpha,tolower
表头文件
     #include<ctype.h>
定义函数
     int toupper(int c);
函数说明
     若参数c为小写字母则将该对映的大写字母返回。
返回值
     返回转换后的大写字母,若不须转换则将参数c值返回。
附加说明
    
范例
     /* 将s字符串内的小写字母转换成大写字母*/
#include<ctype.h>
main()
{
char s[]=”aBcDeFgH12345;!#$”;
int i;
printf(“before toupper() : %s ”,s);
for(i=0;I<sizeof(s);i++)
s=toupper(s);
printf(“after toupper() : %s ”,s);
}

 

http://www.retran.com/beej/inet_ntoaman.html

你可能感兴趣的:(socket)