sprintf转换类型和参数类型必须一致么

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sprintf转换类型和参数类型必须一致么相关的知识,希望对你有一定的参考价值。

例如sprintf(a, '%d', b )其中b如果是 无符号长整形(u l )的,会报错,那么应该如何修改?类型冲突指的是有无符号冲突还是int 和 long int 冲突 还是有符号的%d和无符号b冲突? 如果b是 无符号的short int 是否还有问题?
补充一下,如果a 是个数组呢?貌似%ld等于没用吧?怎么看编译器

这牵涉到数据类型的向上转换的问题,只能往更高级的类型转换,比如unsigned char->char->int在这个例子里,你相当于把无符号长整形这个变量“填写”到一个整形的“空格”里,你想啊,系统先看你输入的是'%d',以为你要输入一个整形,给你准备了2字节的空间,结果你给他一个长度是4字节的无符号长整形,就没办法塞进这个空间里去了,但是呢,如果你输入的是'%dl',那么系统就会分配一个长度是4字节的空间,那么这么大的空间,就可以输入任何比这个长度小的整形数据,比如unsigned char(1字节)、int(2字节)等;好,你后来说的这个如果b是short int的情况,这个是可以的,因为short int 是2字节的,正好符合'%d'的标准。就这么多了,可能说的比较乱,如果不懂欢迎来问我。追问

%d 是signed 而我的变量是unsigned,这个是否必须一致?

追答

你用 %dl 就可以了,%d是2字节输出格式,可以输出unsigned char、char、int等等;%dl 是4字节输出格式,可以输出long int、unsigned long int,你可以试试看,实践出真知~

追问

你确定是%dl ,不是%ld?大哥你说的靠谱不啊?这个没法验证,因为不会出错误,只是警告,你这回答看的很有道理,可是一句%dl让我不敢信你啊

追答

……是ld,不好意思啊……

追问

补充一下,如果a 是个数组呢?貌似%ld等于没用吧?

追答

我没看懂啊,sprintf只能输出到字符串,a不能是数组吧……

参考技术A 有vc里,数据类型转换有atoi,itoa,在linux中,没有这些函数,但能sprintf能实现数据转换!
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
int main()

char buffer[20];
int i=3455;
long l=-343115L;
unsigned long ul=123456789UL;
// *itostr(i);
sprintf(buffer,"%x",i);
printf("%s",buffer);
return 0;


% 印出百分比符号,不转换。
b 整数转成二进位。
c 整数转成对应的 ASCII 字符。
d 整数转成十进位。
f 倍精确度数字转成浮点数。
o 整数转成八进位。
s 整数转成字符串。
x 整数转成小写十六进位。
X 整数转成大写十六进位。
注:sprintf的作用是将一个格式化的字符串输出到一个目的字符串中,而printf是将一个格式化的字符串输出到屏幕。sprintf的第一个参数应该是目的字符串,如果不指定这个参数,执行过程中出现 "该程序产生非法操作,即将被关闭...."的提示。
因为C语言在进行字符串操作时不检查字符串的空间是否够大,所以可能会出现数组越界而导致程序崩溃的问题。即使碰巧,程序没有出错,也不要这么用,因为早晚会出错。所以一定要在调用sprintf之前分配足够大的空间给buf。
参考技术B 无符号的打印应该是%u吧。
我不知道你用的什么编译器,但是dev cpp 好像没有问题。追问

不是报错,是有warning 用的cygdriver软件编译的

追答

恩。unsigned的数据标识的正数范围比一般的非unsigned大, 如果你直接转换成%d就可能出现溢出的问题。所以尽量都是对应的类型进行转换。
看看下面的这个东西
http://wenku.baidu.com/view/e905ce69a98271fe910ef914.html

追问

但是我看到如果b是unsigned short int 形式的,就不会warning,我想知道到底是长短警告还是类型不同警告

追答

都有吧,不同编译器不一样,像我用的根本就没警告。自己写程序的时候注意下就行了。尽量对应起来用。

参考技术C %ld

如果是数组 你要循环输出才行

Java基本数据类型转换

类型转换

