c语言中大小端字节序和字节序判断

当我们了解了整数在内存中的存储后,我们调试看一个细节:

//整形占用四个字节,就是看字节在存储的位置的高低

什么是大小端?

其实超过一个字节的数据在内存中存储的时候,就有存储顺序的问题,按照不同的存储顺序,我们分为大端字节序存储和小端字节序存储。

大端(存储)模式:

是指数据的低地位内容保存在内存的高地位地址,而数据的高位字节内容,保存在内容的低地址位

小端(存储)模式:

是指数据的低地位字节内容保存在内存的低地址处,而数据的高位字节内容,保存在内存的高地址

例如:设计一个小程序来判断当前机器的字节序

cs 复制代码
#include<stdio.h>
int main()
{
	int a = 1;
	if(*(char*)&a == 1)
	{
		printf("小端\n");
	 } 
	 else
	 {
	 	printf("大端\n");
	 }
	return 0;
 } 
cs 复制代码
#include<stdio.h>
int check_sys()
{
	int a=1;
	return *(char*)&a;//返回第一个字节,如果是1就返回1,是0就返回0 
}
int main()
{
	if(check_sys() == 1)
	{
		printf("小端\n");//说明第一个字节是1 
	 } 
	 else
	 {
	 	printf("大端\n");//说明最后一个字节是1 
	 }
	return 0;
 } 

//X86环境 小端字节序,%x是以16进制的形式进行打印

cs 复制代码
#include<stdio.h>
//X86环境 小端字节序 
int main()
{
	int a[4]={1,2,3,4};
	int *ptr1 = (int*)(&a+1);
	int *ptr2 = (int*)((int)a + 1);
	printf("%x,%x",ptr1[-1],*ptr2);
	return 0; 
 } 
 //4 20000000 
相关推荐
QiLinkOS6 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
mit6.8247 小时前
阅读的核心,是再读
c++
疯狂打码的少年7 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室7 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen8 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜9 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
upgrador9 小时前
基础知识:C++ STL构造函数的左闭右开惯例及其实现原理
开发语言·c++
我是一颗柠檬10 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农10 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
wuyk55510 小时前
24. C 语言模块化:不是拆几个.c 文件那么简单
c语言·开发语言·stm32·单片机