【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串

简介: 本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]="hello"`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。

1字符数组初始化及传递

字符数组的定义方法与前面介绍的一维数组类似.例如,

char c[10];

字符数组的初始化可以采用以下方式.
(1)对每个字符单独赋值进行初始化.例如,

c[O]='I';c[1]=' ' ;c[2]='a';c[3]='m';c[4]=' ';c[5]='h';c[6]='a';c[7]='p';c[8]='p';c[9]='y';

(2)对整个数组进行初始化.例如,

char c[10]='T",'a','m';'h','a','p';'p','y}

但工作中一般不用以上两种初始化方式,因为字符数组一般用来存取字符串.通常采用的初始化方式是char c[10]="hello".因为C语言规定字符串的结束标志为'0',而系统会对字符串常量自动加一个o',为了保证处理方法一致,一般会人为地在字符数组中添加'\0',所以字符数组存储的字符串长度必须比字符数组少1字节.例如, char c[10]最长存储9个字符,剩余的1个字符用来存储'\0'.

【例】字符数组初始化及传递

#include <stdio.h>
vold print(char c[])
(
    int  i=0;
    while(c[i])
    {
   
        printf("%c" ,c[i]);
    i++;
)
    printf("\n"");
}
//字符数组存储字符串,必须存储结束符'\O'
int main()
{
   
    char c[5]={
   h,e,T,T,o;
    char d[5]="how";
    printf("%s\n",c);//会发现打印了乱码
    printf("%s\n",d);
    print(d);
    return 0;
}

为什么会打印出乱码?

hello后面没有'\0',打印字符串读取时未结束

为什么改成"hello"也不行

char c[5]="hello";正常是应该加上一个'\0',但是因为数组长度不够.无法填上,所以改成char c[6]就可以了


2.scanf 读取字符串

int main()
{
   
    char c[10];
    char d[10l;
    scanf("%s",c);
    printf("%s\n",c);
    scanf("%s%s",c,d);
    printf("c=%s,d=%s\n",c,d);
return O;
}

scanf通过%s读取字符串,对c和d分别输入"are"和"you”(中间加一个空格) , scanf在使用%s读取字符串时,会忽略空格和回车(这一点与%d和%f类似).
输入顺序及执行结果如下.

hello
hello
are you
c=are, d=you

相关文章
|
1天前
|
C语言 C++
【C语言】解决不同场景字符串问题:巧妙运用字符串函数
【C语言】解决不同场景字符串问题:巧妙运用字符串函数
|
1天前
|
存储 编译器 C语言
【C语言】数组(一维、二维数组的简单介绍)
【C语言】数组(一维、二维数组的简单介绍)
|
27天前
|
存储 编译器 C语言
【C语言基础考研向】09 一维数组
数组是一种有序集合,用于存储相同类型的数据,便于统一操作与管理。例如,将衣柜底层划分为10个格子存放鞋子,便于快速定位。在C语言中,数组定义格式为 `类型说明符数组名[常量表达式];`,如 `int a[10];` 表示定义了一个包含10个整数的数组。数组初始化时可以直接赋值,也可以部分赋值,且数组长度必须固定。数组在内存中连续存储,访问时需注意下标范围,避免越界导致数据异常。数组作为参数传递时,传递的是首地址,修改会影响原数组。
|
1天前
|
存储 编译器 C语言
【C语言篇】数组和函数的实践:扫雷游戏(附源码)
【C语言篇】数组和函数的实践:扫雷游戏(附源码)
7 0
|
1天前
|
编译器 C语言
【C语言】指针篇-深入探索数组名和指针数组- 必读指南(2/5)
【C语言】指针篇-深入探索数组名和指针数组- 必读指南(2/5)
|
存储 固态存储 程序员
考研计算机组成原理总结(5)
考研计算机组成原理总结(5)
645 0
|
11月前
|
存储 算法 调度
【考研必备】解开“黑匣子”的神秘面纱,透视数字世界底层实现过程(计算机组成原理)(下)
【考研必备】解开“黑匣子”的神秘面纱,透视数字世界底层实现过程(计算机组成原理)
|
4月前
|
存储 知识图谱
【计算机组成原理】指令系统&考研真题详解之拓展操作码!
也就是说 “其中三地址指令29”条这句话,完全可以翻译成“三地址这种类型的指令一共能有29种不同的可能性” 这样说就清晰多 因为这就意味着 我们需要用若干个字节 来表示这29种不同的可能性 然后又已知每一个字节位能表示的可能性是2种(0/1),那么我们想有多少个字节可以表示29种不同的可能呢?最少5种 (因为2的4次方=16<29),2^5=32>29,也就是说有32-29=3种可能性是不在三地址指令这种类型的指令集里面的,所以这3 种余出来的可能性要被利用 就在下一种 “二地址指令集”中利用到
45 0
|
4月前
计算机网络——物理层相关习题(计算机专业考研全国统考历年真题)
计算机网络——物理层相关习题(计算机专业考研全国统考历年真题)
37 0
|
11月前
|
存储 安全 网络安全
【考研必备二】解开“黑匣子”的神秘面纱,透视数字世界底层实现过程(计算机组成原理)(下)
【考研必备二】解开“黑匣子”的神秘面纱,透视数字世界底层实现过程(计算机组成原理)