【C语言】网络字节序和主机字节序

网络字节序和主机字节序是计算机中字节的两种排序方式,它们主要用于解决不同计算机之间数据通信的问题。

一、网络字节序

        也被称为大端字节序,是一种标准的字节序。在网络通信中,如果两台主机的字节序不同,可能会导致数据解释的二义性。为了避免这种问题,网络字节序被采用。无论主机使用什么字节序,发送到网络中的数据都是网络字节序,接收方可以根据自己的主机字节序进行转换。这样,无论接收方使用什么字节序,都能正确地解释数据。

二、主机字节序

        常为小端字节序,是每台计算机根据其硬件设计所采用的字节序。不同的计算机主机字节序可能不相同,与CPU设计有关。这导致了在存储单元超过一个字节的数据时,需要使用网络字节序进行通信,以避免兼容性问题。

三、网络字节序和主机字节序的示例

      假设我们有一个32位的整数0x12345678。

  1. 在主机字节序中,这个整数的存储方式取决于主机的字节序规则。在大端(Big-Endian)系统中,高位字节存储在低地址处,低位字节存储在高地址处。因此,0x12345678在大端系统中的存储顺序是0x12 0x34 0x56 0x78。而在小端(Little-Endian)系统中,低位字节存储在低地址处,高位字节存储在高地址处。所以,0x12345678在小端系统中的存储顺序是0x78 0x56 0x34 0x12。
  2. 在网络字节序中,采用的是大端(Big-Endian)字节序。因此,无论主机使用的是什么字节序规则,发送到网络上的数据都必须转换成网络字节序。在这个例子中,我们要发送的整数0x12345678在网络字节序中的表示就是0x12 0x34 0x56 0x78。

        在实际编程中,我们通常会使用一些函数如htons, htonl, htonll,ntohs, ntohl,ntohll等来进行主机字节序和网络字节序之间的转换。

四、编程示例

       下面是一个使用C语言编写的示例,演示了如何在网络字节序和主机字节序之间进行转换。

#include <stdio.h>  
#include <arpa/inet.h>  
#include <netinet/in.h>  
  
int main() {  
    uint32_t host_int = 0x12345678; // 假设主机字节序为Little-Endian  
    uint32_t net_int;  
    uint32_t converted_host_int;  
  
    // 将主机字节序转换为网络字节序  
    net_int = htonl(host_int);  
    printf("Host byte order: 0x%X\n", host_int);  
    printf("Network byte order: 0x%X\n", net_int);  
  
    // 将网络字节序转换回主机字节序  
    converted_host_int = ntohl(net_int);  
    printf("Converted back to host byte order: 0x%X\n", converted_host_int);  
  
    return 0;  
}

        上面的示例中,我们使用了两个函数:htonlntohlhtonl函数用于将32位主机字节序整数转换为网络字节序,而ntohl函数则执行相反的操作。这两个函数都在头文件<arpa/inet.h>中定义。对于16位整数,可以使用htonsntohs函数。64位整数,可以使用htonll和ntohll函数。这些函数在处理IP地址和端口号时非常有用,因为IP地址和端口号在网络传输时需要使用网络字节序。

        编程示例中,主机字节序转换为网络字节序函数相当于:

void int2bytes( unsigned int v, unsigned char *str )
{
	str[0] = (v>>24)&0xFF;
	str[1] = (v>>16)&0xFF;
	str[2] = (v>>8)&0xFF;
	str[3] = (v)&0xFF;
}

        网络字节序转换为主机字节序函数相当于:

unsigned int bytes2int(unsigned char *str)
{
	unsigned int data;
	data = ((*str) << 24) | ((*(str+1))<<16) | ( (*(str+2))<<8 ) | (*(str+3));
	return data;
}

       请注意,示例中的主机字节序假设为小端字节序(Little-Endian)。如果主机实际上使用大端字节序(Big-Endian),则网络字节序和主机字节序将是相同的,因此这些转换函数在这种情况下不会执行任何操作。

