c语言的新手注意事项

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 <iso646.h>//将&&改为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第六版)
发布了8 篇原创文章 · 获赞 4 · 访问量 440

猜你喜欢

转载自blog.csdn.net/iohappyoi/article/details/102528041