易截截图软件、单文件、免安装、纯绿色、仅160KB

linux字节序转换函数和地址转换函数

刚才阅读代码的时候看到了一个字节排序函数,一时想不起具体用法了。想想学习linux下的网络编程也不少时间了,这些字节排序和转换的函数还是不太清楚,容易混淆。今天索性把这方面的知识汇总一下,争取以后能够熟练的认识和运用。
字节顺序函数:
小端字节序:将低序字节存储在起始地址。(linux)
大端字节序:将高序字节存储在起始地址。(网络字节序)
举个例子:对于整数0x12345678来说,在不同的系统中存放的方式如下图:
正是因为网际协议采取的是大端字节序,我们在编程的时候才需要考虑网络字节许和主机字节序之间的转换。下面是四个转换函数(在某些采用大端字节序的系统里面,这四个函数被定位空宏):
#include <netinet/in.h>
uint16_t htons(uint16_t host16bitvalue);
uint32_t htonl(uint32_t host32bitvalue); //均返回网络字节序
uint16_t ntohs(uint16_t net16bitvalue);
uint32_t ntohl(uint32_t net32bitvalue); //均返回主机字节序 
地址转换函数:
下面介绍两组地址转换函数。首先是第一组:
#include <arpa/inet.h>
int inet_aton(const char *strptr, struct in_addr *addrptr);
//返回:1——串有效,0——串有错
char* inet_ntoa(struct in_addr inaddr);
//返回一个指向ASCII字串的指针
in_addr_t inet_addr(const char *strptr);
//成功返回网络字节序,错误返回INADDR_NONE 
接下来是第二组,这两个函数比较新,对于IPv4和IPv6都能处理。p的含义是presentation,代表ASCII字串。n的含意是numberic,代表网络地址值。
#include <netinet/in.h>
#define INET_ADDRSTRLEN 16
#define INET6_ADDRSTRLEN 46
#include <arpa/inet.h>
int inet_pton(int family, const char *strptr, void *addrptr);
//返回:1——成功,输入的不是有效表达格式,-1——出错
const char* inet_ntop(int family, const void *addrptr, char *strptr, size_t len);
//返回:指向结果的指针——成功,NULL——出错 


相关文档:

Linux系统命令Top/free的使用及参数详解

   1.作用
  top命令用来显示执行中的程序进程,使用权限是所有用户。
  2.格式
  top [-] [d delay] [q] [c] [S] [s] [i] [n]
  3.主要参数
  d:指定更新的间隔,以秒计算。
  q:没有任何延迟的更新。如果使用者有超级用户,则top命令将会以最高的优先序执行。
  c:显示进程完整的 ......

Linux系统管理实践(7):网络配置

 
   
要建立一个安全Linux服务器就首先要了解Linux环境下和网络服务相关的配置文件的含义及如何进行安全的配置。在Linux系统中,TCP/IP网
络是通过若干个文本文件进行配置的,也许你需要编辑这些文件来完成联网工作,但是这些配置文件大都可以通过配置命令linuxconf(其中网络部分的配
置可以通过n ......

Linux系统管理实践(8):网络配置 (续)

     12、网络接入的配置过程:
    现在的Linux一般在启动时会自动配置好网卡(有线网卡或无线网卡),只要直接设置好的它的IP(可以用DHCP)、子网掩码、默认路由(即默认网关)、有时还要设置一下DNS,就可以上网了。这些配置现在都有图形用户界面,一般在系统栏的左上角,直接打开 ......

linux下快速安装apache+php+mysql

 (1)、yum安装mysql
//yum安装
yum -y install mysql mysql_server
//在服务清单中添加mysql服务
chkconfig --add mysqld
//服务启动
service mysqld start
//初始化mysql数据库
/usr/bin/mysql_secure_installation
(2)、安装apache
yum -y install httpd
service httpd start
添加iptables允许访 ......

Linux 操作系统日志管理全攻略(3)

   4. Syslog设备
  Syslog已被许多日志函数采纳,它用在许多保护措施中--任何程序都可以通过syslog 纪录事件。Syslog可以纪录系统事件,可以写到一个文件或设备中,或给用户发送一个信息。它能纪录本地事件或通过网络纪录另一个主机上的事件。
  Syslog设备依据两个重要的文件:/etc/syslogd(守护进程)和/ ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号