【C】Tutorial C 04 基本输入输出

输出单个字符

    putchar('a'); // 字符输出函数,其功能是在终端(显示器)输出单个字符。

    putchar('\n'); // 支持转义换行

    putchar(77); // 可以直接注入ASCII的字符值

获取控制台输入的字符

    char character = getchar(); // 接收用户从键盘上输入的一个字符,会以返回值的形式返回接收到的字符
putchar(character);

格式化输出

printf函数叫做格式输出函数,其功能是按照用户指定的格式,把指定的数据输出到屏幕上

printf函数的格式为: 

printf(“格式控制字符串”,输出表项); 

其中格式控制字符串用来说明输出表项中各输出项的输出格式(好比我要吃苹果,告诉printf是做成罐头吃还是直接吃)。

输出表项列出了要输出的项,各输出项之间用逗号分开。

输出表项也可以没有,则表示输出的是格式字符串本身。 

格式控制字符串有两种:格式字符串和非格式字符串。

非格式字符串在输出的时候原样打印;

格式字符串是以%打头的字符串,在”%”后面跟不同格式字符,用来说明输出数据的类型、形式、长度、小数位数等。

格式字符串的形式为: % [输出最小宽度] [.精度] [长度] 类型 

例如:

  %d格式符表示 用十进制整形格式输出。

  %f表示用实型格式输出,

  %5.2f 格式表示输出宽度为5(包括小数点),并包含2位小数。

常用的输出格式及含义如下:

#include<stdio.h>
int main()
{
    int a=12;
    float b=3.1415;
    char c='A';
    printf("%d\n",a); //默认的整数形式输出,包括负整数
    printf("o%o\n",a); //按照八进制输出
    printf("0x%x\n",a);  //按照十六进制输出
    printf("%3.2f\n",b);  // 按Float浮点数
    printf("%c\n",c);  // 单个字符输出
    getchar();
    return 0;
}

【*】修饰符在printf()中的用法:

假如您不想事先指定字段宽度,而是希望由程序来制定该值,

那么您可以在字段宽度部分使用*代替数字来达到目的,但是您也必须使用一个参数来告诉函数宽度的值是多少。

具体的说,如果转换说明符为%*d,那么参数列表中应该包括一个*的值和一个d的值,来控制宽度和变量的值。

该技术也可以和浮点值一起使用来指定精度和字段宽度。 

/*使用可变宽度输出字段*/
#include<stdio.h>
int main(void)
{
    unsigned width,precision;
    int number = 256;
    double weight = 25.5;
    printf("Please input number's width:\n");
    scanf("%d",&width);
    printf("The number is: %*d\n",width,number);
    printf("Then please input width and precision:\n");
    scanf("%d %d",&width,&precision);
    printf("Weight = %*.*f\n",width,precision,weight);
    return 0;
}

关于printf()的返回值

printf函数的返回值是返回所打印的字符的数目。

如有输出错误,那么printf()会返回一个负数(printf()的一些老版本会有不同的值)。

格式化输入函数scanf

scanf函数称为格式输入函数,即按照格式字符串的格式,从键盘上把数据输入到指定的变量之中。

Scanf函数的调用的一般形式为: 

scanf(“格式控制字符串”,输入项地址列表); 

其中,格式控制字符串的作用与printf函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。

地址表项中的地址给出各变量的地址,地址是由地址运算符”&”后跟变量名组成的。 

Scanf 函数中格式字符串的构成与printf函数基本相同,但使用时有几点不同. 

- 1、格式说明符中,可以指定数据的宽度,但不能指定数据的精度。

例:

float a;
scanf(“%10f”,&a);  //正确
scanf(“%10.2f”,&a); //错误

- 2、输入long类型数据时必须使用%ld,输入double数据必须使用%lf或%le。 

- 3、附加格式说明符”*”使对应的输入数据不赋给相应的变量。 

scanf()函数所用的转换说明符与printf()所用的几乎完全相同。

主要区别在于printf()把%f、%e、%E、%g、%G同时用于float类型和double类型,

而scanf()只是把他们用于float类型,而用于double类型时要求使用l(字母l)修饰符。

【*】修饰符在scanf中()的用法:

*在scanf()中提供截然不同的服务,当把它放在%和说明符字母之间时,它使函数跳过相应的输入项目。

请参考程序事例:

/*用*跳过scanf接收的数字*/
#include<stdio.h>
int main(void)
{
        int num;
        printf("Please enter three number:\n");
        scanf("%*d %*d %d",&num);
        printf("The last number is %d\n",num);
        return 0;
}

关于scanf()的返回值

scanf() 函数返回成功读入的项目的个数。

如果它没有读取任何项目(比如它期望接收一个数字而您却输入的一个非数字字符时就会发生这种情况),scanf()返回0。 

当它检测到“文件末尾”(end of file)时,它返回EOF(EOF在是文件stdio.h中的定义好的一个特殊值,一般,#define指令将EOF的值定义为-1)。

当您学过循环之后,或在参加ACM这样的比赛及使用在线评测系统的时候会经常用到这种写法。


https://www.dotcpp.com/course/12

猜你喜欢

转载自www.cnblogs.com/mindzone/p/12913488.html