数据类型扩展和有关面试题知识点
一.有关进制数的表示及输出
int a = 10;
int b = 010;//0开头八进制数
int b1 = 011;
int c = 0x10;//0x开头代表十六进制数
int c1 = 0x11;
//注意这里的10只是满足当前进制数,满10即为当前进制数,差数再加上进制数才是当前在计算机中表示的真正数字
//(1)考考你:int b2 = 022;实际输出是多少?(最后会给出答案)
二.有关浮点数精度的问题(重要)
float f = 0.1f;
double d = 1.0/10.0;
//分别输出f、d ,请问 f == d true or false ?
这里为什么不相等呢?
看完下边的知识你就能知道由于表示的位数不同,计算机没办法认为他俩相同
先来看看float和double数据类型的不同:
1、变量类型不同
float属于单精度型浮点数据。
double属于双精度型浮点数据。
2、指数范围不同属
float的指数范围为-127~128。
double而double的指数范围为-1023~1024
3、表达式指数位不同
float的表达式为1bit(符号位)+8bits(指数位)+23bits(尾数位)
double的表达式为1bit(符号位)+ 11bits(指数位)+ 52bits(尾数位)
4、占用内存空间不同
float占4个字节(32位)内存空间,其数值范围为3.4E-38~3.4E+38。(E为科学计数法)
double占8 个字节(64位)内存空间,其数值范围为1.7E-308~1.7E+308。
5、有效位数不同
float只能提供七位有效数字。
double可提供16位有效数字。
//有关对double的特点描述: 有限 离散 舍入误差 大约 接近但不等于
//银行系统中采用BigDecimal类型进行数据的精准控制,而不会采用int,float,double类型(面试题)
//做好完全避免使用浮点数进行比较
//做好完全避免使用浮点数进行比较
//做好完全避免使用浮点数进行比较
三.字符扩展
char c1 = 'a';
char c2 = '中';
System.out.println(c1);
System.out.println(c2);
System.out.println((int)c1);//强制转换
System.out.println((int)c2);//强制转换
//所有单个字符的本质还是数字,都能找到一个与其对应的数字
四.转义字符的扩展
转义字符是很多程序语言、数据格式和通信协议的形式文法的一部分。对于一个给定的字母表,一个转义字符的目的是开始一个字符序列,使得转义字符开头的该字符序列具有不同于该字符序列单独出现时的语义。因此转义字符开头的字符序列被叫做转义序列。
转义序列通常有两种功能。第一个是编码一个句法上的实体,如设备命令或者无法被字母表直接表示的特殊数据。第二种功能,也叫字符引用,用于表示无法在当前上下文中被键盘录入的字符(如字符串中的回车符),或者在当前上下文中会有不期望的含义的字符(如C语言字符串中的双引号字符",不能直接出现,必须用转义序列表示)。在后面那种情况,转义序列是一种由转义字符自身和一个被引用的字符组成的一个二合字母(digraph)情形。
注意:区分,斜杠:"/" 与 反斜杠:"" ,此处不可互换
扩展:/斜线与\反斜线
① / 斜线, slash或又称为forward slash (前斜线), 原本是标点符号。 起源于古罗马,中世纪时用作逗号(而当时的双斜线//是被当作连接号的,后来演化成等号=)。
a) 英语里的斜线, 最常用的即使替代字符“or”表选择, 比如: Yes/No; 还有就是避免名字的冲突,比如美国的人口普查表中有"Assyrian/Chaldean/Syriac", 就是为了避免因Syriac名字不同叫法而产生的冲突或歧义,其实也是or的含义;
b) 算术; 英文里面称over, 比如: 123/456,也即分数
c) 金钱表示。 $50/- 表示50美元上限, 后面没有了,防止有人添加修改。
d) 日期的表示
② \ backslash, 反斜线, 主要用于电脑中, 也正是对普通/斜线的借鉴。 操作系统(xNix), 电脑语言(C/C++, Perl),编码(部分Unicode)等都使用它。(此处扩展知识转载自CSDN种棵西府海棠吧)
(1)做对了哦!答案是18(8+8+2)