c语言新手注意事项
1.第一点
*c库函数---printf*
第二点
第三点
写代码需要注意的地方
(小技巧)打印较长的字符串
1.第一点
c库函数—printf
api文档的描述:printf()函数根据format(格式)给出的格式打印输出到STDOUT(标准输出)和其它参数中
printf()函数的调用格式为:
printf("", );
下面是 printf() 函数的声明。
int printf(const char *format, ...)
format – 这是字符串,包含了要被写入到标准输出 stdout 的文本。它可以包含嵌入的 format 标签,format 标签可被随后的附加参数中指定的值替换,并按需求进行格式化。format 标签属性是 %[flags][width][.precision][length]specifier
从前往后讲,先讲flags(标识符)
flags
意义
-
在给定的字段宽度内左对齐,默认是右对齐
+
在数字前面显示+或-号,普通情况下只有负数有-号
#
1.与 o、x 或 X 说明符一起使用时,非零值前面会分别显示 0、0x 或 0X2与 e、E 和 f 一起使用时,会强制输出包含一个小数点,即使后边没有数字时也会显示小数点。默认情况下,如果后边没有数字时候,不会显示显示小数点。3与 g 或 G 一起使用时,结果与使用 e 或 E 时相同,但是尾部的零不会被移除。
0
在指定填充的数字左边放置0,而不是空格
width(宽度)
width
意义
数字
要输出的字符的最小数目。如果输出的值短于该数,结果会用空格填充。如果输出的值长于该数,结果不会被截断。
*
宽度在 format 字符串中未指定,但是会作为附加整数值参数放置于要被格式化的参数之前。来自
.precision(精度)
.precision
意义
.数字
对于整数说明符(d、i、o、u、x、X):precision 指定了要写入的数字的最小位数。如果写入的值短于该数,结果会用前导零来填充。如果写入的值长于该数,结果不会被截断。精度为 0 意味着不写入任何字符。对于 e、E 和 f 说明符:要在小数点后输出的小数位数。对于 g 和 G 说明符:要输出的最大有效位数。对于 s: 要输出的最大字符数。默认情况下,所有字符都会被输出,直到遇到末尾的空字符。对于 c 类型:没有任何影响。当未指定任何精度时,默认为 1。如果指定时不带有一个显式值,则假定为 0。
*
精度在 format 字符串中未指定,但是会作为附加整数值参数放置于要被格式化的参数之前。
length(长度)
length
意义
h
参数被解释为短整型或无符号短整型(仅适用于整数说明符:i、d、o、u、x 和 X)。
l
参数被解释为长整型或无符号长整型,适用于整数说明符(i、d、o、u、x 和 X)及说明符 c(表示一个宽字符)和 s(表示宽字符字符串)
L
参数被解释为长双精度型(仅适用于浮点数说明符:e、E、f、g 和 G)。
specifier(格式字符)
specifier
意义
d
以十进制输出带符号整数
o
以八进制输出无符号整数
x
以16进制输出无符号
u
以十进制输出无符号整数
f
输出单,双精度浮点数(在scanf中输入double浮点数需要使用lf)
e
以指数形式输出单,双精度的浮点数
g
以e或f中较短的方式输出单,双精度的浮点数
c
输出单个字符
s
输出字符串
p
输出指针
第二点
1 .short int适用于int较小的场合,节省储存空间,unsigned int只适用于非负值,16位unsigned int取值范围为0到65535,而不是-32768到32768.无符号可以表示更大的数。
2 .打印unsigned int类型的值,使用%u转换说明;打印long类型的值使用%ld转换说明。对于short类型%hd显示short类型的整数。*
3 .char类型用于储存字符,c语言中,用单引号括起来的单个字符被称为字符常量,而双引号则是字符串。
4 .转义符号不一定在所有显示设备上都起作用,例如换页符和垂直制表符在pc屏幕上会变成奇怪的符号,光标也不会移动,只有将其输入到打印机上才会起作用。
5 .浮点型常量,正数可以省略。可以没有小数点(如2E5)或指数部分如19.89,单不能同时省略两者。可以省略小数部分如3.E16或整数部分如(.45E-6),不要在浮点型常量中加空格。
6 .\r与回车的区别,前者是让光标回到行的起点,后者包括前者,而且还会换行
7 .浮点数:计算机把浮点数分成小数部分和指数部分储存。而且分开储存
8 .整数溢出:当整数达到它能表示的最大整数时,会重新从起点开始
第三点
写代码需要注意的地方
1 .c中的字符串一定以空字符结尾,所以40个储存单元的数组只能存39个字符
2 .注意scanf()只读取空格之前的,例如Ms Li,scanf只会读取Ms.
3 .'A’与"A"不同前者只表示A,后者表示A\0,后者表示两个字符
4 .养成大写常量的好习惯
5 .#define TOSE =20这个是错误的,因为TOSE表示的是=20而不是20
6 .scanf读取基本变量类型,在变量名前加上一个&
scanf把字符串读入字符数组中,不用&
7 .scanf中的%c scanf("%c",&ch)从输入中的第一个字符开始提取,而scanf(" %c",&ch)则从第一个非空白字符开始读取(黄色区域有个空格)
8 .++前缀和后缀的区别
q=2*++a 首先,a递增1;然后,2乘以a,并将结果赋值给q
q=2*a++ 首先,2乘以a,并将结果赋值给q,然后a递增1
9 .可以通过a-(a/b)*b来计算a%b
10 .如果一个变量出现在一个函数的多个参数中时,不要将增量或者减量运算符用在它上面
11 .当一个变量多次出现在一个表达式里时,不要将增量或减量运算符运用在它的上面
12 .scanf输入时double类型要用%lf而不能是%f
13 .头文件stdbool.h可以将_Bool用bool表达
14 .#include //将&&改为and,||改为or,!改为not(详细请自行查阅c语言API文档)
15 .(重点)使用缓冲输入的系统中,数值与字符混合输入问题:数值会跳过换行符和空格,但是字符不会,例如在%s中输入98,不仅仅提交了98,而且还提交了一个换行符,这个换行符会留在输入序列中,成为下一个读取的值,所以在字符输入之前如果输入了数字,就应该在处理字符之前删除换行符代码,我的另一篇文章中有解决方法在这里
16 .当初始化列表中的值少于数组元素个数时,编译器会把剩余的元素都初始化为0
17 .不初始化数组,调用数据时,输出为随机值
18 .days为一个数组,运算符 sizeof 给出其后对象或类型的大小(以字节为单位)。因此 sizeof days 是 整个数组的大小(字节为单位),sizeof days[0] 是一个元素癿大小(字节为单位)。 整个 数组的大小除以单个元素的大小就是数组中元素的数目
19 .汉字的ACSII码为负数,且汉字为两个字节
20 .定义初始化项目有两个重要特性。第一,如果在一个指定初始化项目后紧跟有不止一个值,例如在序列 [4]=31,30,31 中这样,则返些数值将用会对后续的数组元素初始化。也就是说,当31 赋给 days[4]之后,紧接着 30 和 31 分别赋值给 days[5] 和 days[6]。
21 .C不允许把数组作为一个整体来赋值
22 .数组名同时也是该数组首元素的地址。也就是说, 如果 flizny 是一个数组,下面的代码是正确的: flizny == &flizny[0] //数组名是该数组首元素的地址
23 .在指针前运用运算符 * 就可以得到该指针所指向的对象的数值
24 .对指针加 1 ,等价于对指针的值加上它指向的对象的字节大小
25 .一元运算符 * 和 ++ 具有相等的优先级,但它在结尾时是从右向左进行的。
26 .
##第四点
(小技巧)打印较长的字符串
1.使用多个printf()
2.用反斜杠\和Enter键,但是下一行代码必须从最左边开始,否则缩进的空格将会包括到字符串中
3.将一句话用多个双引号连接
(摘自C pirmer plus第六版)