变量:存数的
声明:---------相当于在银行开账户
int a;//声明一个整型的变量,名为a
int b,c;//声明两个整型的变量,名为b,c
//int a;//编译错误,变量不能同名
初始化:即第一次赋值----------相当于给账户存钱
int a = 520;//声明整型变量a并赋值为520
int b;//声明整型变量b
b = 520;//给变量b赋值为520
b = 52;//修改变量b的值为52
int c = 5,d = 10;//声明两个整型变量c和d,并分别赋值为5和10
使用:-----------使用的是账户里面的钱
对变量的使用就是对它所存的那个数的使用
int a = 5;
int b = a+10;//取出a的值5,加上10后,再赋值给变量b
System.out.println(b);//输出变量b的值15
System.out.println("b");//输出b,双引号中的原样输出
a = a+10;//在a本身基础之上增10
int c = 5000;//账户余额
c = c-1000;//取款1000
变量在用之前必须声明并初始化
//System.out.println(m);//编译错误,变量m未声明
int m;
//System.out.println(m);//编译错误,变量m初始化
命名:
- 只能包含字母、数字、_和$符,并且不能以数字开头
- 严格区分大小写
- 不能使用关键字
- 允许中文命名,但不建议,建议“英文的见名知意”、“小驼峰命名法”
代码如下:
int a_5$,_3c,$_;
//int a*b;//编译错误,不能包含*号等特殊符号
//int 1a;//编译错误,不能以数字开头
int aa=5;
//System.out,println("aA);//编译错误,严格区分大小写
//int class;//编译错误,不能使用关键词
int 年龄;//允许,但是不建议
int age;//“英文见名知意”
int score,myScore,myJavaScore;//“小驼峰命名法”
八种基本数据类型:byte、short、int、long、float、double、boolean、char
int:整型,4个字节,-21个多亿到21个多亿
- 整型直接量默认为int类型,但不能超范围,若超范围则发生编译错误;
- 两个整数相除,结果还是整数,小数位无条件舍弃(不会四舍五入);
- 整数运算时,若超过int范围则发生溢出(溢出不是错误,但是要避免)
int a = 25;//25称为整数直接量,默认iny类型
//int b = 10000000000;//编译错误,100亿默认为int类型,但超过int范围了
//int c = 3.14;//编译错误,整型变量中只能装整数
System.out.println(5/2);//2
System.out.println(2/5);//0
System.out.println(5/2.0);//2.5
int d = 2147483648;//int的最大值
d = d+1;
System.out.println(d);//-2147483648(int最小值),发生溢出了,溢出是需要避免的
long:长整型,8个字节,很大很大很大
- 长整型直接量需在数字后加L或l;
- 运算时若有可能溢出,建议在第1个数字后加L
long a = 25L;//25L为长整型直接量
//long b = 10000000000;//编译错误,100亿默认为int类型,但超过int范围了
long c = 10000000000L;//100L为长整型直接量
//long d = 3.14;//编译错误,长整型变量只能装整数
//运算时若有可能溢出,建议在第1个数字后加L
long e = 1000000000*2*10L;
System.out.println(e);//200亿
long f = 1000000000*3*10L;
System.out.println(f);//不是300亿
long g = 1000000000L*3*10;
System.out.println(g);//300亿
double:浮点型,8个字节,很大很大很大
- 浮点数直接量默认为double型,若想表示float需在数字后加F或f
- double与float型数据参与运算时,有可能会出现舍入误差,精确场合不能使用
double a = 3.14;//3.14为浮点数,默认double型
float b = 3.14F;//3.14F为float型直接量
double c = 1234000000000000000000000000000000000.0;
System.out.println(c);//1.234E33,科学计数法表示,相当于1.234*(10的33次幂)
double d = 3.0,e = 2.9;
System.out.println(d-e);//0.100000000000000009,有可能会发生舍入误差,精确场合不能使用
boolean:布尔型,1个字节
只能赋值为true或false
boolean a = true;//true为布尔型直接量-----------真
boolean b = false;//false为布尔型直接量------------假
//boolean c = 250;//编译错误,布尔型只能赋值为true或false
char:字符型,2个字节
- 采用Unicode字符集编码格式,一个字符对应一个码,表现的形式是字符char,但本质上是码int(0到65535之间);
- ASCII码:‘a’—57,‘A’—65,‘0’—48
- 字符型直接量必须放在单引号中,并且只能有1个
- 特殊符号需要通过\来转义
char c1 = '女';//字符女
char c2 = 'f';//字符f
char c3 = '6';//字符6
char c4 = ' ';//空格符
//char c5 = 女;//编译错误,字符型直接量必须放在单引号中
//char c6 = '';//编译错误,必须有字符
//char c7 = '女性';//编译错误,只能有1个字符
char c8 = 65;//0到65535之间
System.out.println(c8);//println输出时会依据c8的数据类型显示
//若c8为char型,则显示字符
//若c8为int型,则显示数字
char c9 = '\\';
System.out.println(c9);//\
类型间的转换:
基本类型有小到大依次为:byte—short—int—long—float—double—char
两种方式:
- 自动/隐式类型转换:小类型到大类型
- 强制类型转换:大类型到小类型
语法:(要转换成为的数据类型)变量
强转有可能溢出或丢失精度
int a = 5;
long b = a;//自动类型转换
int c = (int)b;//强制类型转换
long d = 5;//自动类型转换
double e = 5;//自动类型转换
long f = 10000000000L;
int g = (int)f;//强制类型转换
System.out.println(g);//1410065408,强转有可能发生溢出
double h = 25.987;
int i = (int)h;//强制类型转换
System.out.println(i);//25,强转有可能丢失精度
两种规则:
- 整数直接量可以直接赋值给byte、short、char,但不能超出范围;
- byte、short、char型数据参与运算时,系统一律自动将其转换为int再运算
byte b1 = 5;//byte的范围为-128到127之间
byte b2 = 6;
byte b3 = (byte)(b1+b2);
System.out.println(2+2);//4
System.out.println(2+'2');//52,2加上'2'的码50
System.out.println('2'+'2');//100,'2'的码50,加上'2'的码50
自动类型转换(小到大)、强制类型转换(大到小)
short s1 = 5;
short s2 = 6;
short s3 = (short)(s1+s2);
数据类型分类:
- 引用数据类型
- 基本数据类型
内存大小:
1G=1024M(兆)
1M=1024KB(千字节)
1KB=1024B(字节)
1B=8bit(位)