在 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 上运行的。
干杯,
马可