C学习笔记(四)字符串和格式化输入\输出
一、字符串
C没有字符串类型,而是把字符串存在char数组里,但是字符数组比字符串长度多1,因为最后一个是\0(空字符)
二、strlen()
#include <string.h>
以字符(char)为单位给出字符串的长度,不包括结尾的\0
printf("\"字符串和格式化输入输出\"的长度=%d\n",strlen("字符串和格式化输入输出"));
"字符串和格式化输入输出"的长度=33
UTF-8中汉字占3个字节
三、printf()
1、转化符
转换说明 | 输出 |
---|---|
%a | 浮点数、十六进制数字和p-记数法(C99) |
%A | 浮点数、十六进制数字和p-记数法(C99) |
%c | 字符 |
%d | 有符号十进制数 |
%e | 浮点数、e-记数法 |
%E | 浮点数、e-记数法 |
%f | 浮点十进制数 |
%i | 有符号十进制数与%d相同 |
%o | 无符号八进制数 |
%p | 指针 |
%s | 字符串 |
%u | 无符号十进制数 |
%f | 使用十六进制数字0f的无符号十六进制整数 |
%F | 使用十六进制数字0F的无符号十六进制整数 |
%% | 打印% |
2、修饰符
修饰符 | 意义 |
---|---|
- | 打印的字符串左对齐 |
+ | 有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号 |
(空格) | 有符号的值若为正,则显示时带有前导空格(但不显示符号);若为负,则带减号符号。+标志会覆盖空格标志 |
# | 若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始 |
0 | 对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志 |
#include <stdio.h>
#include <stdlib.h>
#include <inttypes.h>
#include<complex.h>
#include <string.h>
#define PAGES 931
#define PAGES_NEGATIVE -34.45f
int main(void) {
printf("*%d*\n",PAGES);
printf("*%2d*\n",PAGES);
printf("*%10d*\n",PAGES);
printf("*%-10d*\n",PAGES);
printf("*%+d*\n",PAGES);
printf("*% d*\n",PAGES);
printf("*% f*\n",PAGES_NEGATIVE);
printf("*%#d*\n",PAGES);
printf("*%010d*\n",PAGES);
return EXIT_SUCCESS;
}
*931*
*931*
* 931*
*931 *
*+931*
* 931*
*-34.450001*
*931*
*0000000931*
修饰符 | 意义 |
---|---|
数字 | 字段宽度的最小值,如果该字段不能容纳要打印的数字或者字符串,系统会用更宽的字段 |
.数字 | 精度。对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。对于%g和%G转换,是有效位数的最大位数。对于%s转换,是将要打印的字符的最大数目。对于整数转换,是将要打印的数字的最小位数 |
h | 和整数转换符一起使用,表示一个short int或者unsigned short int类型的数值 |
hh | 和整数转换符一起使用,表示一个signed chart或者unsigned chart类型的数值 |
j | 和整数转换符一起使用,表示一个intmax_t或者uintmax_t类型的数值 |
l | 和整数转换符一起使用,表示一个long int或者unsigned long int类型的数值 |
ll | 和整数转换符一起使用,表示一个long long int或者unsigned long long int类型的数值(c99) |
L | 和浮点转换符一起使用,表示一个long double类型的数值 |
t | 和整数转换符一起使用,表示一个ptrdiff_t值(c99) |
z | 和整数转换符一起使用,表示一个size_t值(c99) |
3、printf()的返回值
返回所打印的字符的数目。如果出错,返回一个负数。
四、scanf()
scanf在开始读取输入以后,会在遇到的第一个空白字符(blank)、制表符(tab)或者换行符(\n)出停止读取
int age;
float assets;
char pet[30];
sacnf("%d %f",&age,&assets);
scanf("%s",pet);
scanf()函数使用空格(换行,制表符和空格)来决定怎样把输入分成几个字段。
printf()可以把%f,%e,%E,%g和%G同时用于float和double类型,而scanf()对于float能用%f,%e,%E,%g和%G,对于double用%l
转换说明符 | 含义 |
---|---|
%c | 字符 |
%d | 有符号的十进制整数 |
%e,%f,%g,%a | 浮点数(%a c99标准) |
%E,%F,%G,%A | 浮点数(%A c99标准) |
%i | 有符号的十进制整数 |
%o | 有符号的八进制整数 |
%p | 指针 |
%s | 字符串(输入的内容以第一个非空白字符作为开始,并且包含直到下一个空白字符的全部字符) |
%u | 无符号的十进制整数 |
%x,%X | 有符号的十六进制整数 |