在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;
}
有时(大约五分之一的运行),断言的计算结果为false,即使wordexp()总是返回0(即switch()中的所有情况都没有执行)。这意味着wordexp()不会返回错误,但也不会扩展波形符。怎么会这样?
幸运的是,我现在不必依赖wordexp,但我仍然对这里发生的事情感兴趣。我的意思是......没有多线程,没有变化的输入数据,没有。有什么想法吗?
这适用于Mac OS X 10.6.4,Xcode 3.2.4。
干杯,
马