前言碎语:
虽然C没有定义字符串这种数据类型,但字符串文字量所具有的的优良性质(主要是关于指针的),使得对字符串的操作变得极为让人觉得得心应手。在编译期间,字符串文字量的尾部会被编译器加上一个字符'\0',然后按照数组的存储方式存储。每个字符会被转换成对应的ASCII码值,需要注意的是'\0'的值为0,ASCII码值为0x00。
字符串文字量自身就可以被视为一个字符数组,如下面的字符串文字量:
"Jimmy"
这个字符串文字量就可以视为一个数据类型为char [6]的数据。这个数据作为左值的时候表示其所占据的内存,作为右值的时候表示指向该字符串文字量的char *类型的指针。可用以下代码进行验证:
printf("\"Jimmy\" = %p\n", "Jimmy" );
printf("&\"Jimmy\" + 1 = %p\n", &"Jimmy" + 1);
printf("sizeof \"Jimmy\" = %d\n", sizeof "Jimmy" );
更方便的是,可以用一个字符数组将字符串文字量存储起来,或者使用一个字符指针(character pointer)指向这个字符串文字量,例子如下:
char str[10] = "abcdef123";
char *str_p = "abcdef123";
由于数组名也是指针,并且和str_p一样,指向这个字符串的第一个字符,所以可以很方便的操作字符串。
问题引入:输出一个字符串文字量第二个字符之后的所有字符
样例示意:
input: "AB520"
output:"520"
解题思路:
(1)字符串文字量采用数组str存储,将str + 2 作为output()函数的实参,从当前指针所指向的位置开始逐个输出字符,直到遇到第一个null character '\0'。
(2)第二种方法是用指针str_p指向字符串文字量,采用%s这样的输出格式控制符,就可以从任意位置对字符串进行输出。
完整代码(1):
/*问题:输出一个字符串文字量第二个字符之后的所有字符
Written by : Jimmy Tung
Date : 2020.04.12
*/
#include <stdio.h>
#include <stdlib.h>
#define MAXSIZE 16 //字符数组的大小
void output( const char *); //输出结果
int main(void)
{
char str[MAXSIZE] = "ABabcdefg123456";
output( str + 2 ); //将指向第三个字符的指针作为实参
system("PAUSE");
return 0;
}
//输出结果
void output( const char *str_p)
{
while( *str_p != '\0')
{
printf("%c", *str_p);
str_p++;
}
}
完整代码(2):
/*问题:输出一个字符串文字量第二个字符之后的所有字符
Written by : Jimmy Tung
Date : 2020.04.12
*/
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
char *str_p = "ABabcdefg123456";
printf("%s\n", str_p + 2);
system("PAUSE");
return 0;
}
将两个方法写进一个程序中,结果输出如下:
abcdefg123456
abcdefg123456
请按任意键继续. . .
Process returned 0 (0x0) execution time : 7.769 s
Press any key to continue.
要点复盘:
第二种方法之所以能够实现,笔者认为是该字符串文字量虽然被赋给了指针str_p,但实质上该指针并没有表示整个字符串文字量的权利,它只表示该字符串文字量的第一个字符,即该指针实际上只是指向该字符串文字量的第一个字符。用以下代码可以验证。
char *p = "ABC";
printf("sizeof *p = %d\n", sizeof *p);
printf("%c\n", *p);