五、总结

        网络字节序和主机字节序的主要区别在于使用场景:网络字节序主要用于网络通信中保证数据的正确性,而主机字节序则是每台计算机根据其硬件设计所采用的字节序。

        在跨平台通信中,为了确保数据的一致性,通常会使用网络字节序来进行数据的传输和存储。然而,在某些情况下,为了更好地利用硬件的性能,可能会选择使用主机字节序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/230587.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

EasyExcel之文件导出最佳实践

文件导出 官方文档&#xff1a;写Excel | Easy Excel (alibaba.com) 引言 当使用 EasyExcel 进行 Excel 文件导出时&#xff0c;我最近在工作中遇到了一个需求。因此&#xff0c;我决定写这篇文章来分享我的经验和解决方案。如果你对这个话题感兴趣&#xff0c;那么我希望这篇…

队列排序:给定序列a,每次操作将a[1]移动到 从右往左第一个严格小于a[1]的元素的下一个位置,求能否使序列有序,若可以,求最少操作次数

题目 思路&#xff1a; 赛时代码&#xff08;先求右起最长有序区间长度&#xff0c;再求左边最小值是否小于等于右边有序区间左端点的数&#xff09; #include<bits/stdc.h> using namespace std; #define int long long const int maxn 1e6 5; int a[maxn]; int n; …

DOS命令

1.cd.. 返回主目录 2.cd 目录 切换到当前目录 3.dir 查看目录的所有文件夹 4.cls 清除dos窗口所有内容 5.键盘的向上箭头 查看上面输入的命令 6.exit退出dos窗口

webSRc实现浏览器播放rtsp【海康】

