news 2026/7/1 4:35:16

Socket 编程进阶:为什么必须搞懂“字节序”与“大小端”?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Socket 编程进阶:为什么必须搞懂“字节序”与“大小端”?

各类资料学习下载合集
链接:https://pan.quark.cn/s/770d9387db5f

一、 套接字(Socket):网络的插头与插座

Socket 的原意是“插座”。在网络通信中,它的角色分工非常明确,就像家用电器插电一样:

  • 服务器端 (Server):扮演插座的角色。它被动等待,必须绑定一个固定的 IP 和端口,静静等待别人来连。
  • 客户端 (Client):扮演插头的角色。它主动发起连接,必须知道服务器的 IP 和端口才能“插”进去。

虽然编程语言各异(C, Python, Java),但这套基于 TCP/IP 的流程是全球通用的事实标准。


二、 隐形杀手:字节序 (Byte Order)

你可能会问:“由于不同计算机的体系结构不同,内存存储数据的方式也不同,这会影响通信吗?”答案是肯定的。

1. 什么是大端与小端?

假设我们要存储一个十六进制数字0x12345678(共4个字节)。

  • 大端序 (Big-Endian):高位字节存放在低地址。
    • 内存样子:12 34 56 78(符合人类阅读习惯)
    • 网络字节序采用这种标准。
  • 小端序 (Little-Endian):低位字节存放在低地址。
    • 内存样子:78 56 34 12(x86 架构电脑常用)
    • 主机字节序通常是这种。

2. 为什么要转换?

如果你的电脑(小端)发给服务器(大端)一个端口号80,如果不转换,服务器读出来的可能就是20480!因此,Socket 编程规定:所有大于 1 个字节的数据(如 int, short),传输前必须转换为网络字节序(大端)。


三、 代码实战 1:检测你的电脑是“大端”还是“小端”

在开始写 Socket 代码前,我们先写一段 C 代码,看看你当前使用的电脑内存里到底是怎么存数据的。

代码 (check_endian.c)
#include<stdio.h>intmain(){// 定义一个 4 字节的整数unsignedintx=0x12345678;// 使用字符指针指向 x 的首地址 (只看第 1 个字节)unsignedchar*c=(unsignedchar*)&x;printf("原始数值: 0x12345678\n");printf("内存首字节内容: 0x%x\n",*c);if
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 9:28:00

零基础入门Keil编译环境搭建步骤

从零开始搭建Keil开发环境&#xff1a;避开99%新手都踩过的“c9511e”坑 你是不是也遇到过这种情况——刚装好Keil&#xff0c;信心满满地打开一个工程&#xff0c;点击“Build”&#xff0c;结果编译器弹出一条红色错误&#xff1a; error: c9511e: unable to determine the…

作者头像 李华
网站建设 2026/7/1 9:25:21

Qwen3Guard-Gen-8B开源镜像发布:支持119种语言的安全审核新标杆

Qwen3Guard-Gen-8B&#xff1a;用生成式理解重塑内容安全防线 在AI生成内容&#xff08;AIGC&#xff09;爆发式增长的今天&#xff0c;一个看似简单的问题正变得越来越棘手&#xff1a;我们如何确保大模型输出的内容既合规又安全&#xff1f;尤其是在全球用户混杂、语言文化差…

作者头像 李华
网站建设 2026/7/1 9:28:24

谷歌镜像搜索技巧:精准定位Qwen3Guard-Gen-8B技术资料

谷歌镜像搜索技巧&#xff1a;精准定位Qwen3Guard-Gen-8B技术资料 在生成式AI迅速渗透内容创作、客服系统和智能助手的今天&#xff0c;一个棘手的问题正不断浮现&#xff1a;如何确保大模型输出的内容既合规又安全&#xff1f;传统的关键词过滤和简单分类器&#xff0c;在面对…

作者头像 李华
网站建设 2026/6/30 15:33:29

未来AI会取代人类吗?

AI的发展速度令人惊叹&#xff0c;从写代码到画画&#xff0c;甚至能和你聊天到深夜。但“取代人类”这个命题&#xff0c;真的那么简单吗&#xff1f; AI擅长的是模式识别和高效执行。它能一天写出100篇报告&#xff0c;画出1000张插画&#xff0c;甚至模拟人类的情绪反应。但…

作者头像 李华
网站建设 2026/7/1 9:25:25

CGPO:完美融合—用评审混合机制重塑RLHF

强化学习人类反馈(Reinforcement learning from human feedback,RLHF)已成为微调大语言模型(LLM)的主流方法。然而,RLHF在多任务学习(MTL)中存在局限性,原因在于奖励操纵(reward hacking)问题以及极端的多目标优化(即多个甚至有时相互冲突的目标之间的权衡)带来的…

作者头像 李华