鱼C论坛

 找回密码
 立即注册
查看: 500|回复: 3

[已解决]realloc

[复制链接]
发表于 2023-7-27 08:13:32 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
        
        TCHAR* p, * q;

        //用法:指针名=(数据类型*)realloc(要改变内存大小的指针名,新的大小)

        p = (TCHAR*)malloc(10 * sizeof(TCHAR));
        
        for (int i = 0; i < 9;i++) {
                *(p + i) = _T('a');

        }

        *(p + 9) = _T('\0');

        q = (TCHAR*)realloc(p, 15*sizeof(TCHAR));//修改数组容量
        /*
        格式:指针名=(数据类型*)realloc(源指针名,新的大小)
        将原数组中的数据拷贝到新的数组中,释放掉原数组,并返回一个数组首地址
        若失败:不会释放掉原数组,会返回一个空地址,表示开辟新数组失败,原来的数组空间没动

        */

        if (q != NULL) {
                for (int i = 9*sizeof(TCHAR); i < 13 * sizeof(TCHAR); i+ sizeof(TCHAR)) {
                        *(q + i) =_T( 'b');

                }
        }

        *(p + 14 * sizeof(TCHAR)) = _T('\0');

        CString str = q;

        ::OutputDebugString(str);

我的问题:在Unicode编码下    好像处于死循环  ??




最佳答案
2023-7-27 08:13:46
在您提供的代码中,存在一个潜在的死循环的问题。问题出现在以下这行代码:
for (int i = 9*sizeof(TCHAR); i < 13 * sizeof(TCHAR); i+ sizeof(TCHAR)) {    *(q + i) = _T('b');}
循环条件 i < 13 * sizeof(TCHAR) 应该是 i += sizeof(TCHAR),而不是 i+ sizeof(TCHAR)。目前的写法没有对循环变量 i 进行自增操作,导致循环条件始终满足,进入了死循环,从而引发了问题。

修正后的代码应该如下所示:
for (int i = 9 * sizeof(TCHAR); i < 13 * sizeof(TCHAR); i += sizeof(TCHAR)) {    *(q + i) = _T('b');}
请注意,在修改数组容量后,应该使用指针 q 来进行操作,因为 realloc() 可能会重新分配内存,并返回一个新的指针。在代码的最后,您可以根据需要释放原来的内存空间,例如使用 free(p);

总结:代码中的死循环问题是由于错误的循环自增表达式引起的。修正后的代码应该使用 += 运算符对循环变量进行自增操作。同时要注意在修改数组容量后使用新的指针来操作。

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-7-27 08:13:37 | 显示全部楼层
问题出在这行代码上:
for (int i = 9*sizeof(TCHAR); i < 13 * sizeof(TCHAR); i+ sizeof(TCHAR)) {
    *(q + i) =_T( 'b');
}

在这个循环中,你没有正确地更新  i  的值,导致循环进入死循环。在每次循环迭代中,你需要将  i  增加  sizeof(TCHAR) ,以便正确地遍历数组。修改代码如下:
for (int i = 9*sizeof(TCHAR); i < 13 * sizeof(TCHAR); i += sizeof(TCHAR)) {
    *(q + i) =_T( 'b');
}

这样就可以避免死循环,并正确地将字符  'b'  插入到新数组中。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-27 08:13:46 | 显示全部楼层    本楼为最佳答案   
在您提供的代码中,存在一个潜在的死循环的问题。问题出现在以下这行代码:
for (int i = 9*sizeof(TCHAR); i < 13 * sizeof(TCHAR); i+ sizeof(TCHAR)) {    *(q + i) = _T('b');}
循环条件 i < 13 * sizeof(TCHAR) 应该是 i += sizeof(TCHAR),而不是 i+ sizeof(TCHAR)。目前的写法没有对循环变量 i 进行自增操作,导致循环条件始终满足,进入了死循环,从而引发了问题。

修正后的代码应该如下所示:
for (int i = 9 * sizeof(TCHAR); i < 13 * sizeof(TCHAR); i += sizeof(TCHAR)) {    *(q + i) = _T('b');}
请注意,在修改数组容量后,应该使用指针 q 来进行操作,因为 realloc() 可能会重新分配内存,并返回一个新的指针。在代码的最后,您可以根据需要释放原来的内存空间,例如使用 free(p);

总结:代码中的死循环问题是由于错误的循环自增表达式引起的。修正后的代码应该使用 += 运算符对循环变量进行自增操作。同时要注意在修改数组容量后使用新的指针来操作。

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-27 08:13:54 | 显示全部楼层
本帖最后由 陶远航 于 2023-7-27 08:44 编辑

根据您提供的代码,其中使用了realloc函数来改变指针p所指向内存的大小,并将其赋值给指针q。然后,您尝试在q指向的内存中写入字符'b'。

然而,我注意到在代码中有几个错误,可能导致问题出现。首先是在for循环中,更新i的方式是 b]i+ sizeof(TCHAR)[/b],这是不正确的。应该使用 i += sizeof(TCHAR) 来更新i的值。此外,在为新分配的内存设置终止符'\0'时,您使用了 [b)/b] 的表达式,应该更正为 [b)[/b],因为您想要操作的是q指向的内存。

另外,如果realloc函数失败,则不会释放原始数组p,并且q将返回一个空地址。因此,在使用q之前,您应该检查q是否为NULL,以防止使用无效的内存。

以下是修复上述问题的代码示例:
realloc, TCHAR* p, * q;
p = (TCHAR*)malloc(10 * sizeof(TCHAR));

for (int i = 0; i < 9; i++) {
    *(p + i) = _T('a');
}
*(p + 9) = _T('\0');

q = (TCHAR*)realloc(p, 15 * sizeof(TCHAR));

if (q != NULL) {
    for (int i = 9; i < 13; i++) {
        *(q + i) = _T('b');
    }
}

*(q + 14) = _T('\0');

CString str = q;
::OutputDebugString(str);

这样修改后的代码应该能够正确地改变指针p所指向内存的大小,并在q指向的内存中写入字符'b'。请尝试使用这个修复后的代码,并检查是否仍然存在死循环的问题。如果问题仍然存在,请提供更多关于死循环的详细信息,以便我可以更准确地帮助您解决问题。
如果问题已经解决,请设置最佳答案
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 10:16

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表