您的位置:首页 > 编程语言 > C语言/C++

C语言 字符数组赋值的方法 整理

2015-03-15 18:38 393 查看
部分转载,其他根据自己整理的略作修改

char a[10];

怎么给这个数组赋值呢?

1、定义的时候直接用字符串初始化

char a[10]="hello";

注意:不能先定义再给它赋值,如char a[10]; a[10]="hello";这样是错误的!只有定义初始化是才能这样赋值

2、对数组中字符逐个赋值

char a[10]={'h','e','l','l','o'};

3、利用strcpy,这个比较值得推荐的方法

char a[10]; strcpy(a, "hello");

易错情况:

1、char a[10]; a[10]="hello";//一个字符怎么能容纳一个字符串?况且a[10]也是不存在的!

这个最常见错误:

2、char a[10]; a="hello";//这种情况容易出现,a虽然是指针,但是它已经指向在堆栈中分配的10个字符空间,现在这个情况a又指向数据区中的hello常量,这里的指针a出现混乱,不允许!会出现const char无法转换为 char类型

3、补充一点 char *a; a="hello";//这种情况是正确的。因为定义时a还没有指向的空间,不存在指针指向混乱的情况。

还有:不能使用关系运算符“==”来比较两个字符串,只能用strcmp() 函数来处理。

C语言的运算符根本无法操作字符串。在C语言中把字符串当作数组来处理,因此,对字符串的限制方式和对数组的一样,特别是,它们都不能用C语言的运算符进行复制和比较操作。

直接尝试对字符串进行复制或比较操作会失败。例如,假定str1和str2有如下声明:

char str1[10], str2[10];

利用=运算符来把字符串复制到字符数组中是不可能的:

str1 = "abc"; //会报错,原理同上面分析的

str2 = str1; //不能直接赋值

C语言把这些语句解释为一个指针与另一个指针之间的(非法的)赋值运算。

但是,使用=初始化字符数组是合法的:

char str1[10] = "abc";

这是因为在声明中,=不是赋值运算符。

试图使用关系运算符或判等运算符来比较字符串是合法的,但不会产生预期的结果:

if (str1==str2) ...

这条语句把str1和str2作为指针来进行比较,而不是比较两个数组的内容。因为str1和str2有不同的地址,所以表达式str1 == str2的值一定为0。

strcpy memcpy memset 三个函数的说明

Linux中实现:

void* memcpy(void*dest,constvoid*src,size_tcount)

{

assert(dest!=NULL && src!=NULL);

char* tmp=dest;

const char* s=src;

for(size_t i=0;i<count;i++)

{

tmp[i]=s[i];

}

return dest;

}

strcpy和memcpy主要有以下3方面的区别。

1、复制的内容不同。strcpy只能复制字符串,而memcpy可以复制任意内容,例如字符数组、整型、结构体、类等。

2、复制的方法不同。strcpy不需要指定长度,它遇到被复制字符的串结束符"\0"才结束,所以容易溢出。memcpy则是根据其第3个参数决定复制的长度。

3、用途不同。通常在复制字符串时用strcpy,而需要复制其他类型数据时则一般用memcpy

void *memset(void *s, int ch, size_t n);

函数解释:将s中前n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。

memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: