char []和char [10](或任何其他任意常量)之间有什么区别吗?
例如:
char[] = "here";
char[10] = "there";
当我运行这样的程序时:
struct TreeNode
{
struct TreeNode* left;
struct TreeNode* right;
char elem;
};
void BinaryTreeFromOrderings(char* ,char* ,int);
int main()
{
char a[] = "";
char b[] = "";
cin >> a >> b;
BinaryTreeFromOrderings(b, a, strlen(a));
return 0;
}
void BinaryTreeFromOrderings(char* inorder, char* preorder, int length)
{
if(length == 0) return;
TreeNode* node = new TreeNode;
node->elem = *preorder;
int rootIndex = 0;
for(;rootIndex < length ; rootIndex ++)
{
if(inorder[rootIndex] == *preorder)
break;
}
//left
BinaryTreeFromOrderings(inorder,preorder+1,rootIndex);
//right
BinaryTreeFromOrderings(inorder + rootIndex +1 ,preorder + rootIndex +1,length - (rootIndex + 1));
cout << node->elem;
delete [] node;
return;
}
结果似乎正确,但程序将在退出之前转储。
然后我做了一个实验:
int main()
{
char a[] = "";
cin >> a;
cout << a;
return 0;
}
输入少于9个字符时,它将成功运行。 (gcc版本4.6.3(Ubuntu / Linaro 4.6.3-1ubuntu5))
如果我使用:
初始化[]char a[] = "123456789";
它的成功不到25个特征。
我猜编译器无法确定a的大小。但具体原因是什么?
答案 0 :(得分:7)
char[] = "here";
这是一个大小为5的数组,自动从4个字母中推导出来,加上一个隐含的空终结符('\ 0')加在最后。您可以从0-4位置进行书写和阅读。其他任何事都是未定义的行为。
char[10] = "there";
这是一个大小为10的数组,内容为"there\0\0\0\0\0"
。您可以从0-9位置进行书写和阅读。其他任何事都是未定义的行为。
char a[] = "";
这是一个大小为1的数组,只是一个空终止符。当你输入9个字符时,这是未定义的行为。 (实际上,使用标准字符串输入函数,您甚至无法安全地输入1个字符,因为标准字符串输入函数会自动添加到空终止符上。
char a[] = "123456789";
这是一个大小为10的数组,当你输入25个字符时,这是未定义的行为。
答案 1 :(得分:1)
char a[] = "here";
编译器将确定char数组a
的大小,即4个字符+ 1个结束字符\0
。
char a[10] = "there";
char数组a
的大小为10,包括\0
,因此您可以将最多 9个字符放入int中。否则,您正在写入不属于该阵列的内存。如果按上述方式执行,则字符5-9为空初始化。请在此处查看实时示例:http://ideone.com/O7c8Zp