网络编程的基础DAY1

文章通过创建一个C语言的联合体,利用其成员变量的字节对齐特性,来判断计算机是大端还是小端字节序。代码中,将一个整数0x1234赋值给联合体的int成员,然后读取char成员的值。如果char的第一个字节是0x34,则系统为小端字节序,否则为大端字节序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、请简述字节序的概念,并用联合体(共用体)的方式验证计算机是大端还是小端?

  1. 字节序是计算机存储 多字节整数 序列的方式
  2. 例如:short int long longlong 类型,就需要主机字节序
  3. char单字节,float double浮点类型,字符串以上均没有字节序的说法

 

#include <stdio.h>
union endian
{
	char a[2];
	int b;
}A;

int main(int argc, const char *argv[])
{
	A.b=0x1234;
	printf("A.a[0] = %#x\n",A.a[0]);
	printf("A.a[1] = %#x\n",A.a[1]);

	if(A.a[0]==0x34)
	{
		printf("little endian\n");
	}
	else
	{
		printf("big endian\n");
	}

	
	return 0;
}

运行结果

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值