格式化输出输入

你看到的这个文章来自于http://www.cnblogs.com/ayanmw

头段时间我的代码,有一个 unsigned char,我需要从sscanf 中读取字符串为这个值。但是一般char 是用%c的,我是要值得。

所以我使用了%d %u来读,结果报警告:

unsigned char a;

sscanf("15","%u",&a);

warning: format ‘%u’ expects type ‘unsigned int*’, but argument 3 has type ‘unsigned char*’

警告挺烦人的,查了下,才发现自己没有注意过的细节:

I‘m trying to use this code to read values between 0 to 255 (unsigned char).

#include<stdio.h>
int main(void)
{
    unsigned char value;

    /* To read the numbers between 0 to 255 */
    printf("Please enter a number between 0 and 255 \n");
    scanf("%u",&value);
    printf("The value is %u \n",value);

    return 0;
}
I do get the following compiler warning as expected.

warning: format ‘%u’ expects type ‘unsigned int *’, but argument 2 has type ‘unsigned char *’

And this is my output for this program.

Please enter a number between 0 and 255 45 The value is 45 Segmentation fault

I do get the segmentation fault while running this code.

What is the best way to read unsigned char values using scanf?

c
share|edit
asked Jan 3 at 20:09

user1293997
766

use %c to read a byte – TJD Jan 3 at 20:12
4
Actually %hhu for unsigned char. – Joe Jan 3 at 20:15

@TJD. I don‘t want to read a char. I would like to read values between 0 to 255. – user1293997 Jan 3 at 20:15

@Joe. That worked great. Thanks a lot. – user1293997 Jan 3 at 20:17

user1293997: you might want to write an answer and accept it (assuming @Joe is not interested in doing so). The only currently standing answer is quite incorrect. – user4815162342 Jan 3 at 20:34

%hhu   指定signed char 或 unsigned char     char是1个字节

%h      指定short int 或者unsigned short int    short 是2个字节

C中格式字符串printf()的一般形式为: %[标志][输出最小宽度][.精度][长度]类型, 其中方括号[]中的项为可选项。各项的意义介绍如下:
1.类型:

表示输出类型的格式字符       格式字符意义
a                                             浮点数、十六进制数字和p-计数法(C99)
A                                           浮点数、十六进制数字和p-计数法(C99)
c                  输出单个字符
d                  以十进制形式输出带符号整数(正数不输出符号)
e                  以指数形式输出单、双精度实数
E                  以指数形式输出单、双精度实数
f                  以小数形式输出单、双精度实数
g                以%f%e中较短的输出宽度输出单、双精度实数,%e格式在指数小于-4或者大   于等于精度时使用
G                以%f%e中较短的输出宽度输出单、双精度实数,%e格式在指数小于-4或者大于等于精度时使用
i                                            有符号十进制整数(与%d相同)
o                以八进制形式输出无符号整数(不输出前缀O)
p                                          指针
s                 输出字符串
x                 以十六进制形式输出无符号整数(不输出前缀OX)
X                以十六进制形式输出无符号整数(不输出前缀OX)
u                 以十进制形式输出无符号整数
2.标志
标志字符为-、+、#、空格和0五种,其意义下表所示:

标志格式字符                     标 志 意 义
-                                 结果左对齐,右边填空格
+                                输出符号(正号或负号)
空格                                                    输出值为正时冠以空格,为负时冠以负号
#                               对c,s,d,u类无影响;对o类,在输出时加前缀0;对x类, 在输出时加前缀0x或者0X;
                                      对g,G 类防止尾随0被删除;对于所有的浮点形式,#保证了即使不跟任何数字,也打印一个小数点字符
0                                          对于所有的数字格式,用前导0填充字段宽度,若出现-标志或者指定了精度(对于整数),忽略
3.输出最小宽度
用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。
4.精度
精度格式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数大于所定义的精度数,则截去超过的部分。
5.长度
长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出。
     h和整数转换说明符一起使用,表示一个short   int 或者unsigned short int类型的数值 ,示例:
%hu,%hx,%6.4hd
     hh和整数转换说明符一起使用,表示一个short   int 或者unsigned short类型的数值 ,示例:
%hhu,%hhx,%6.4hhd
     j和整数转换说明符一起使用,表示一个intmax_t或者uintmax_t类型的数值 ,示例:
%jd,%8jx
     l和整数转换说明符一起使用,表示一个long int 或者unsigned long int类型的数值 ,示例:
%ld,%8lu
     ll和整数转换说明符一起使用,表示一个long int 或者unsigned long int类型的数值 (C99),示例:
