数据类型与变量
文章目录
在Java中数据类型主要分为两类:基本数据类型和引用数据类型
1. 基本数据类型
基本数据类型有四类八种
1.四类: 整型 , 浮点型 , 字符型 , 以及布尔型
2.八种:
数据类型 | 关键字 | 内存占用 | 范围 |
---|---|---|---|
字节型 | byte | 1字节 | -128 ~ 127 |
短整型 | short | 2字节 | -32768 ~ 32767 |
整型 | int | 4字节 | − 2 31 -2^{31} −231 ~ 2 31 − 1 2^{31}-1 231−1 |
长整型 | long | 8字节 | − 2 63 -2^{63} −263 ~ 2 63 − 1 2^{63}-1 263−1 |
单精度浮点数 | float | 4字节 | 有范围,一般不关注 |
双精度浮点数 | double | 8字节 | 有范围,一般不关注 |
字符型 | char | 2字节 | 0 ~ 65535 |
布尔型 | boolean | 没有明确规定 | true和false |
2. 变量
2.1 变量的概念
变量指的是程序运行时可变的量. 相当于开辟一块内存空间来保存一些数据。
2.2 类型的概念
类型则是对变量的种类进行了划分, 不同的类型的变量具有不同的特性。
2.3 整型变量(重点)
2.3.1 字节变量
注:不常用,一般用于文件和网络传输中。
基本语法格式:
byte 变量名 = 初始值;
代码示例:
//定义一个字节变量
byte num = 10;
//输出
System.out.println(num);
注意事项:
byte 表示变量的类型是一个字节型变量
变量名是变量的标识. 后续都是通过这个名字来使用变量
Java 中 = 表示赋值(和数学不一样), 意思是给变量设置一个初始值.
初始化操作是可选的, 但是建议创建变量的时候都显式初始化.
最后不要忘记分号, 否则会编译失败.
// 表示注释. 注释作为代码的解释说明部分, 不参与编译运行.
在Java中变量在定义时可以不赋值,但是一般推荐定义变量时赋予初始化值。
也就是说,在方法中定义的变量(局部变量),必须赋值后才能使用。
2.3.2 短整型变量(基本没用)
基本语法格式:
short 变量名 = 初始值;
代码示例
//定义一个短字节变量
short num = 10;
//输出
System.out.println(num);
2.2.3 整形变量
基本语法格式:
int 变量名 = 初始值;
代码示例:
//定义一个整形变量
int num = 10;
//输出
System.out.println(num);
注意事项:
在 Java 中, 一个 int 变量占 4 个字节. 和操作系统没有直接关系.
补充:
什么是字节
1.字节是计算机中表示空间大小的基本单位.
2.计算机使用二进制表示数据. 我们认为 8 个二进制位(bit) 为一个字节(Byte).
3,我们平时的计算机为 8GB 内存, 意思是 8G 个字节.
4.其中 1KB = 1024 Byte, 1MB = 1024 KB, 1GB = 1024 MB.所以 8GB 相当于 80 多亿个字节.4 个字节表示的数据范围是 -2^31 -> 2^31-1 , 也就大概是 -21亿 到 +21亿.
使用以下代码查看 Java 中的整型数据范围:
//int 最小值
System.out.println(Integer.MAX_VALUE);
//int 最大值
System.out.println(Integer.MIN_VALUE);
如果运算的结果超出了 int 的最大范围, 就会出现溢出的情况
int maxValue = Integer.MAX_VALUE;
System.out.println(maxValue+1);
int minValue = Integer.MIN_VALUE;
System.out.println(minValue-1);
此时输出结果为
21亿这样的数字对于当前的大数据时代来说, 是很容易超出的. 针对这种情况, 我们就需要使用更大范围的数据类型来表示,Java中提供了long类型.
2.2.4 长整型变量
基本语法格式:
long 变量名 = 初始值;
代码示例:
//定义一个长整形变量,此时表示这个 10 是一个 long 类型的值
long num = 10L;
//输出
System.out.println(num);
注意:
long类型占八个字节,其能存储的最大范围是 -(2^63) ~ (2^63)-1,现实生活的场景已经完全够用.
2.4 浮点型变量
2.4.1 双精度浮点型(重点)
基本语法格式:
double 变量名 = 初始值;
代码示例:
//定义一个双精度浮点数
double num = 1.0f;
System.out.println(num);
下面提出如下问题
问题一:下面代码的输出结果为什么是0?
System.out.println(1/2);
答:在计算机中,当整型与整型运算时(结果会忽略小数部分),输出整型,也就是int / int = int.当计算过程中我们想要结果为小数,我们就更换相应的类型为 double,即如下代码.
将其中任意一个参与运算的整型数字转换为double类型.
问题二:下列代码输出结果为什么是2.4200000000000004,而不是2.42?
double a = 1.1;
double b = 2.2;
System.out.println(a*b);
答:计算机的内部只能存储一大堆的0和1,浮点数在计算机的内部实际上是通过整数模拟的。
在工程中一般有以下两种解决方法:
1.仍然使用double,但是我们一般只看小数点后6~7位左右为有效位数,剩下的小数忽略不计
⒉.使用BigDecimal****类来代替double使用。
注意:
Java 中的 double 虽然也是 8 个字节, 但是浮点数的内存布局和整数差别很大, 不能单纯的用 2 ^ n 的形式表示数据范
围.Java 的 double 类型的内存布局遵守 IEEE 754 标准(和C语言一样), 尝试使用有限的内存空间表示可能无限的小数, 势必会存在一定的精度误差.
在Java中,直接写出来的小数默认都double类型的.
2.4.2 单精度浮点型
基本语法格式:
float 变量名 = 初始值;
代码示例:
float num = 1.0f;//写作1.0F也可以
System.out.println(num);
注意:
float 类型在 Java 中占四个字节, 同样遵守 IEEE 754 标准. 由于表示的数据>精度范围较小, 一般在工程上用到浮点数都
优先考虑 double, 不太推荐使用 float
2.5 字符型变量
基本语法格式:
char 变量名 = ‘初始值’;
代码示例:
char ch = 'A';
System.out.println(ch);
使用一个字符表示一个汉字:
char ch = '呵';
System.out.println(ch);
注意:
1.Java中字符集默认为Unicode编码,支持地球上的所有语言。
2.使用"括起来的值都是字符字面量,默认都是char类型
3.计算机中的字符本质上是一个整数. 在 C 语言中使用 ASCII 表示字符, 而 Java 中使用 Unicode 表示字符. 因此一
个字符占用两个字节, 表示的字符种类更多, 包括中文.
4.关于字符编码方式的讨论, 参见https://zhuanlan.zhihu.com/p/35172335
2.6 字符串String–引用数据类型(重点)
把一些字符放到一起就构成了字符串,String是引用数据类型,不是基本数据类型.
基本语法格式:
String 变量名 = “初始值”;
代码示例:
String sh = "bit";
System.out.println(sh);
注意事项:
1.Java 使用 双引号 + 若干字符 的方式表示字符串字面值.
2.当碰到一些特殊字符时,需要转义输出所谓的转义输出,就是告诉编译器,对这个字符不要做特殊处理。 " " 默认都是定义字符串变量,我现在就想输出 " ,需要对 " 转义,\\表示转义字符
转义字符示例:
转义字符 | 解释 |
---|---|
\n | 换行 |
\t | 水平制表符 |
\’ | 单引号 |
\" | 双引号 |
\\ | 反斜杠 |
字符串的 + 操作, 表示字符串拼接:
String a = "hello";
String b = "world";
String c = a + b;
System.out.println(c);
还可以用字符串和整数进行拼接:
String str = "result = ";
int a = 10;
int b = 20;
String result = str + a + b;
System.out.println(result);
// 执行结果
result = 1020 //此时的result为字符型
注:在Java中,任意数据类型只要和字符串"+",都会把其他类型转变为字符串然后进行字符串的拼接操作.
2.7 变量的作用域
变量的作用域,就是这个变量起作用的区域在哪,就看变量是在哪个大括号{}中定义的!!!
代码示例一:
public class Test {
public static void main(String[] args) {
int a = 10;
int b = 10;
System.out.println("a = "+a +",b = "+b);
}
}
a和b是在主方法0中定义的,因此在主方法的内部都是可以使用的,出了主方法,a和b就会销毁。
代码示例二:
public class Test {
{
//代码块
int a = 10;
}
}
出了{}后,a就销毁了.
2.8变量的命名规则
大家从第刚开始写代码就要规范起来,规范的代码是非常加分的,写代码一定要遵从相应的语言规范.
硬性指标:
一个变量名只能包含数字, 字母, 下划线
数字不能开头.
变量名是大小写敏感的. 即 num 和 Num 是两个不同的变量.
注意: 虽然语法上也允许使用中文/美元符($)命名变量, 但是 强烈 不推荐这样做
软性指标
变量命名要具有描述性, 见名知意.
变量名不宜使用拼音(但是不绝对).
变量名的词性推荐使用名词.
变量命名推荐 小驼峰命名法, 当一个变量名由多个单词构成的时候, 除了第一个单词之外, 其他单词首字母都大写.
2.9 final关键字修饰的常量
final int a = 10;
a = 20; // 编译出错. 提示 无法为最终变量a分配值
常量不能在程序运行过程中发生修改.
2.10字面值常量
10 // int 字面值常量(十进制)
010 // int 字面值常量(八进制) 由数字 0 开头. 010 也就是十进制的 8
0x10 // int 字面值常量(十六进制) 由数字 0x 开头. 0x10 也就是十进制的 16
10L // long 字面值常量. 也可以写作 10l (小写的L)
1.0 // double 字面值常量. 也可以写作 1.0d 或者 1.0D
1.5e2 // double 字面值常量. 科学计数法表示. 相当于 1.5 * 10^2
1.0f // float 字面值常量, 也可以写作 1.0F
true // boolen 字面值常量, 同样的还有 false
'a' // char 字面值常量, 单引号中只能有一个字符
"abc" // String 字面值常量, 双引号中可以有多个字符.
3.小结
每种数据类型及其范围, 是需要我们掌握的重点.
谢谢欣赏!!!