1. java开发环境
-
编译运行过程:
- 编译期:.java源文件,经过编译,生成.class字节码文件
- 运行期:JVM加载.class并行.class(0和1)
特点:跨平台、一次编译到处使用
-
名词解释:
-
JVM:java虚拟机
加载.class并运行.class
-
JRE:java运行环境
除了包含JVM以外还包含了运行java程序所必须的环境
JRE = JVM+java系统类库(小零件)
-
JDK:java开发工具包
除了包含JRE以外还包含了开发java程序所必须的命令工具
JDK = JRE+编译、运行等命令工具
说明:
- 运行java程序的最小环境JRE
- 开发java程序的最小环境JDK
-
2. IDEA:开发工具
-
JetBrains公司的,分为社区版(免费的)和终级版(收费的)
-
开发步骤:
-
新建Java项目/工程-------------------------小区
-
新建Java包-----------------------------------楼+单元
-
新建Java类-----------------------------------房子
main中:System.out.println(“hello world”);
代码如下:
package day01; //声明包day01(楼+单元) public class HelloWorld { //声明类HelloWorld(房子) //主方法,为程序的入口(大门口),程序的执行从main开始,main结束则程序结束 public static void main(String[] args) { //输出hello world //1)严格区分大小写 //2)所有符号必须是英文模式的 //3)每句话必须以分号结尾 System.out.println("hello world"); //双引号中的原样输出 System.out.println("欢迎大家来到达内"); } }
-
3.注释:解释性文本(计算机不执行)
- 单行注释://
- 多行注释:/* */
- 文档注释:/** */
换算:
1G=1024M(兆)
1M=1024KB(千字节)
1KB=1024B(字节)
1B=8bit(位)
4. 变量:存数的
-
声明:-------------相当于在银行开帐户
int a; //声明一个整型的变量,名为a int b,c,d; //声明三个整型的变量,名为b,c,d //int a; //编译错误,变量不能同名
-
初始化:第一次赋值---------相当于给帐户存钱
int a = 250; //声明整型变量a并赋值为250 int b; //声明整型变量b b = 250; //给变量b赋值为250 b = 360; //修改变量b的值为360 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未初始化
-
-
命名:
- 只能包含字母、数字、_和$符,并且不能以数字开头
- 严格区分大小写
- 不能使用关键字
- 允许中文命名,但不建议,建议"英文的见名知意"、“小驼峰命名法”(myScore)
大驼峰命名:MyScore(类的命名)
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; //建议"小驼峰命名法"
5. 八种基本数据类型
byte,short,int,long,float,double,boolean,char
-
int:整型,4个字节,-21个多亿到21个多亿
- 整数直接量默认为int类型,但不能超范围,若超范围则发生编译错误
- 两个整数相除,结果还是整数,小数位无条件舍弃(不会四舍五入)
- 整数运算时,若超出int范围则发生溢出(溢出不是错误,但需要避免)
//1)int:整型,4个字节,-21个多亿到21个多亿 int a = 25; //25称为整数直接量,默认int类型 //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 = 2147483647; //int的最大值 d = d+1; System.out.println(d); //-2147483648(int最小值),发生溢出了,溢出是需要避免的
-
long:长整型,8个字节,很大很大很大
- 长整型直接量需在数字后加L或l
- 运算时若有可能溢出,建议在第1个数字后加L
//2)long:长整型,8个字节,很大很大很大 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型数据参与运算时,有可能会出现舍入误差,精确场合不能使用
//3)double:浮点型,8个字节,很大很大很大 double a = 3.14; //3.14为浮点数直接量,默认double型 float b = 3.14F; //3.14F为float型直接量 double c = 1234000000000000000000000000000000.0; System.out.println(c); //1.234E33,科学计数法表示,相当于1.234*(10的33次幂) double d=3.0,e=2.9; System.out.println(d-e); //0.10000000000000009,有可能会发生舍入误差,精确场合不能使用
-
boolean:布尔型,1个字节
- 只能赋值为true或false
//4)boolean:布尔型,1个字节 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个
-
特殊符号需通过\来转义
//5)char:字符型,2个字节 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); //\
-
6. 类型间的转换
基本类型由小到大依次为:
byte----short( char----)----int----long----float----double
-
两种方式:
-
自动/隐式类型转换:小类型到大类型
-
强制类型转换:大类型到小类型
语法:(要转换成为的数据类型)变量
强转有可能溢出或丢失精度
//类型间的转换: 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
7. 运算符:运算的符号
-
算术:+,-,*,/,%,++,–
- %:取模/取余,余数为0即为整除
- ++/–:自增1/自减1,可在变量前也可在变量后
- 单独使用时,在前在后都一样
- 被使用时,在前在后不一样
- a++的值为a--------(a–的值为a)
- ++a的值为a+1------(–a的值为a-1)
//%的演示 System.out.println(8%2); //0,商4余0----整除 System.out.println(5%2); //1,商2余1 System.out.println(2%8); //2,商0余2 //++单独使用: int a=5,b=5; a++; //相当于a=a+1 ++b; //相当于b=b+1 System.out.println(a); //6 System.out.println(b); //6 //++被使用: int a=5,b=5; int c = a++; //1)保存a++的值5 2)a自增1变为6 3)将第1步保存的值5赋值给c--底层运算过程 //---粗暴记法:a++的值为5,c就是5 int d = ++b; //1)保存++b的值6 2)b自增1变为6 3)将第1步保存的值6赋值给d--底层运算过程 //---粗暴记法:++b的值为6,d就是6 System.out.println(a); //6 System.out.println(b); //6 System.out.println(c); //5 System.out.println(d); //6 //--单独使用: int a=5,b=5; a--; //相当于a=a-1 --b; //相当于b=b-1 System.out.println(a); //4 System.out.println(b); //4 //--被使用: int a=5,b=5; int c = a--; //a--的值为5,所以c的值为5 int d = --b; //--b的值为4,所以d的值为4 System.out.println(a); //4 System.out.println(b); //4 System.out.println(c); //5 System.out.println(d); //4
-
关系:>,<,>=,<=,==,!=
- 关系运算的结果为boolean型,
关系成立则为true,关系不成立则为false
int a=5,b=10,c=5; boolean b1 = a>b; System.out.println(b1); //false System.out.println(c<b); //true System.out.println(a>=c); //true System.out.println(a<=b); //true System.out.println(a==c); //true System.out.println(a!=c); //false System.out.println(a+c>b); //false
- 关系运算的结果为boolean型,