2

在 Xcode 中启动时,在最小的 C 程序中使用 wordexp() 时,我看到了一些奇怪的行为。我无法通过从命令行启动编译的二进制文件来重现这一点。

#include <stdio.h>
#include <stdlib.h>
#include <wordexp.h>
#include <errno.h>
#include <assert.h>

int main (int argc, const char * argv[])
{
    int         wordexpResult;
    wordexp_t   words;
    char*       origPath = "~";

    wordexpResult = wordexp(origPath, &words, 0);

    printf("wordexpResult = %i\n", wordexpResult);

    switch (wordexpResult)
    {
        case 0:
            break;

        case WRDE_BADCHAR:
            fprintf(stderr, "BADCHAR\n");
            exit(EXIT_FAILURE);

        case WRDE_BADVAL:
            fprintf(stderr, "BADVAL\n");
            exit(EXIT_FAILURE);

        case WRDE_CMDSUB:
            fprintf(stderr, "CMDSUB\n");
            exit(EXIT_FAILURE);

        case WRDE_NOSPACE:
            fprintf(stderr, "NOSPACE\n");
            exit(EXIT_FAILURE);

        case WRDE_SYNTAX:
            fprintf(stderr, "SYNTAX\n");
            exit(EXIT_FAILURE);

        default:
            fprintf(stderr, "Unrecognized value: %d\n", wordexpResult);
            exit(EXIT_FAILURE);
    }

    assert(words.we_wordc != 0);

    wordfree(&words);

    return 0;
}

有时(大约五分之一的运行),断言评估为假,即使 wordexp()总是返回 0(即 switch() 中没有任何情况被执行)。这意味着 wordexp() 不会返回错误,但也不会扩展波浪号。这个怎么可能?

幸运的是,我现在不必依赖 wordexp,但我仍然会对这里发生的事情感兴趣。我的意思是......没有多线程,没有变化的输入数据,什么都没有。有任何想法吗?

这是在 Mac OS X 10.6.4、Xcode 3.2.4 上运行的。

干杯,

马可

4

0 回答 0