float在c语言中的意思,详解浮点数在c语言中的使用方法和注意事项

I/O是计算机系统中的一个核心组成部分,它负责处理计算机系统中的输入(Input)和输出(Output)数据。计算机系统通过接收输入数据,经过中央处理器(CPU)的运算处理,最终将处理结果输出。

因此,I/O是一个至关重要的概念。对于刚开始学习C语言编程的人来说,我们可以由浅入深地学习。在前面,我们已经讲解了终端的I/O操作。现在,我们将编写一个程序,该程序能够从终端接收用户的输入数据,并将其再次输出到终端。

C语言提供了scanf函数,用于向程序输入数据。用户可以通过键盘,向指定的变量输入数据。而printf函数则用于向终端输出数据。scanf函数从终端接收(获取)用户的输入数据。

scanf函数的格式如下:

int scanf (const char* format_str, addr list);

函数分析:

(1) 参数 format_str 是控制格式输入的字符串;

(2) 参数 addr list 是变量地址列表,是需要获取用户输入数据的变量地址列表;

(3) 函数的返回值是int类型,如果调用成功,则返回addr list指定的参数个数,如果调用失败,返回-1值。以下是一个程序测试的例子:

程序运行结果如下:

可以看到,对应输入格式:

scanf(“%d,%d,%d”, &a, &b, &c);

在%d与%d之间,使用逗号“,”分隔开,所以,在输入数据的时候,使用逗号“,”分隔。同理,对于:

scanf(“%d;%d;%d”, &a, &b, &c);

在输入数据的时候,使用分号“;”分隔开。

在printf函数中,输出float和double类型的数据,使用%f格式输出。但是,在scanf函数中,读取输入float和double类型的数据时,需要注意:

(1) float类型数据,使用 %f 格式输入;

(2) double类型数据,使用 %lf格式输入;在%和f之间添加字母“l”;

程序测试的例子如下:

程序运行结果如下:

可以看到,在编译的时候,就已经提示“warning 警告”:第12行代码,即:

scanf(“%f”, &b);

第二个参数b是double类型,但是,格式控制输入字符串使用‘%f’表示float类型,所以,提示警告。输入数据的时候,float类型,使用%f格式输入。double类型,应该使用%lf格式输入。

那么,我们在输入数据的时候,也可以看到,在第二次输入时,输入1.2,输出0.000000,运行出错了。所以,给double类型变量输入数据的时候,必须使用%lf格式,输出的时候,可以使用%f格式。

C语言提供putchar函数,用于向终端输出一个字符;getchar函数,可以从终端接收用户输入的一个字符。函数的定义如下:

void putchar(char c);

函数说明:把字符c输出到终端屏幕中。

int getchar(void);

函数说明:从终端接收用户的输入,获取一个字符,通过函数的返回值返回。

程序测试的例子如下:

程序运行结果如下:

可以看到,通过putchar函数,可以输出一个字符常量和字符变量。

当我们想让程序从终端接收用户输入一个字符时,可以使用scanf函数;也可以使用getchar函数。以下是一个程序测试的例子:

程序运行结果如下:

可以看到,当我们输入字符“F”之后,按下回车键,表示结束输入。然后,再输出变量c中的值。可以看到,用户输入的字符“F”被存放到变量c中。

注意:getchar函数的返回值是int类型,所以,我们应该定义int类型变量来接收返回值。那么,使用putchar函数输出int类型变量的时候,就截取最低的一个字节,这一个字节存放的就是getchar函数获取到的数据。

C语言提供了puts函数,用于向终端输出一串数据。gets函数,可以从终端接收用户输入的字符串。这两个函数的使用需要数组和字符串的基础知识才能更好地理解,所以,在介绍了数组和字符串之后再介绍该函数的使用。

本章节我们介绍了C语言对标准终端的I/O操作。

可以使用printf()函数,输出信息到标准输出终端。可以使用scanf()函数,从标准输入终端获取用户输入的信息。

后续随着课程的深入学习,学习到更多、更复杂的系统I/O知识。例如磁盘文件的I/O读写操作,串口、网络socket通信等高级的I/O应用。

在后续的“Linux系统编程”课程,我们学习Linux系统下串口通信、网络通信等操作,就是一种I/O操作。涉及到I/O操作,我们就会讲解“阻塞和非阻塞”的通信模式。

读者要仔细分析,掌握好每一个知识点,然后,自己总结出对该知识点的理解。自己总结出来的知识,理解才深刻,才是自己掌握的知识。