Java 语言是一种强类型的语言。强类型的语言有以下几个要求:

变量或常量必须有类型:要求声明变量或常量时必须声明类型,而且只能在声明以后才能使用。

赋值时类型必须一致:值的类型必须和变量或常量的类型完全一致。

运算时类型必须一致:参与运算的数据类型必须一致才能运算。


但是在实际的使用中,经常需要在不同类型的值之间进行操作,这就需要一种新的语法来适应这种需要,这个语法就是数据类型转换。
在数值处理这部分,计算机和现实的逻辑不太一样,对于现实来说,1和 1.0 没有什么区别,但是对于计算机来说,1 是整数类型,而 1.0 是小数类型,其在内存中的存储方式以及占用的空间都不一样,所以类型转换在计算机内部是必须的。

Java 语言中的数据类型转换有两种:

自动类型转换:编译器自动完成类型转换,不需要在程序中编写代码。

强制类型转换:强制编译器进行类型转换,必须在程序中编写代码。

由于基本数据类型中 boolean 类型不是数字型,所以基本数据类型的转换是出了 boolean 类型以外的其它 7 种类型之间的转换。下面来具体介绍两种类型转换的规则、适用场合以及使用时需要注意的问题。


自动类型转换

自动类型转换,也称隐式类型转换,是指不需要书写代码,由系统自动完成的类型转换。由于实际开发中这样的类型转换很多,所以 Java 语言在设计时,没有为该操作设计语法,而是由 JVM 自动完成。


转换规则:从存储范围小的类型到存储范围大的类型。
具体规则为:byte→short(char)→int→long→float→double

也就是说 byte 类型的变量可以自动转换为 short 类型,示例代码:

byte  b  =  10;

short  sh  =  b;这里在赋值时,JVM 首先将 b 的值转换为 short 类型,然后再赋值给 sh。
在类型转换时可以跳跃。示例代码:

byte  b1  =  100;
int  n  =  b1;

在声明和定义变量时,整数默认是int类型,小数默认是double类型。若想声明小数为float 类型,必须在小数后面跟上F或f。若想声明整数为long类型,必须在整数后面跟上L或l。

注意问题:在整数之间进行类型转换时,数值不发生改变,而将整数类型,特别是比较大的整数类型转换成小数类型时,由于存储方式不同,有可能存在数据精度的损失。

 

强制类型转换

强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。

转换规则:从存储范围大的类型到存储范围小的类型。

具体规则为:double→float→long→int→short(char)→byte

语法格式为:(转换到的类型)需要转换的值

示例代码:

double  d  =  3.10;
int  n  =  (int)d;

这里将 double 类型的变量 d 强制转换成 int 类型,然后赋值给变量 n。需要说明的是小数强制转换为整数,采用的是“去 1 法”,也就是无条件的舍弃小数点的所有数字,则以上转换出的结果是 3。整数强制转换为整数时取数字的低位,例如 int 类型的变量转换为 byte 类型时,则只去 int 类型的低 8 位(也就是最后一个字节)的值。
示例代码:

int  n  =  123;
byte  b  =  (byte)n;
int  m  =  1234;
byte  b1  =  (byte)m;

则 b 的值还是 123,而 b1 的值为-46。b1 的计算方法如下:m 的值转换为二进制是10011010010,取该数字低8位的值作为b1的值,则b1的二进制值是11010010,按照机器数的规定,最高位是符号位,1 代表负数,在计算机中负数存储的是补码,则该负数的原码是 10101110,该值就是十进制的-46。
注意问题:强制类型转换通常都会丢失精度,所以使用时需要谨慎


以上是关于sprintf转换类型和参数类型必须一致么的主要内容,如果未能解决你的问题,请参考以下文章

字符串函数sprintf / sprintf_s 容易出错的地方

字符串函数sprintf / sprintf_s 容易出错的地方

重载中没有一个可以转换所有参数类型

c语言中如何将short,int,long,float这些类型的数值转换为字符串?

c语言中如何将short,int,long,float这些类型的数值转换为字符串?

跨编译器的诊断不一致,用于缩小非类型模板参数中的转换