c语言字符串定义是存入字符的数组。

定义一个数组,数组里存放元素为字符串各个字符+'\0',其中'\0'为码0值,编译器会自动在字符串的末尾添加此值。
在定义这个数组时,指定数组的大小为6,也就是说需要申请6个字节的存储空间,而在等号右侧的双引号中我们却只书写了5个字符。这并不是笔误,C语言规定当使用双引号定义字符串时以'\0'作为这个字符串的结束标志符,也就是说这个字符串一共有6个字符。
在c 语言中,将字符串作为字符数组来处理。(c++中不是)在实际应用中人们关心的是有效字符串的长度而不是字符数组的长度,例如,定义一个字符数组长度为100,而实际有效字符只有40个,为了测定字符串的实际长度,C 语言规定了一个“字符串结束标志”,以字符'\0’代表。
C语言采用字符数组储存字符串,在从字符数组中读取字符串时,计算机是按照顺序来读取的,当然如果没有结束标记,计算机就会一直的读取下去(那么一直读取,然后超出了所定义的数组范围。
1.1、什么是字符串常量
C 语言虽然没有字符串类型,但是 C语言提是存在字符串这个概念的,也就是字符串常量:以 NUL 字节结尾的 0 个或多个字符组成的序列。字符串常量是不可被修改的,一般用一对双引号(" ")括起的一串字符来表示字符串常量,如:
字符串常量可以为空,如""就是一个空的字符串常量,但是即使为空,还是存在一个终止符 NUL 的。(在 C 语言中,常用转义字符 \0 来表示 NUL)
1.2、字符串常量与指针
1. C语言中字符串的表示方式有两种:字符指针和字符数组
2. 字符指针表示字符串
从编译器角度分析:
例如:char *p = "linux" ; p是字符指针,"linux" 字符串本身,当编译器遇到这种字符串表示时,会将指针和字符串本身分开处理, 字符指针p是一个变量,将其放在栈上,而字符串本身 "linux" 则被存放在代码段,其首地址赋给p。
例如:char *p = "linux" ; 首先对字符指针p,会为其在栈上开辟一个4字节的空间,而"linux" 字符串本身,会在代码段为其开辟一个6字节的存储空间,将该存储空间的首地址赋值给p。
3. 字符数组表示字符串
从编译器角度分析:
例如:char a[] = "linux" ; a是字符数组,编译器会将其放在栈上,而"linux" 字符串本身却只存在于编译器中,即编译器只是将它用来初始化字符数组a后丢弃掉。
例如:char a[] = "linux" ; 定义了一个字符数组a,在栈上开辟一个6字节的存储空间,而"linux"字符串本身由于只存在于编译器中,所以不需要为此开辟存储空间。