字符串赋值的几种办法分类及常见错误总结

字符串的输入与赋值是非常容易搞混淆的一块,这里总结一下顺序存储的字符串输入方式:

一、栈内静态存储

1.定义时用字符串赋值

char s[15] = "helloworld";

不能先定义,然后赋值,如:

char s[10];
s = “helloworld”;

原因是s是指向一个栈区数组首元素的指针,不能给指针赋上字符串。
注意!C语言中字符串以字符 ‘\0’ 结尾,所以实际上上述数组存储的是:h,e,l,l,o,w,o,r,l,d,\0。看到的有10个字符,实际上还加上一个结尾 \0 表示串的终结,长度为11 。
若定义的数组时s[10],打印出来会在helloword后添加若干乱码,而且每次乱的都不一样。就是因为没读到终结符 \0 。

2.对数组中的字符逐个赋值

char s[15]={'h','e','l','l','o','w','o','r','l','d'};

3.使用strcpy()函数

char s[15];
strcpy(a, "helloworld");

4.从终端读入字符串
scanf:

char s[15];
scanf("%s", s);

这里的s是读入的整个一行,遇到空白字符,包括空格,制表符,换行符时会停止输入。
gets:

char s[15];
gets(s);

s同样代表一行,但是只在遇到换行符的时候停止读入。

二、堆中动态分配

和栈中类似,声明时有区别,其他都类似,因为不论堆还是栈,本质上还是顺序存储。

char* s = (char*)malloc(sizeof(char) * 15); 
strcpy(s, "helloworld");

强调一下,这里同样不允许这种赋值方式:
char* s = (char*)malloc(sizeof(char) * 15);
s = “helloworld”;

因为本质上字符串还是存在数组中,s是指向数组首元素的指针。就算是*s也是指该数组的第一个元素s[0]。

你可能感兴趣的:(字符串,c语言,数据结构)