gpt4 book ai didi

c、数组和malloc的区别。错误

转载 作者:行者123 更新时间:2023-11-30 21:28:54 32 4
gpt4 key购买 nike

我是 AES 开发人员。所以我下载并使用。所以,这是我的问题。如果我使用 [array] 是很好的工作。但如果我使用 [malloc] 就会出错。我错了什么?

uint8_t key[] = { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c };
uint8_t iv[] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f };
uint8_t *original = "aaaaaaaaaaaaaaaaa65aaaaaaaaaaaassssssssssssssssssssss65sssaaaaaa";
int len = 65;
uint8_t out[64] = {0,};

uint8_t ctext[200] = { 0, };
//uint8_t *ctext = (uint8_t*)malloc(sizeof(uint8_t) * len);

for (int i = 0; len > 0; i+=64) {
len = len - 64;
AES128_CBC_encrypt_buffer(out, original + i, 64, key, iv);
memcpy(ctext+i , out, 64);
}
uint8_t ptext[200] = { 0, };
len = 65;
for (int i = 0; len > 0; i += 64) {
len = len - 64;
AES_CBC_dec(out, ctext + (i * sizeof(uint8_t)), key, iv, 64);
memcpy(ptext + (i * sizeof(uint8_t)), out, 64);
}
return 0;

ctext[200]

这是有效的。但。如果我会使用

*ctext

有错误

我错了什么?这是c语言。

最佳答案

使用len = 65memcpy两倍于len = len - 64,在第一次迭代。
您的 memcpy 现在从 ctext + 64 开始,这将超出 sizeof(uint8_t) * len 的内存分配范围

您可以通过使用 len = 64 只进行一次循环迭代或保持 len = 65 并将内存分配加倍来看到这一点 sizeof( uint8_t) * len * 2

如果您使用malloc,请不要忘记随后释放内存

关于c、数组和malloc的区别。错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36788978/

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