////////// 如果通过一个地址返回呢?该怎么处理啊?
#include
#include
#define M 3
#define N 30
void fun(char a[M][N], char *b)
{
for (int i = 0; i< M; ++ i ){
strcat( b, a[i]); // 这样子使用.
}
}
int main(int argc, char ** argv )
{
char w[M][N]={"AAAA","BBBBBBB","CC"}, a[100];
int i ;
printf("The string: \n");
for(i=0; i
}
printf("\n");
//bzero(a, sizeof(a));
memset(a,0, sizeof(a));
fun(w,a);
printf("The A string: ---------> \n");
printf("a = [%30s]\n",a);
return 0;
}
////////////////////////////// 为什么结果出现错误 无法运行??
// 因为 b 没有给它申请内存, 是个未定义的指针. 肯定会出错.
// 用 strcat 时, 一定要确保, 目标内存的大小有足够的空间存放合并后的字符串.
// 如果空间太小, 就会出现内存溢出.
#include
#include
int main( int argc, char ** argv )
{
char *b = NULL;
char a[3][20]={"AAAA","BBBBBBB","CC"};
int len = strlen(a[0]) + strlen(a[1]) + strlen(a[2]) + 1 ; //目标字符串长度.
b = (char *)malloc( len ) ;
memset(b, 0, len); // 清0 ;
strcat(b,a[0]);
strcat(b,a[1]);
strcat(b,a[2]);
printf("%s",b);
free(b); // 要记得 free 哦.
b = NULL;
return 0;
}
#include
#include
main()
{
char strDes[N]= "kkkjdah", strSor[N]="sdasdaaa";
strcat(strSor,strDes);//字符合并函数
puts(strDes);
puts(strSor);//打印合并后的字符串。
}
看好
char a[]="AAAA";
char b[]="BBBBBBB";
char c[]="CC";
strcat(a,b);//第一次把b[]的加到a[]中
strcat(a,c);//第二次再把c[]的加到a[]中,a[]就是所要的结果了
#include
main()
{
char d[20]="AAAA";
char *s1="BBBBBBB";
char *s2="CC";
strcat(d,s1);
strcat(d,s2);
printf("%s",d);
return 0;
}