c语言宽
Ⅰ C语言 格式宽度的问题
格式宽度%md(m为数值)原则是:
如果实际宽度小于m,则前面填充空格,如果实际宽度大于m,则按实际的宽度输出。
Ⅱ 关于C语言的位宽
解释如下:
1
如果不用.n显式指定小数位数,则默认是保留6位小数。
这里就没有显式指定,所以保留6位小数。
2
%10f中的10表示输出的最小宽度是10,同时,因为是正数,所以是右对齐(当然负数就是左对齐了),当实际宽度不足10位时,会在左边补充空格以填充到10位,当宽度超出10位时,不受此指定的影响。
同时,对于这里的宽度,小数点也算一位。
所以,输出就是那样了。
Ⅲ C语言 输出宽度的宽度指的是什么
样例中的%4d中的4就是最小输出宽度,即显示数字所占用的最小的字符数,如果不足4个字符,用空格补齐
Ⅳ 什么是C语言中的宽字符与多字节字符
C 语言原本是在英文环境中设计的,主要的字符集是7 位的ASCII 码。从此开始,8 位的byte(字节)变成最常见的字符编码单位,但是国际化软件必须能够表示不同的字符,而这些字符数量庞大,无法使用一个字节编码,于是世界上使用各式 各样多字节的字符编码集合已经有数十年了,比如用来表示“非拉丁字母”以及“非字母”的中、日、韩文字系统。在1994 年,“Normative Addenm 1”(基准增补一)的采用,让ISO C 可以标准化两种表示大型字符集的方法:宽字符(wide character,该字符集内每个字符使用相同的位长)以及多字节字符(multibyte character,每个字符可以是一到多个字节不等,而某个字节序列的字符值由字符串或流(stream)所在的环境背景决定)。
注 意: 虽然C现在提供抽象机制,可以处理和转换不同种类的编码集合,但语言本身并没有定义或指定任何编码集合,或任何字符集(除前一节提到的基本源代码字符集和 基本运行字符集外)。换句话说,这部分是由个别的实现版本指定如何编码宽字符,以及要支持什么类型的多字节字符编码机制。
自从1994 年的增补之后,C 不只提供char类型,还提供wchar_t类型(宽字符),此类型定义在stddef.h 头文件中。wchar_t 类型足以表示某个实现版本扩展字符集的任何元素。
虽然C 标准没有支持Unicode 字符集,许多实现版本使用Unicode 转换格式UTF-16 和UTF-32(参考http://www.unicode.org) 来处理宽字符。Unicode 标准和ISO/IEC 10646标准相当接近,而且是许多既有字符集(包括7 位的ASCII)的超集。如果遵循Unicode标准,wchar_t类型至少是16或32位长,而wchar_t类型的一个值就代表一个Unicode 字符。
在多字节字符集中,每 个字符的编码宽度都不等,可以是一个字节,也可以是多个字节。源代码字符集和运行字符集都可能包含多字节字符,如果真的包含多字节字符的话,那么基本字符 集中的每个字符都只会占用一个字节(完全没有多字节的字符),空字符是唯一的例外,空字符可能会占用任意个数的字节(但这些字节内全部的位都必须为0)。 多字节字符可以被用于字符的常量、字符串字面值(string literal)、标识符(identifier)、注释(comment),以及头文件。许多的多字节字符集被设计来支持特定国家的语言,例如JIS 字符集(日本业界标准,Japanese Instrial Standard)。多字节UTF-8 字符集是由Unicode Consortium(万国码联盟)定义的,可以表示Unicode 字符集的所有字符。
UTF-8 字符所使用的空间大小从一个字节到四个字节都有可能。多字节字符和宽字符(也就是wchar_t)的主要差异在于宽字符占用的字节数目都一样,而多字节字符的字节数目不等,这样的表示方式使得多字节字符串比宽字符串更难处理。
比 方说,即使字符'A'可以用一个字节来表示,但是要在多字节的字符串中找到此字符,就不能使用简单的字节比对,因为即使在某个位置找到相符合的字节,此字 节也不见得是一个字符,它可能是另一个不同字符的一部分。然而,多字节字符相当适合用来将文字存储成文件(参见第13 章)。
C 提供了一些标准函数,可以将多字节字符转换为wchar_t,或将宽字符转换为多字节字符。比方说,如果C 编译器使用Unicode 标准的UTF-16 和UTF-8
Ⅳ 在C语言中什么是字符宽
在C中,printf函数的使用格式是:printf(“格式控制字符串”,输出表列)
其中“格式控制字符串”一般形式为:
[标志][输出最小宽度][.精度][长度]类型。
如LZ问题中"%1d",其中数值1,就是指的输出最小宽度。
而这个输出最小宽度,是用十进制整数来表示的。
若实际位数多于定义的宽度,则按实际位数输出,
若实际位数少于定义的宽度则补以空格或0。
所以当这个宽度为1时,因为此时a的值是5,只有1位,定义的宽度不大于实际宽度,所以按实际宽度输出。但是定义宽度为2时,超过了实际数据宽度,所以多输出的位补了空格。
另外,LZ所谓的字符宽应该是指输出的字符位数的宽度。
Ⅵ C语言中宽度和长度有什么区别
可以在"%"和字母之间的数字表示最大场宽。
例如:
%3d
表示输出3位整型数,
不够3位右对齐。
%9.2f
表示输出场宽为9的浮点数,
其中小数位为2,
整数位为6,
小数点占一位,
不够9位右对齐。
%8s
表示输出8个字符的字符串,
不够8个字符右对齐。
如果字符串的长度、或整型数位数超过说明的场宽,
将按其实际长度输出。
但对浮点数,
若整数部分位数超过了说明的整数位宽度,
将按实际整数位输出;
若小数部分位数超过了说明的小数位宽度,
则按说明的宽度以四舍五入输出。
对于整数和字符串来说,不存在精度问题。
对于浮点来说,所谓的精度是指小数位宽度。
Ⅶ C语言怎么输入和输出宽字符
宽字符有专门的输入函数wscanf。
用普通的scanf也可以做到,但需要做处理,所以在输入宽字符的时候,最佳选择还是专门的wscanf。
当输入宽字符型变量时,需要使用格式符号%lc, 输入宽字符串时需要使用格式符号%ls。
另外,宽字符一般用wprintf输出,这时输出字符和字符串时,用%c和%s即可。
参考代码如下:
void main( void ){ wchar_t wc, ws[81];//定义一个宽字符变量,及一个宽字符数组。 wscanf( L"%lc%ls",&wc, ws );//输入值。 wprintf( L"%c,%s\n",wc, ws);//输出值。}
Ⅷ 在C语言中怎么打出宽字符呢
用大写的%S就可以:
wchar_t *wideChar = L"This is wide 中文显示";
setlocale( LC_ALL, ".936" ); // 设置中文代码页,否则不打印中文
printf( "%s\n", wideChar ); //小写,只打出一个字母
printf( "%S\n", wideChar ); //大写,打出全部
Ⅸ C语言中数据的实际宽度指的什么。
用于确定最小输出宽度,例如:
printf("%5d",i);
默认输出宽度为5,如果实际宽度超出5则以实际宽度输出,如果不足5则输出右对齐,左边补空格。如果是%-5d那么就是左对齐,右边补空格。