gpt4 book ai didi

C 缓冲区和混淆,初学者

转载 作者:太空宇宙 更新时间:2023-11-04 07:54:18 24 4
gpt4 key购买 nike

<分区>

我今天一直在弄乱 c,当我在这段代码中注释掉第三个缓冲区时,我不明白输出的区别:

 #include <unistd.h>
#include <string.h>
#include <stdio.h>
void main() {
unsigned char letters[10];
memset(letters, 0x00, 10);
memset(letters, 0x41, 10);
printf(letters);
printf(" Total buffer len: %d bytes\n",strlen(letters));

char nletters[10];
memset(nletters, 0x00, 10);
memset(nletters, 0x42, 10);
printf(nletters);
printf(" Total buffer len: %d bytes\n",strlen(nletters));

int nums[10];
memset(nums, 0x00, 10);
memset(nums, 0x43, 10);
printf(nums);
printf(" Total buffer len: %d bytes\n",strlen(nums));
return 0;
}

区别在于删除了 nums 缓冲区周围的注释:

AAAAAAAAAA�7ǝ�U Total buffer len: 16 bytes
BBBBBBBBBBAAAAAAAAAA�7ǝ�U Total buffer len: 26 bytes

还有缓冲区留在:

AAAAAAAAAA Total buffer len: 10 bytes
BBBBBBBBBBAAAAAAAAAA Total buffer len: 20 bytes
CCCCCCCCCC��U Total buffer len: 14 bytes

我没有得到的是:

  1. 看在上帝的份上,注释掉第三个缓冲区会影响其他缓冲区的大小吗?

  2. 缓冲区末尾的额外字节是什么?我如何丢失/管理它们(如果我选择连接缓冲区)?

  3. 为什么我选择是否注释第三个buffer时打印的buffer size和初始化的size不一致?

  4. 缓冲区 2 应该是 10 个字节,为什么是 20 个字节?我不要20,我只要求10,我觉得这不合理。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com