这是越界访问了吗?
题目描述:编写一个程序,将两个字符串连接起来,不要用 strcat 函数。代码如下:
#include <stdio.h>
void stringContact(char *str1, char *str);
void stringContact(char *str1, char *str)
{
int i;
for(i=0;*(str1+i)!='\0';i++)
{
;
}
for(int j=0;*(str+j)!='\0';j++,i++)
{
*(str1+i)=*(str+j);
}
*(str+i)='\0';
printf("%s",str1);
}
void main()
{
char *str1="ABCD",*str="EFG";
stringContact(str1,str);
}
是的,因为char *str1="ABCD" 定义时就已经将长度固定了,要不然就申请新空间,要不用一个临时变量来存放 #include <stdio.h>
#include<stdlib.h>
void stringContact(char *str1, char *str);
void stringContact(char *str1, char *str)
{
int i;
char *p;
for(i=0;*(str1+i)!='\0';i++)
{
*(p+i) = *(str1+i) ;
}
for(int j=0;*(str+j)!='\0';j++,i++)
{
*(p+i) =*(str+j);
}
*(p+i)='\0';
printf("%s",p);
}
int main()
{
char *str1="ABCD",*str="EFG";
stringContact(str1,str);
return 0;
} 本帖最后由 jackz007 于 2021-11-1 01:16 编辑
是的
char *str1="ABCD"
这样定义的 str1[] 只有 5 个字符的存储空间,如果把 str 的 "EFG" 拼接进来,实际需要的存储空间为 8 个字符,显然,这样使用 str1 必然是会越界的。
#include <stdio.h>
char * stringContact(char s1[] , char s2[])
{
int i , j ;
for(i = 0 ; s1 ; i ++) ;
for(j = 0 ; s2 ; j ++) s1 = s2 ;
s1 = '\0' ;
return s1 ;
}
int main(void)
{
char s1 = "ABCD" , s2[] = "EFG" ; // s1 必须定义足够大的存储空间,以便可以容纳拼接后的字符串;
printf("%s\n" , stringContact(s1 , s2)) ;
} 刚开始的指针变量没有初始化吧 这么多vip
页:
[1]