show-bytes.c代码解释

本文详细解析show-bytes.c代码,通过展示内存中数据的形式和地址,揭示大小端模式。size-t用于计算数据大小,sizeof()返回结果为size-t类型。代码重点在于show_bytes函数,用于输出数据值和地址。测试结果表明,在不同类型的byte_pointer定义下,数据读取的字节数不同,验证了系统的字节序为小端模式。

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

代码功能

展示了数据在内存中的形式及其所在地址,可以看出大小端模式,强制类型转换发生的溢出。

代码分析

typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer start, size_t len)
 {
    size_t i;
    for (i = 0; i < len; i++)
	printf("%p\t0x%.2x\n", &start[i], start[i]); 
    printf("\n");
}
  1. size-t全称为size type,可以计算数据的大小,通常使用的sizeof()的结果就可以被定义为size-t。
  2. %p输出start[i]所在地址,0x%.2x输出start[i]的值,都是以十六进制输出。
  3. show_bytes函数输出数据的值和其所在地址,本篇代码中的其他函数都在调用show_bytes函数。
    例如
void show_int(int x) {
    show_bytes((byte_pointer) &x, sizeof(int)); 
}
//输出int型数据
void show_float(float x) {
    show_bytes((byte_pointer) &x, sizeof(float));
}//输出float型数据
void test_show_bytes(int val) {
    int ival = val;
    //float fval = (float) ival;
	double fval = (double) ival;
    int *pval = &ival;
    printf("Stack variable ival = %d\n", ival);
    printf("(int)ival:\n");
    show_int(ival);
    printf("(float)ival:\n");
    show_float(fval);
    printf("&ival:\n");
    show_pointer(pval);
}//定义int型val,强制类型转换为float和double,在相应类型下输出值和所在地址。
void show_twocomp() 
{
/* $begin show-twocomp */
    short x = 12345; 
    short mx = -x; 
    
    show_bytes((byte_pointer) &x, sizeof(short)); 
    show_bytes((byte_pointer) &mx, sizeof(short)); 
/* $end show-twocomp */
}//输出取反后的值和地址

完整代码

/* show-bytes - prints byte representation of data */
/* $begin show-bytes */
#include <stdio.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值