在这个问题,有人建议意见,我应该不会投的结果malloc,即
int *sieve = malloc(sizeof(int) * length);
Run Code Online (Sandbox Code Playgroud)
而不是:
int *sieve = (int *) malloc(sizeof(int) * length);
Run Code Online (Sandbox Code Playgroud)
为什么会这样呢?
所以我一直在教自己C,并希望学习如何从一开始就正确地管理内存并编写更好的代码,我一直在运行Valgrind.这有助于我内存泄漏,但我似乎无法摆脱这种"有条件的跳转或移动取决于未初始化的值/未初始化的值是由堆分配"创建的情况,尽管我已经缩小了它到这段代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main()
{
char* test = (char*) malloc(3);
strncpy(test, "123", 2);
printf("%s\n", test);
free(test);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
当我运行Valgrind时---track-origins=yes,我得到这个输出:
==91702== Conditional jump or move depends on uninitialised value(s)
==91702== at 0x100011507: strlen (mc_replace_strmem.c:282)
==91702== by 0x1000AA338: puts (in /usr/lib/libSystem.B.dylib)
==91702== by 0x100000EFA: main (valgrind_test.c:10)
==91702== Uninitialised value was created by a heap allocation
==91702== at 0x100010345: malloc (vg_replace_malloc.c:236)
==91702== by 0x100000EEA: main (valgrind_test.c:8)
Run Code Online (Sandbox Code Playgroud)
这对我来说似乎是一种误报,但是我不能凭自己的知识自信地将它写下来.也许我分配错误或使用strncpy错误?我不确定.
提前致谢
struct node* new_node =
(struct node*) malloc(sizeof(struct node));
Run Code Online (Sandbox Code Playgroud)
我不明白*这里:...(struct node*) malloc(siz...
首先,*属于node或malloc?这是什么意思?指针如何与内存函数malloc有关?我真的很困惑*位置
谢谢
嘿伙计我正在学习C语言我需要一些有关代码段的解释,
int *p;
p = (int *) malloc(sizeof(int));
Run Code Online (Sandbox Code Playgroud)
当执行上面的代码时,(int*)意味着什么,以及最新的事情.
码:
int main()
{
char *name=NULL;
int n;
printf("\nenter the string\n");
scanf("%s",name);
n=strlen(name);
printf("%d",n);
return 0;
}
Run Code Online (Sandbox Code Playgroud)
我得到分段错误.代码有什么问题?我已经包括stdio.h,stdlib.h,string.h.