java导⼊类_java怎么导⼊类
你好,世界!
源代码组织⽅式
Java程序由package+class组成,package对应⽬录的相对路径,class对应⽂件,如
E:\Workspaces\MyEclipse
10\JavaStudy\src\com\happyframework\javastudy\hello\Hello.java
关于class有如下⼏点规则:
⽂件的名字必须和class的名字⼀致(public级别的class名字)。⽂件必须只包含⼀个public访问基本的class(可以包含多个⾮public级别的class)。package名字必须和⽬录⼀致。1⼊⼝⽅法
App.java
2
最终的项⽬结构
3
java接口有没有构造方法数据类型
8种原⼦类型
整数类型:byte、short、int和long。⼩数类型:float和double。字符类型:char。布尔类型:bool。除此之外的是interface、class和array。
⼩数类型的常量默认是double类型,声明float类型的常量需要使⽤F作为后缀。
4
运算符
算术运算符:+、-、*、/ 和 %,两个整数相除,结果还是整数。赋值运算符:=、+=、-=、*=、/=、%=、&=、|=、~=、^=、>>=、<<=、 <<<=、++ 和 --。⽐较运算符:==、!=、>、>=、< 和 <=。逻辑运算符:&&、|| 和 !。位运算符:&、|、~、^、>>、<< 和 <<
字符串
String是拥有“值语义”的引⽤类型,字符串常量实现了“享元模式”,equals会按照内容进⾏⽐较,==按照地址⽐较。
为了⾼效的修改字符串Java引⼊了StringBuffer。
6
数组
声明语法
DataType[] name 或 DataType name[]。
初始化语法
DataType[] name = new DataType[length]。
DataType[] name = new DataType[] { element1, element2, ...elementn }。
DataType[] name = { element1, element2, ...elementn }。
多维数组
只有不等长多维数组DataType[][],没有DataType[xxx, xxx]。
控制结构
条件:if-else if-else、switch-case-default和三元运算符(?:)。循环:while、do-while、for和foreach。Labeled block。
最近觉得label是个不错的东西,最起码多了⼀种选择。
⽅法
Java中所有的赋值和⽅法调⽤都是“按值“处理的,引⽤类型的值是对象的地址,原始类型的值是其⾃⾝。
Java⽀持变长⽅法参数。
7
注意:调⽤⾃⾝的构造⽅法是⽤this(xxx,xxx,...)来完成,且必须位于第⼀⾏。
静态成员
Java中类似静态构造⽅法的结构,称之为:静态初始化代码块,与之对应的是实例初始化代码块,见下例:
8
继承
继承使⽤ extends,抽象类和抽象⽅法使⽤abstract声明,向下转型使⽤ (ChildType)instance,判断是否是某个类型使⽤ instanceof,见下例:
9
重写
Java中的重写规则⽐较灵活,具体如下:
除了 private 修饰之外的所有实例⽅法都可以重写,不需要显式的声明。重写的⽅法为了显式的表达重写这⼀概念,使⽤ @Override进⾏注解。重写的⽅法可以修改访问修饰符和返回类型,只要和⽗类的
⽅法兼容(访问级别更⾼,返回类型更具体)。可以使⽤final将某个⽅法标记为不可重写。在构造⽅法中使⽤ super(xxx, xxx)调⽤⽗类构造⽅法,在常规实例⽅法中使⽤ hod(xxx, xxx)调⽤⽗类⽅法。Java不⽀持覆盖(new)。
10
包的名字和项⽬路径下的⽬录路径相对应,⽐如:项⽬路径为:C:\Study,有⼀个Java源⽂件位于:C:
\Study\com\happyframework\study\App.java,那么App.java的包名字必须为:com.happyframework.study,且 App.java 的第⼀⾏语句必须为:package com.happyframework.study。
Java⽀持三种导⼊语法:
导⼊类型:xClass。导⼊包:x.*。导⼊静态成员:import *。
11
访问级别
Java⽀持四种访问级别:public、private、protected 和 default(默认),类型和接⼝只能使⽤public 和 default,成员和嵌套类型可以使⽤所有,下⾯简单的解释⼀下 protected 和 default。
protected 修饰过的成员只能被⾃⼰、⼦类和同⼀个包⾥的(不包括⼦包)其他类型访问。default 修改过的类型或成员只能被⾃⼰和同⼀个包⾥的(不包括⼦包)其他类型访问。嵌套类
Java⽀持如下⼏种嵌套类:
nested class,定义在类型内部的类型。static nested class,使⽤ static 声明的 nested class,static nested class 可以访问所有外部类的静态成员。inner class,没有使⽤ static 声明的 nested class,inner class 可以访问所有外部类的实例成员,inner class 不能定义静态成员。代码⽰例
特殊的inner class:local class
除了inner class的规则之外,local class可以访问局部final变量,在Java8中有更多的改进。
特殊的local class:anonymous class
12
常量
不废话了,直接看代码:
有⼀点需要注意的是:只有⼀种情况Java的常量是编译时常量(编译器会帮你替换),其它情况都是运⾏时常量,这种情况是:静态类型常量且常量的值可以编译时确定。
接⼝
Java的接⼝可以包含⽅法签名、常量和嵌套类,见下例:
13
枚举
Java枚举是class,继承⾃java.lang.Enum,枚举中可以定义任何类型可以定义的内容,构造⽅法只能是private或package private,枚举成员会被编译器动态翻译为枚举实例常量,见下例:
调⽤枚举的构造⽅法格式是:常量名字(xxx, xxx),如果构造⽅法没有参数只需要:常量名⼦,如:
14
异常
Java中的异常分为checked和unchecked,checked异常必须声明在⽅法中或被捕获,这点我觉得⽐较好,必定:异常也是API的⼀部分,见下例:
所有继承Exception的异常(除了RuntimeException和它的后代之外)都是checked异常。
15
装箱和拆箱
Java提供了原始类型对应的引⽤类型,在1.5之后的版本还提供了⾃动装箱和⾃动拆箱,结合最新版本的泛型,⼏乎可以忽略这块。
注意:⾃动装箱和⾃动拆箱是Java提供的语法糖。
16
泛型
Java的泛型是编译器提供的语法糖,官⽅称之为:类型参数搽除,先看⼀下语法,然后总结⼀点规律:
泛型⽅法
测试代码
调⽤泛型⽅法
输出的结果是
17
泛型类
测试代码
调⽤代码
输出结果
18
泛型接⼝
测试代码
调⽤代码
输出结果
19
类型参数约束
测试代码
调⽤代码
输出结果
类型搽除过程
将泛型定义中的类型参数去掉。
2.将T换成extends指定的约束类型,默认是Object。
3.如果有⾮泛型类型继承或实现了泛型基类或接⼝,⽽且进⾏了重写,根据情况,编译器会⾃动⽣成⼀些⽅法。
4.根据泛型参数的实际参数搽除调⽤代码。
这⾥说的不⼀定正确,特别是Java泛型的约束⽀持&(如:可以约束实⾏多个接⼝),不过过程估计差别不⼤,我没有看Java语⾔规范,这⾥只是⼤概的猜测。
然后今天就讲到这⾥啦,⼤家记得点赞收藏,分享转发,关注⼩哦!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。