C语言初始化字符型数组时,两种方式的区别? 5
如下两张图,我记得两种初始化方式的区别就是,其中一个的最后多了个'\0',但是为什么strlen求长度的时候会计算到8呢,或者说,为什么初始化完a之后再初始化b,b存储的...
如下两张图,我记得两种初始化方式的区别就是,其中一个的最后多了个'\0',但是为什么strlen求长度的时候会计算到8呢,或者说,为什么初始化完a之后再初始化b,b存储的字符串变成了——在初始化b的基础上,后面又跟上了一整个a
展开
3个回答
展开全部
左图的程序是a和b初始化时都被赋值为字符串,它们的最后都有字符'\0',有了这个标志,求字符串长度和输出字符串时都能得到正确的结果。
右图的程序a的初始化赋值仍然是字符串,所以它的输出也是正确的。而b的初始化使b成为一个“字符数组”,它的最后没有字符串结束符,系统也不会主动加上。所以,当后面你用字符串操作函数strlen和字符串格式符%s输出b时,系统会一直往后找,直到找到一个'\0'时,系统便认为,这就是字符串结束的地方,故,输出的字符串长度和字符串本身都是错误的。
b除了所以与a相同的初始化方式,或者应该用下面的语句:
b={'a','b','w','f','\0'};
就能成为字符串了。
右图的程序a的初始化赋值仍然是字符串,所以它的输出也是正确的。而b的初始化使b成为一个“字符数组”,它的最后没有字符串结束符,系统也不会主动加上。所以,当后面你用字符串操作函数strlen和字符串格式符%s输出b时,系统会一直往后找,直到找到一个'\0'时,系统便认为,这就是字符串结束的地方,故,输出的字符串长度和字符串本身都是错误的。
b除了所以与a相同的初始化方式,或者应该用下面的语句:
b={'a','b','w','f','\0'};
就能成为字符串了。
展开全部
strlen函数计算的是从形参开始到'\0'的有效字符个数
而数组b定义时,数组大小只有4,所以这里明显是越界访问了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个需要解释局部变量的栈的保存方式了。
首先 a[]= "abcd"; 这里初始化相当于 a[]= {'a','b', 'c','d', '\0'}
strlen是从开头直接到'\0' 为止。
然后,a保存在栈里,站了5个字节;b继续被压栈,但保存的只有4个字节。
因为栈是自下往上的存储方式,因此b其实在a的前面因此从内存角度看保存的样子是
b(四个字节)b(五个字节)
首先 a[]= "abcd"; 这里初始化相当于 a[]= {'a','b', 'c','d', '\0'}
strlen是从开头直接到'\0' 为止。
然后,a保存在栈里,站了5个字节;b继续被压栈,但保存的只有4个字节。
因为栈是自下往上的存储方式,因此b其实在a的前面因此从内存角度看保存的样子是
b(四个字节)b(五个字节)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询