(三十二)数值·编码

简介:

当我们书写常量的时候,办法很多,比如int a=1; 其中,1就是常量。

我们又知道,每一个字符(包括字母数字),都有其数值编码(ASCII码),因此,如果我们直接书写一个数值常量,可以用单引号将字符括起来。例如'a',这就表示常量 97,其常量,就是这个字母a的ASCII码。

 

我们在用这个常量,给变量赋值的时候,可以这样:

char a= 97;
cout << a;

通过这种方式,我们输出的结果为a。因为常量97,在通过整型声明变量i的时候,认为是以ASCII编码的形式进行储存的,而char的输入和输出方式,是将字符转为ASCII编码进行输入和输出。由于cout的智能,输出i的时候,会认为97是被储存的常量,不是数字,而是字符。

 

但是,这个方法有一个问题,特别是:

#include <iostream>
using namespace std;

int main()
{
	cout << "请在A,B,C,D四个选项中选择一个你认为是正确的,然后输入相应的大写字母。" << endl;
	cout << "A. 1+1=2\n";	//A的ASCII值是65
	cout << "B. 10*1=11\n";
	cout << "C. 7-3=5\n";
	cout << "D. 4/2=1" << endl;
	char i ;
	cin >> i;
	int m = i;

	if(64<m<69)
	{
		if (m == 65) { cout << "恭喜你,答对了!" << endl; }
		if (m == 66) { cout << "不对,你答错了!" << endl; }
		if (m == 67) { cout << "不对,你答错了!" << endl; }
		if (m == 68) { cout << "不对,你答错了!" << endl; };

	}
	if (m < 65, m>68) { cout << "请输入正确选项." << endl; }

	system("pause");
	return 0;
}

假如在某种情况下,例如系统使用的EBCDIC(IBM好多年出的一种编码方式),那么A的ASCII值就不是65了。那么这个程序就会出错——可能输出结果有问题。

 

因此,我们可以用单引号   ''  将字母括住。

例如char a= 'a';

那么无论何时,变量a输出的肯定就是字母a了,而不是可能存在的其他字母。

 

又在有的时候,某些字符,我们是无法用键盘输入的,

比如让字符串中包含一个换行符。

又比如双引号,他在编译器中被赋予了特殊的含义——分隔字符串字面值。

简单点来说,就是 cout << "a "bc" d" << endl;  编译器就傻了。他不知道你想让他显示的是 a "bc" d  。

 

这个时候呢,我们就需要一种特殊的方法,来显示这些正常输入无法显示的东西,而这种方法,被C++称为——转义序列。

例如,我们需要换行的时候,就输入\n,比如cout << "a\nb"

其显示出来的不是a\nb,而是:

a

b

又比如,像上面那样我们需要他显示a"bc"d。就用  \"  来替代。

cout << "a\"bc\"d";

这样就如我们所愿了。

 

转移序列有其特别的编码。

例如:

换行符		是 \n
水平制表符		是 \t
垂直制表符		是	\v
退格键		是	\b
回车键		是 \r
振铃(就是会响一声)	是	\a
反斜杠		是	\\

上代码:



#include <iostream>
using namespace std;

int main()
{
	cout << "a \"bc\" d" << endl;	//显示的为a "bc" d	。\"显示的是双引号
	cout << "e\nf" << endl;		//第一行显示e,第二行显示f。\n是换行符的意思
	cout << "\t\t\t\t" << endl;	//不知道为什么,什么都没显示
	cout << "\v" << endl;	//这个显示的也很怪……
	cout << "you type ____\b\b\b\b";	//这行和下面2行的效果是,你输入的字母,将复写在下划线____上。例如,刚开始是这样you type ____ ,当你输入a后,则为you type a___ 。另外注意,退格后的输入,实质上是复写,因此不复写就不会覆盖之前的东西。
	char a[10];
	cin >> a;
	cout << "\a\a\a" << endl;	//你在输入完字母之后,按回车,便会响三声。每一个\a 表示响一声
	cout << "\\aa" << endl;		//这个输出结果是\aa。之所以这样,是如果只用一个\的话,他会响一声,然后输出\a(分别是第一个\和第二个a)
	cout << "abc?\?" << endl;	//输出结果是abc??,按照说明\?显示的是问号没错,但是为什么要多此一举前面加个\这样……我不懂~
	cout << "a\'b\'c" << endl;	//毫无疑问,输出结果是a'b'c。\'显示的是单引号。

	system("pause");
	return 0;
}


另外,将转义字符作为字符常量的时候,用单引号,用在字符串中的时候,用双引号,如果乱用,结果就不同,特别是当应该用双引号却用单引号时


——双引号是字符串,单引号是字符。当该用单引号却用双引号的时候,会认为是字符串,字符串是 字符加最后的空字符\0 ,会根据不同情况出现问题,但也可能不出现明显的问题。



#include <iostream>
using namespace std;

int main()
{
	cout << '\a' << endl;	//响一声
	cout << '\a\a' << endl;	//<span style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 128, 0);">输出</span><span style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 128, 0);">1799<span style="font-family:宋体;">——</span></span><span style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 128, 0);">因为单引号是字符,这种应该就会将单引号的字符输入到内存地址,然后输出的便不是我们想要得到的内容</span>
	char a[10];
	cin >> a;
	cout << "\a" << endl;	//上面输入之后用回车,又响了一声
	system("pause");
	return 0;
}


目录
相关文章
|
7月前
|
JavaScript 前端开发
JavaScript随手笔记 --- 对数据进行判断最大位数是否超过八位
JavaScript随手笔记 --- 对数据进行判断最大位数是否超过八位
|
7月前
|
机器学习/深度学习 编译器 C语言
【C语言】数据输出的域宽控制(如何在输出数据时控制0占位)(如何输出前导0)(保留几位小数)(乘法口诀表打印不齐)等问题
【C语言】数据输出的域宽控制(如何在输出数据时控制0占位)(如何输出前导0)(保留几位小数)(乘法口诀表打印不齐)等问题
110 0
|
4月前
|
存储
字符编码问题之mbtowc 函数中计算最终的 Unicode 值如何解决
字符编码问题之mbtowc 函数中计算最终的 Unicode 值如何解决
18 0
|
7月前
|
5G
MFC编程 -- 浮点数与字符串之间转换
MFC编程 -- 浮点数与字符串之间转换
120 1
|
7月前
|
BI 索引 Python
python报表自动化系列 - 译码:将纯数字译码为Excel列坐标的字母索引表示形式
python报表自动化系列 - 译码:将纯数字译码为Excel列坐标的字母索引表示形式
46 1
|
7月前
|
机器学习/深度学习 数据处理 索引
Python下数值型与字符型类别变量独热编码(One-hot Encoding)实现
Python下数值型与字符型类别变量独热编码(One-hot Encoding)实现
|
编译器 C++
c++中基本类型详细解释外加基本运算规则
类型 含义 wchat_t 宽字符 bool 布尔类型 char 字符 chat16_t unicode字符 chat_32 unicode字符 short 短整型 int 整形 long 长整型 longlong 长整型 float 单精度浮点型 double 双精度浮点型 longdouble 扩展精度浮点型
120 1
|
存储 算法
聊一聊整数编码
聊一聊整数编码
82 0
|
C++
【C++知识点】浮点数据的输出控制
【C++知识点】浮点数据的输出控制
113 0
|
小程序 JavaScript 前端开发
vba 在代码窗口里不能正常显示的双字节字符的转换
vba 在代码窗口里不能正常显示的双字节字符的转换
101 0