linux c语言的格式化输入输出

        对于Linux c语言来说,格式化输入输出是很重要的,错误的输入输出格式可能导致你看不到自己想要的数据,比如当你想要显示字符串时,你在printf里却用了%d,结果是你看到的是字符串的ascii码,要想看字符串内容,你应该使用%c,今天我们就来讲讲linux c语言格式化输入输出的标准,同样我会把初学者经常犯的错误写在前面。
注意:
1、屏幕输入可以用char Rcode  scanf("%hhd",&Rcode),注意取地址符号&不要忘了写。
2、主函数结尾要加return 0,来表示程序是否运行成功,失败返回0。




格式化输入输出字符有:
%d 带符号十进制整数
%o 无符号八进制
%u 无符号十进制
%x 无符号十六进制
%f 显示十进制计数的浮点数
%e 指数形式显示浮点数
%c  字符形式
%s  字符串形式
%p  显示基地址









查看转义字符可使用手册  ---->  man ascii




   八进制  十进制 十六进制   目标字符


       007   7     07    BEL '\a' (bell)             
       010   8     08    BS  '\b' (backspace)        
       011   9     09    HT  '\t' (horizontal tab)  
       012   10    0A    LF  '\n' (new line)         
       013   11    0B    VT  '\v' (vertical tab)     
       014   12    0C    FF  '\f' (form feed)        
       015   13    0D    CR  '\r' (carriage ret)




char 字符变量 ---> ascii  ----> 本质是一个整形变量(-128 ~ 127)


格式字符用以指定输出项的数据类型和输出格式。
  ①d格式:用来输出十进制整数。有以下几种用法:
 %d:按整型数据的实际长度输出。
 %md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
 ②o格式:以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。
 例:
    main()
    { int a = -1;
      printf("%d, %o", a, a);
    }
   运行结果:-1,177777
   程序解析:-1在内存单元中(以补码形式存放)为(1111111111111111)2,转换为八进制数为(177777)8。




 ③x格式:以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。
 ④u格式:以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。
 ⑤c格式:输出一个字符。
 ⑥s格式:用来输出一个串。有几中用法




 %s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)




补充:  sizeof()  计算目标占用的空间的大小   
strlen    计算可视的字符串长度
字符串保存时,计算机自动在最后一个字节添加'\0'

 %ms:输出的字符串占m列,如果字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。
 %-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
 %m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
 %-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。








 ⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:
 %f:不指定宽度,整数部分全部输出并输出6位小数。
 %m.nf:输出共占m列,其中有n位小数,若数值宽度小于m左端补空格。 
 %-m.nf:输出共占m列,其中有n位小数,若数值宽度小于m右端补空格。








 ⑧e格式:以指数形式输出实数。可用以下形式:
 %e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。
 %m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。




 ⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。
 




对于单精度数,使用%f格式符输出时,仅前7位是有效数字,小数6位.
对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位.




 从 scanf 输入    按开发者需要从输入缓冲区取值




scanf("%d" , &j);


注意1:  
一般在获取 %c 这个格式之前,需要先把之前缓冲区的内容给清除。
getchar() 是以字符为单位去取缓冲区的内容,返回值为得到的字符。
while(1)
{
if(getchar() == '\n')
break;
}
 
=========等价于============ while(getchar() != '\n') ;

注意2:
关注scanf的返回状态,以此初步判断得到的数据是否符合要求
返回值表示成功获取了几个符合条件的值; 0表示获取失败




if(scanf("%d",&x) != 0)
{
// success
}
else
{
//fail 如再次要求输入一个整型数
}

注意3:
scanf怎么写 就怎么输入




scanf("%c,%c", &a, &b);  == 那就需要输入 x,y 这样的形式



















你可能感兴趣的:(linux,C语言)