Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/c/56.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何为结构和某些变量正确地malloc?_C_Malloc_Valgrind - Fatal编程技术网

如何为结构和某些变量正确地malloc?

如何为结构和某些变量正确地malloc?,c,malloc,valgrind,C,Malloc,Valgrind,我正在努力为Racer争取马洛克,但我在Valgrind中不断出现错误。有人能帮我理解为什么我不这样做吗 Valgrind告诉我错误在第49、50和57行。。。我用箭头标出了它们 这是我的racer.c代码: #define _BSD_SOURCE #include <stdlib.h> #include <stdio.h> #include <string.h> #include <time.h> #include <assert.h&g

我正在努力为Racer争取马洛克,但我在Valgrind中不断出现错误。有人能帮我理解为什么我不这样做吗

Valgrind告诉我错误在第49、50和57行。。。我用箭头标出了它们

这是我的racer.c代码:

#define _BSD_SOURCE
#include <stdlib.h> 
#include <stdio.h>
#include <string.h>
#include <time.h>
#include <assert.h>
#include <pthread.h>
#include <unistd.h>

long waitTime = DEFAULT_WAIT;
pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;

// Does the setup work for all racers at the start of the program.
void initRacers( long milliseconds ){
    clear();
    if (milliseconds != 0){
        waitTime = milliseconds;
    }
    pthread_mutex_init(&lock, NULL);
    srand(time(NULL));
}

// Creates a new racer.
Racer *makeRacer( char *name, int position ){
    int remain;
    int sizeOfRear = 0;
    char *frontSide = "o>";
    char *rearSide = "~0=";
    char *middleOfCar;

    int lengthOfName = strlen(name);
    int lengthOfRearSide = strlen(rearSide);
    size_t sizeOfRacer = sizeof(Racer);
->  Racer *nRacer = (Racer *)malloc(sizeOfRacer);
->  nRacer->graphic = (char *)malloc(lengthOfName);

    strncpy(nRacer->graphic, rearSide, lengthOfRearSide + 1);
    strcat(nRacer->graphic, name);
    sizeOfRear = strlen(nRacer->graphic);

    remain = MAX_CAR_LEN - sizeOfRear;
->  middleOfCar = (char *)malloc(remain);
    for (int x = 0; x < remain - 2; x++){
        middleOfCar[x] = '-';
    }
    strcat(middleOfCar, frontSide);
    strcat(nRacer->graphic, middleOfCar);
    nRacer->dist = 0;
    nRacer->row = position;
    return nRacer;
}
Valgrind错误:

