【网络编程】Day1 字节序

文章介绍了字节序的概念,包括小端字节序和大端字节序的定义,并提供了两种方法检查计算机是使用小端还是大端字节序:一种是通过指针访问多字节整数的低地址字节,另一种是利用共用体(联合体)直接读取。通过示例代码和运行结果,展示了如何判断本机字节序。

简述字节序的概念,并用指针方式,或者共用体(联合体)的方式计算本机是大端还是小端

1.  概念:

        1). 字节序是指不同类型的CPU主机,内存存储多字节整数序列的方法

                a. float char 字符串没有字节序的说法

                b. short int long longlong 有字节序的说法。

        2). 字节序分为小端字节序和大端字节序

                a. 小端字节序:低序字节存储在低地址上

                b. 大端字节序:低序字节存储在高地址上,高序字节存储在低地址上。

2. 用指针方式确认计算机是大端还是小端

        实现代码如下:

#include <myhead.h>

int main(int argc, const char *argv[])
{
	unsigned int a = 0x87654321;
	char *p = (char *)&a;
	
	printf("*p = %#x\n",*p);
	if(*p == 0x21)
	{
		printf("是小端\n");
	}
	else if(*p == 0x87)
	{
		printf("是大端\n");
	}

	return 0;
}

        运行结果如下:

ubuntu@ubuntu:com$ ./a.out 
*p = 0x21
是小端

3. 用共用体(联合体)方式计算本机是大端还是小端

        实现代码:

#include <myhead.h>

typedef union
{
     int a;
     char b;
 } A_t;

int main(int argc, const char *argv[])
{
    A_t A;
    A.a=0x87654321;

	printf("b = %#x\n",A.b);
	if(A.b=0x21) 
	{
		printf("是小端\n");
	}
	else if(A.b = 0x87) 
	{
		printf("是大端\n");
	}
	
	return 0;
}

        运行结果如下:

ubuntu@ubuntu:com$ ./a.out 
b = 0x21
是小端

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值