先上代码 <template><div>video的配置自己写<video id"video" autoplay width"900" height"900"></video></div> </template><script> export default {name: index1,data() {return {webRtcServer: …

LeetCode Hot100 78.子集

题目&#xff1a; 给你一个整数数组 nums &#xff0c;数组中的元素 互不相同 。返回该数组所有可能的子集&#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 方法&#xff1a;灵神 选 or 不选 class Solution {private final List&…

天津大数据培训机构品牌 数据分析师的发展方向

大数据专业还是有一定难度的&#xff0c;毕竟大数据开发技术所包含的编程技术知识是比较杂且多的如果是计算机专业的学生或者自身有一定基础的人学&#xff0c;相对来说会比较容易&#xff0c;但对于零基础小伙伴学习来说&#xff0c;想要学习大数据&#xff0c;难度还是很高的…

Struts 框架(架构师考试复习资料)

Struts 是一个基于 SUN J2EE平台的 MVC 框架&#xff0c;主要是采用 Servlet 和 JSP 技术来实现的。在 Struts 框架中&#xff0c;模型由实现业务逻辑的 JavaBean 或 EJB 构件构成&#xff0c;控制器由ActionServlet和 Action 来实现&#xff0c;视图由一组 JSP 文件构成&#…

Python-猜数字游戏

&#x1f388; 博主&#xff1a;一只程序猿子 &#x1f388; 博客主页&#xff1a;一只程序猿子 博客主页 &#x1f388; 个人介绍&#xff1a;爱好(bushi)编程&#xff01; &#x1f388; 创作不易&#xff1a;喜欢的话麻烦您点个&#x1f44d;和⭐&#xff01; &#x1f388;…

Springboot+FastJson实现解析第三方http接口json数据为实体类(时间格式化转换、字段包含中文)

场景 若依前后端分离版手把手教你本地搭建环境并运行项目&#xff1a; 若依前后端分离版手把手教你本地搭建环境并运行项目_前后端分离项目本地运行-CSDN博客 在上面搭建SpringBoot项目的基础上&#xff0c;并且在项目中引入fastjson、hutool、lombok等所需依赖后。 系统需…

【数据结构第 6 章 ②】- 图的存储结构(详解邻接矩阵)- 用 C 语言实现

目录 一、邻接矩阵表示法 二、AMGraph.h 三、AMGraph.c 四、Test.c 【数据结构第 6 章 ① 】- 图的定义和基本术语-CSDN博客 由于图的结构比较复杂&#xff0c;任意两个顶点之间都可能存在联系&#xff0c;因此无法以数据元素在存储区中的物理位置来表示元素之间的关系&…

KUKA机器人在编程时添加需要等待的输入信号的2种方法

KUKA机器人在编程时添加需要等待的输入信号的2种方法 第一种方法:手动输入法 如下图所示,选中某个程序后,点击下方的“打开”, 如下图所示,将光标定位到所需位置,然后按下左上角的“编辑”按钮,此时示教器上会弹出输入键盘, 如下图所示,在键盘上手动输入语句:wait fo…

mysql支持的整数类型、各类型整数能够表示的数值范围

MySQL :: MySQL 8.2 Reference Manual :: 11.1.2 Integer Types (Exact Value) - INTEGER, INT, SMALLINT, TINYINT, MEDIUMINT, BIGINT mysql支持的整数有&#xff1a;TINYINT、SMALLINT、MEDIUMINT、INT&#xff08;INT和INTEGER是同义词&#xff09;、BIGINT&#xff0c;各…

小黑子——springBoot基础

springBoot简单学习 一、SpringBoot简介1.1 springBoot快速入门1.1.1 开发步骤1.1.2 对比1.1.3 官网构建工程1.1.3 SpringBoot工程快速启动 1.2 springBoot概述1.2.1 起步依赖I. 探索父工程II. 探索依赖III. 小结 1.2.2 程序启动1.2.3 切换web服务器-jetty 二、配置文件2.1 配置…

智能优化算法应用:基于指数分布算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于指数分布算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于指数分布算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.指数分布算法4.实验参数设定5.算法结果6.参考…

【博客园美化】博客园简单动态背景美化(css个人现写的,不喜勿喷)

效果如图&#xff08;背景是动态的&#xff09; 效果参见&#xff1a; 浅吟清风 的博客园 1、前置操作 1、有一个博客园账号&#xff1b; 2、 登陆博客园&#xff0c;进入设置&#xff1b; 3、 选择“博客设置”-> “博客侧边栏公告”-> 申请JS权限&#xff08;图片展…

js写旋转的时钟动态

目录 1、css代码 2.html代码 3.js代码 1、css代码 .box {position: relative;width: 600px;height: 600px;background: url(./images/clock.jpg) no-repeat center;}.hour,.minute,.second {position: absolute;left: 0;top: 0;width: 100%;height: 100%;}.hour {background…

24、pytest通过xfail将测试函数标记为预期失败

官方实例 # content of test_xfail.py import pytest import syspytest.mark.xfail def test_function():print("test_function was invoked.")def valid_config():return Falsedef test_function_02():if not valid_config():pytest.xfail("failing configura…

素材创作平台,解决企业素材供给问题

企业对于高质量素材的需求日益增长。无论是为了提升品牌形象&#xff0c;还是为了推动产品销售&#xff0c;都需要大量的专业设计素材。然而&#xff0c;素材的获取、设计和定制往往是一项耗时耗力的工作。这时&#xff0c;美摄科技素材创作平台应运而生&#xff0c;为企业提供…

387.字符串中的第一个唯一字符 —> `size()`

解答&#xff1a; int firstUniqChar(string s) {int size s.size();// char count[26] { 0 };// error.1int count[26] { 0 };// for (int i 0; i < s.size() - 1; i) // error.2for (int i 0; i < size; i){count[s[i] - a] 1;}for (int i 0; i < size; i){…

J.408之数据结构

J-408之数据结构_北京信息科技大学第十五届程序设计竞赛&#xff08;同步赛&#xff09; (nowcoder.com) 思维好题&#xff0c;直接用两个set存没出现的数字就好了 // Problem: 408之数据结构 // Contest: NowCoder // URL: https://ac.nowcoder.com/acm/contest/68572/J // Me…