ShaolinGOD@comp:~/Desktop/Threads$ valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes ./pt-cruisers one two
==18972== Memcheck, a memory error detector
==18972== Copyright (C) 2002-2015, and GNU GPL'd, by Julian Seward et al.
==18972== Using Valgrind-3.11.0 and LibVEX; rerun with -h for copyright info
==18972== Command: ./pt-cruisers one two
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C31644: __strncpy_sse2_unaligned (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x401208: makeRacer (racer.c:52)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420093 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid read of size 1
==18972==    at 0x4C30C14: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40121F: makeRacer (racer.c:53)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420093 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C30C30: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40121F: makeRacer (racer.c:53)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420093 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C30C3F: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40121F: makeRacer (racer.c:53)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420096 is 3 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid read of size 1
==18972==    at 0x4C30F74: strlen (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40122F: makeRacer (racer.c:54)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420093 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Conditional jump or move depends on uninitialised value(s)
==18972==    at 0x4C30C17: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x401289: makeRacer (racer.c:61)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Uninitialised value was created by a heap allocation
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40124A: makeRacer (racer.c:57)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C30C3F: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x401289: makeRacer (racer.c:61)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x54200e6 is 0 bytes after a block of size 6 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40124A: makeRacer (racer.c:57)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid read of size 1
==18972==    at 0x4C30C14: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4012A0: makeRacer (racer.c:62)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420093 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C30C30: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4012A0: makeRacer (racer.c:62)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x5420096 is 3 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid read of size 1
==18972==    at 0x4C30C33: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4012A0: makeRacer (racer.c:62)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x54200e6 is 0 bytes after a block of size 6 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40124A: makeRacer (racer.c:57)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== Invalid write of size 1
==18972==    at 0x4C30C3F: strcat (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4012A0: makeRacer (racer.c:62)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972==  Address 0x542009c is 9 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
0=two----o> Thread 3:
==18972== Invalid read of size 1
==18972==    at 0x401413: run (racer.c:116)
==18972==    by 0x4E416F9: start_thread (pthread_create.c:333)
==18972==  Address 0x5420183 is 0 bytes after a block of size 3 alloc'd
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
                    ~X=one----o> Thread 2:
==18972== Invalid read of                                  ~X=two----o>
==18972==    at 0x4013C7: run (racer.c:107)
==18972== HEAP SUMMARY:F9: start_thread (pthread_create.c:333)
==18972==     in use at exit: 50 bytes in 6 blocksock of size 3 alloc'd
==18972==   total heap usage: 14 allocs, 8 frees, 3,288 bytes allocatedeck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972== Thread 1:00F4F: main (pt-cruisers.c:74)
==18972== 6 bytes in 2 blocks are indirectly lost in loss record 1 of 3
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011DD: makeRacer (racer.c:50)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== 12 bytes in 2 blocks are definitely lost in loss record 2 of 3
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x40124A: makeRacer (racer.c:57)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== 38 (32 direct, 6 indirect) bytes in 2 blocks are definitely lost in loss record 3 of 3
==18972==    at 0x4C2DB8F: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x4011CC: makeRacer (racer.c:49)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
==18972== 
==18972== LEAK SUMMARY:
==18972==    definitely lost: 44 bytes in 4 blocks
==18972==    indirectly lost: 6 bytes in 2 blocks
==18972==      possibly lost: 0 bytes in 0 blocks
==18972==    still reachable: 0 bytes in 0 blocks
==18972==         suppressed: 0 bytes in 0 blocks
==18972== 
==18972== For counts of detected and suppressed errors, rerun with: -v
==18972== ERROR SUMMARY: 797 errors from 15 contexts (suppressed: 0 from 0)
ShaolinGOD@comp:~/Desktop/Threads$ 

我不知道您为什么要标记第49行,但第一个valgrind错误是关于第52行的:

==18972== Invalid write of size 1
==18972==    at 0x4C31644: __strncpy_sse2_unaligned (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==18972==    by 0x401208: makeRacer (racer.c:52)
==18972==    by 0x400F4F: main (pt-cruisers.c:74)
它告诉您(通过
strncpy
)您正在写入您不拥有的内存

第52行是:

    strncpy(nRacer->graphic, rearSide, lengthOfRearSide + 1);
nRacer->graphic
的内存分配为:

    nRacer->graphic = (char *)malloc(lengthOfName);

所以您分配了
lengthOfName
字节,但您正在写入
lengthOfRearSide+1
字节。这是两个完全不同的值:
lengthOfName
是3,而
lengthOfRearSide+1
是4。

我查看了
middlofcar
。那会怎么样

您可以在此处分配:

middleOfCar = (char *)malloc(remain);
middleOfCar[x] = '-';
    }
    strcat(middleOfCar, frontSide);
    strcat(nRacer->graphic, middleOfCar);
然后在这里使用它:

middleOfCar = (char *)malloc(remain);
middleOfCar[x] = '-';
    }
    strcat(middleOfCar, frontSide);
    strcat(nRacer->graphic, middleOfCar);
但是接下来会发生什么呢

没什么了。。。。所以你泄漏了内存


也许你需要在离开函数之前释放它free

,因为你不知道你得到的是哪个Valgrind错误,我假设它不喜欢缺少
free
calls…@EugeneSh我会用Valgrind错误更新帖子。
size\t sizeOfRacer=sizeof(Racer)这里的目的是什么?@wildplasser这是我被教导更简化代码的方式。。。在您阅读并理解其手册页之前,请不要使用strncpy()
。我是否应该释放该函数中的任何其他内容?释放middleOfCar修复了漏洞。@上帝-你必须释放所有你没有引用的东西。所以valgrind说我需要释放nRacer->graphics,但我需要返回nRacer。。。如何释放需要返回的内容?因此我应该只分配lengthOfName或lengthOfRearSide?您应该为要存储在变量中的字符串分配足够的内存。