为何在c++中要将一个char型的变量以数的形式输出需要将其强制转换成int 型的,而单片机中不用

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为何在c++中要将一个char型的变量以数的形式输出需要将其强制转换成int 型的,而单片机中不用相关的知识,希望对你有一定的参考价值。

为何在c++中要将一个char型的变量以数的形式输出,需要将其强制转换成int 型的,而单片机中不用(即char型的数出来就是一个数)

任何变量在内存中的存储都是二进制数。
在输出的时候,
c++中,cout<< 输出一个char型变量默认就是字符串。要输出数字需要强制转换。
在c中,printf,是格式化输出,对于一个char型变量,%c输出字符串,%d输出其ascii码值,不需要强制转换。追问

printf在c++中可以使用吗

追答

因为c++兼容c,所以可以使用,但不建议使用。

追问

如果要使用,是否要加什么header?

追答

和C一样吧,#include

参考技术A 如果用cout输出需要转换, 用printf不用的.
因为cout会自己判断变量的类型, 然后根据类型来决定如何输出

int类型和char类型的区别

下面三个定义式的区别:

int i = 1;
char i = 1;
char i = ‘1‘;

int用来定义整型变量,char用来定义字符型变量,要清楚的知道三个定义式的区别,可以比较它们在内存中的存储形式。

数据在内存中是以二进制形式存放的,而且是以补码表示的。一个正整数的补码和该数的原码(即该数的二进制形式)相同;如果数值是负的,求补码的方法是:将该数的绝对值的二进制形式,按位取反再加1。这里不对补码的知识做过多的讨论了。
int i = 1,则内存中的存储形式为:0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1
在讨论字符型数据以前,首先要明确一个“编码”的概念,即约定一套规则,将a、b、#等符号用二进制的形式表示出来,然后大家都遵守这个规则。美国信息交换标准码(ASCII)就是基于这样的目的产生的。那么我们现在来看下面两个定义式:
char i = 1;
char i = ‘1‘;
将一个整型常量放到一个字符变量中,实际就是把以该整型常量表示的ASCII码放到内存单元中。(ASCII码是以十进制整数表示的)
将一个字符常量放到一个字符变量中,实际上并不是把该字符本身放到内存单元中去,而是把该字符的相应ASCII代码放到存储单元中。
char i = 1;则i的ASCII就是1,在内存中就是0 0 0 0 0 0 0 1
char i = ‘1’;则i的ASCII就是字符‘1’的ASCII码49,就是0 0 1 1  0 0 0 1
上面是int和char的区别,它们的联系就是存储形式类似,就是一个是1个字节,一个是2个字节。int 可以用字符常量赋值,char也可以用整型常量赋值,它们之间的桥梁就是ASCII码,因为字符是与ASCII一一对应的。

char能不能存中文字符

在C语言中,char类型占1一个字节,而汉子占2个字节,所以不能存储。

在Java中,char类型占2个字节,而且Java默认采用Unicode编码,以个Unicode码是16位,所以一个Unicode码占两个字节,Java中无论汉子还是英文字母都是用Unicode编码来表示的。所以,在Java中,char类型变量可以存储一个中文汉字。

char a = 65535;
char b = 65536;//报错  Type mismatch: cannot convert from int to char

 

以上是关于为何在c++中要将一个char型的变量以数的形式输出需要将其强制转换成int 型的,而单片机中不用的主要内容,如果未能解决你的问题,请参考以下文章

JDK9 为何要将 String 的底层实现由 char[] 改成了 byte[] ?

Java9为何要将String的底层实现由char[]改成了byte[]?

对于char型的,如果超出范围怎样算?

JDK9为何要将String的底层实现由char[]改成了byte[]?

JDK9为何要将String的底层实现由char[]改成了byte[]?

JDK9为何要将String的底层实现由char[]改成了byte[]?