1. 变量:存数的
- 声明:相当于在银行开帐户
- 初始化:相当于给帐户存钱
- 访问:访问的是帐户里面的钱
- 对变量的访问就是对它所存的那个数的访问
- 变量在使用之前,必须声明并初始化
- 命名:给帐户起名
- 只能包含字母、数字、_和$符,不能以数字开头
- 严格区分大小写
- 不能使用关键字
- 允许中文命名,但不建议,建议"英文的见名知意"、"小驼峰命名法"
2. 八种基本数据类型
byte、short、int、long、float、double、boolean、char
- int:整型,4个字节,-21个多亿到21个多亿
- 整数直接量默认为int类型,但不能超出范围,若超范围则发生编译错误
- 两个整数相除,结果还是整数,小数位无条件舍弃(不会四舍五入)
- 运算时,若超范围则发生溢出,溢出不是错误,但是需要避免
- long:长整型,8个字节,-900万万亿多到900万万亿多
- 长整型的直接量需在数字后加L或l
- 运算时若有可能溢出,建议在第1个数字后加L
- double:浮点型,8个字节,很大很大很大
- 小数直接量默认为double型,若想表示float,需在数字后加F或f
- 不能表示精确数字,运算时有可能会发生舍入误差,精确场合不能使用
- boolean:布尔型,1个字节
- 只能存储true或false
- char:字符型,2个字节
- 采用Unicode编码格式,一个字符对应一个码
表现的形式是字符char,但本质上是码int (0到65535)
(ASCII码:'a'----97 'A'----65 '0'----48)
- 字符直接量必须放在单引号中,只能有1个
- 特殊符号需要通过\来转义
3. 类型间的转换:
- 数据类型由小到大依次为:byte<short<int<long<float<double
char<
- 两种方式:
- 自动/隐式类型转换:小类型转为大类型
- 强制类型转换:大类型转为小类型
- 语法:(要转换成为的数据类型)变量
- 注意:强转有可能溢出或丢失精度
- 两点规则:
- 整数直接量可以直接赋值给byte,short,char,但不能超出范围
- byte,short,char型数据参与运算时,系统会一律先将其转为int再运算
4. 命名法:
- 小驼峰命名法:第1个单词首字母小写,其余单词首字母大写-------------变量、方法
```java
score,myScore,myJavaScore
```
- 帕斯卡命名法/大驼峰命名法:所有单词首字母大写---------------------------类
```java
Score,MyScore,MyJavaScore
```
2. Unicode:万国码、统一码、通用码,是世界级通用的定长(16位)字符集
int e = 250; //声明整型变量e并赋值为250------开户的同时存钱
int f; //声明整型变量f--------先开户
f = 250; //给变量f赋值为250-----后存钱
f = 360; //修改f的值为360
八种基本数据类型:byte、short、int、long、float、double、boolean、char
- int:整型,4个字节,-21个多亿到21个多亿
- 整数直接量默认为int类型,但不能超出范围,若超范围则发生编译错误
```java
int a = 250; //250为整数直接量,默认为int类型
//int b = 10000000000; //编译错误,100亿默认为int类型,但超出int范围了
//int c = 3.14; //编译错误,数据类型不匹配
```
- 两个整数相除,结果还是整数,小数位无条件舍弃(不会四舍五入)
```java
System.out.println(5/2); //2
System.out.println(2/5); //0
System.out.println(5/2.0); //2.5
```
- 运算时,若超范围则发生溢出,溢出不是错误,但是需要避免
```java
int d = 2147483647; //int的最大值
d = d+1;
System.out.println(d); //-2147483648,发生溢出了,溢出需要避免
```
- long:长整型,8个字节,-900万万亿多到900万万亿多
- 长整型的直接量需在数字后加L或l
```java
long a = 125L; //125L为长整型直接量
//long b = 10000000000; //编译错误,100亿默认为int类型,但超出int范围了
long c = 10000000000L; //100亿L为长整型
```
- 运算时若有可能溢出,建议在第1个数字后加L
```java
long d = 1000000000*2*10L;
System.out.println(d); //200亿
long e = 1000000000*3*10L;
System.out.println(e); //不是300亿
long f = 1000000000L*3*10;
System.out.println(f); //300亿
```
- double:浮点型,8个字节,很大很大很大
- 小数直接量默认为double型,若想表示float,需在数字后加F或f
```java
double a = 3.14; //3.14为小数直接量,默认为double类型
float b = 3.14F; //3.14F为float直接量
```
- 不能表示精确数字,运算时有可能会发生舍入误差,精确场合不能使用
```java
double c=3.0,d=2.9;
System.out.println(c-d); //0.10000000000000009,有可能发生舍入误差
```
- boolean:布尔型,1个字节
- 只能存储true或false
```java
boolean a = true; //true为布尔型直接量
boolean b = false; //false为布尔型直接量
//boolean c = 250; //编译错误,布尔型只能存储true或false
```
- char:字符型,2个字节
- 采用Unicode编码格式,一个字符对应一个码
表现的形式是字符char,但本质上是码int (0到65535)
(ASCII码:'a'----97 'A'----65 '0'----48)
- 字符直接量必须放在单引号中,只能有1个
```java
char c1 = '女'; //字符女
char c2 = 'f'; //字符f
char c3 = '6'; //字符6
char c4 = '*'; //字符*
//char c5 = 女; //编译错误,字符直接量必须放在单引号中
//char c6 = ''; //编译错误,必须有字符
//char c7 = '10'; //编译错误,只能有一个字符
//练习-----------------3:59继续
char c8 = 65; //0到65535之间
System.out.println(c8); //println()输出时会依据c8的类型来输出展示
//若c8是char型,则以字符形式输出
//若c8是int型,则以数字形式输出