c语言2E16什么意思,c语言的新手注意事项

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第六版)

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值