%lld,%8llu
     L和浮点转换说明符一起使用,表示一个long double的值,示例:%Lf,%10.4Le
     t和整数转换说明符一起使用,表示一个ptrdiff_t值(两个指针之间的差相对应的类型)(C99),示例:
%td,%12ti
     z和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型)(C99),示例:%zd,%12zx

使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。Turbo C是按从右到左进行的。

http://www.cppblog.com/zenliang/archive/2010/11/07/132858.html

http://m.blog.csdn.net/blog/kangear/8952033

http://www.cnblogs.com/ilegend/archive/2011/11/22/2258701.html

顺道 道一句:%uud 也是可以得,是有符号的

http://pubs.opengroup.org/onlinepubs/009695399/functions/scanf.html

http://connect.microsoft.com/VisualStudio/feedback/details/416843/sscanf-cannot-not-handle-hhd-format

转载请注明出处:http://www.cnblogs.com/ayanmw 我会很高兴的!

时间: 2024-07-29 09:56:17

格式化输出输入的相关文章

fmt包的格式化输出输入

  fmt包的格式化输出输入 原文地址:https://www.cnblogs.com/qhdsavoki/p/9457853.html

格式化输出输入一二事

前言 输出输入流可以通过各种方式设置多种多样的格式化操作,给输出输入提供多种选项. 每种格式化将输出将通过两种方式进行描述,一种是操纵符,一种是成员函数.操作符一般在流中插入以进行格式化输出,成员函数则是通过对象调用起作用. 注意,流操纵符一般都在iomanip.h中,而成员函数一般都在iostream.h中. 进制相关 整型数字的显示格式 操纵符 设置进制 int n = 100; cout << dec << n << endl; //十进制 cout <&l

While循环,格式化输出,算术运算符,改py文件名字

一.While循环 while来打印每个元素 s = "风扇哥门神哥,邓生" i = 0 while i <len(s): print(s[i]) i+=1 while循环的感悟:while循环多用在交互程序里,做判断:而for循环多是用来获取某个类型集合(list,str,tupe,set...)里面的值 content  #内容的意思,是变量名count    #计数的意思,是变量名 break #彻底的结束循环 continue #停止本次循环,继续执行下次循环 break

go语言基础之格式化输出

1.fmt包的格式化输出输入 格式说明 格式 含义 %% 一个%字面量 %b 一个二进制整数值(基数为2),或者是一个(高级的)用科学计数法表示的指数为2的浮点数 %c 字符型.可以把输入的数字按照ASCII码相应转换为对应的字符 %d 一个十进制数值(基数为10) %e 以科学记数法e表示的浮点数或者复数值 %E 以科学记数法E表示的浮点数或者复数值 %f 以标准记数法表示的浮点数或者复数值 %g 以%e或者%f表示的浮点数或者复数,任何一个都以最为紧凑的方式输出 %G 以%E或者%f表示的浮

python 3 用户输入和格式化输出

# -*- coding:utf-8 -*- #用户输入 && 格式化输出 #getpass 模块是内置的,可以将输入的内容隐藏 import getpass username = input("username:") password = input("password:") age = int (input("age:")) job = input("job:") #print(type(age),type

python学习笔记(注释、用户输入、格式化输出)

注释 单行:# 多行:上下各用3个连续单引号或双引号 3个引号除了多行注释,还可以打印多行 举例: msg = ''' name = "Alex Li" name2 = name print ("My name is",name,name2) ''' # print(msg) 运行结果第二个print就是打印3行字符串. 如果单行,用引号即可:msg = "Alex Li" python中,单引号和双引号相同,除了单套双或双套单. 例: msg

_02_从键盘读入用户的输入,格式化输出hello+用户输入的信息

Hello.cs文件 using System; //引用了一个叫System的名空间 class easyInput //类的名字与文件名(Hello.cs)不同也 无所谓 { public static void Main() { string strName; //声明一个string类型的值变量 Console.Write("please input your name:"); //输出一句话,但不换行 strName = Console.ReadLine(); //从键盘读入

用户输入及格式化输出

输入用户名和密码: username=input("username:")password=input("password:")print(username,password) 格式化输出三种形式:形式一(不用): name=input("name:")age=input("age:")job=input("job:")salary=input("salary:") iofo1='''-

python注释、输入格式化输出输出及数据类型

一.python的注释 1.python中的注释 注释:对代码的解释或者评论,注释仅仅是给人看的,python本身不识别. 2.注释的分类 2.1. 单行注释 # 2.2. 三引号(可以是三个单也可以是三个双) 二.输入 1.python3中的输入 关键字:input() python3中的input获取的用户输入统一全部存成字符串类型 1.2.python2中的输入 1.2.1.input() 需要你人为的声明input输入的是什么数据类型 错误示范: 正确示范:   1.2.2.raw_in