一道有趣的面试题——将int型数组强制转换为char*,再求strlen,涉及大小端 ,求出打印结果

#include<stdio.h>
#include<string.h>
int main()
{
int a[2000];
char *p = (char*)a;
for( int i = 0; i < 2000; i++)
a[i] = -1 - i;
printf( "%d\n", strlen(p));
return 0;
}

 

首先最需要知道的一点就是程序计算strlen(p)的时候遇到8个0就停止了,这个是解除这道题的一个核心。首先要明白负数在内存中的存储方式

a[0] = -1  内存中应当是:11111111  11111111  11111111  11111111

a[1] = -2  内存中应当是:11111111  11111111  11111111  11111110

a[2] = -3  内存中应当是:11111111  11111111  11111111  11111101

……

a[255] = -256 内存中应当是: 11111111 11111111 1111111100000000

假设左边为低地址右边为高地址的话,这个存储方式就为大端点存储,结果就为255*4+3=1023,但是如果是以小端的存储方式来存储的话-256 存放 00000000 11111111 11111111 11111111,所以答案就为255*4=1020.

那么再来看我们这道题如果65是在大端存储的话就是00000000 00000000 00000000 0100 0001这样答案strlen输出就是0。如果是在小端存储的话就是: 00010100 00000000 00000000 00000000 strlen输出就为1.

顺便研究了一下为什么strlen(p)的时候遇到8个0就停止了,原因是因为’\0’的ASSIC码值等于0,所以当一个字节为0的时候就相当于字符串里面有了’\0’,而strlen是遇到’\0’就停止计算。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值