strlen指针vs数组

时间:2014-11-18 08:58:17

标签: c string macos pointers memory-management

使用指针与静态数组时遇到了一些问题。我陷入了这个错误:

void LZWCompress(FILE* file, char minCodeSize, char *pixels, int area)
{

int k = ++minCodeSize, i, len = DEFAULT, jump = 0, dicLen;
lzwDict *dictionary = NULL, *s, *temp;

char *curr, next[2], *buffer;

dicLen = initializeDictionary(&dictionary, minCodeSize);
for(i = 0; i < area; i++)
{
    if(dicLen + 1 >= pow(2, k))
        k = k + 1;

    curr = (char*) malloc(sizeof(char) * DEFAULT);
    curr[0] = pixels[i];
    curr[1] = '\0';

    printf("strlen %lu  %s\n", strlen(curr)); ### strlen(curr) = 0 ? WH ? ###
    if((i + 1) > area)
    {
        //outputs curr
        break; 
    }


    len = len + 1;
    jump = jump + 1;

    next[0] = pixels[i + jump];
    next[1] = '\0';

    buffer = (char*) malloc(sizeof(char) * len);
    printf("%lu %lu %lu \n", strlen(buffer), strlen(curr), strlen(next)); ### prints out "0 0 1" ###

(...)代码继续,因为这个问题我得到了Abort Trap

    buffer = strcat(curr, next);
    HASH_FIND_STR(dictionary, buffer, s);

    if(s)
    {
        printf("YOLO\n");
        do{
            jump = jump + 1;

            if(i + jump >= area)
                exit(-1);

            printf("%d \n", len);
            curr = (char*) realloc(curr, sizeof(char) * len); ### Here i get Abort Trap 6 ###

(...)代码继续

为什么我在使用数组时会得到预期的结果(下一个[2])而不是当我使用指针(* curr,* buffer)时。

如果相关,我正在使用OSX Yosemite。

1 个答案:

答案 0 :(得分:1)

根据strlen doc

  

C字符串的长度由终止空字符决定: AC字符串与字符串开头和终止空字符之间的字符数一样长(不包括终止空字符本身。)

     

这不应与包含字符串的数组的大小混淆。

如果pixels [i]等于0,则strlen(next)将为0。