方法参数类型以及返回值类型问题
类名作为形式参数
如果你以后看到一个方法的形参要一个类 类型,你就传一个该类的对象
例:
public class MyTest {
public static void main(String[] args) {
Student student = new Student();
int num=2;
set(student,num);
student.show(new Student(),100);
System.out.println(student.num);
}
public static void set(Student student,int num){
student.num=num;
}
}
class Student{
int num=10;
public void show(Student student,int num){
student.num=num;
}
}
结果为100
抽象类名作为形式参数
如果你以后看到一个方法的形参要一个抽象类 类型,那么你就传一个该抽象类的子类对象
例:
public class MyTest {
public static void main(String[] args) {
int num=1;
Zi zi = new Zi();
set(new Zi(),num);
zi.show(188);
System.out.println(zi.num);
}
public static void set(Fu fu,int num){
fu.num=num;
}
}
abstract class Fu{
int num=100;
public abstract void show(int num);
}
class Zi extends Fu{
int num=10;
@Override
public void show(int num) {
this.num=num;
}
}
打印 188
接口名作为形式参数
如果你以后看到一个方法的形参要一个接口类型,你要传一个该接口的子类对象
例:
public class MyTest {
public static void main(String[] args) {
int num=1;
B b = new B();
set(b,num);
System.out.println(b.a);
System.out.println(b.NUM);
System.out.println(A.NUM);
System.out.println(B.NUM);
}
public static void set(A a,int num){
new B().a=num;
a.show(num);
}
}
interface A{
public static final int NUM=100;
void show(int num);
}
class B implements A{
int a=10;
@Override
public void show(int num) {
this.a=num;
}
}
打印:
10
100
100
100
类名作为返回值类型
如果你以后看到一个方法的返回值类型 是一个 类 类型,你就返回该类的一个对象
例:
public class MyTest {
public static void main(String[] args) {
int num = 100;
A a = new A();
A a1 = a.getA(num);
System.out.println(a.num);
System.out.println(a1.num);
}
public static A getAA(A a, int num) {
a.num = num;
return a;
}
}
class A {
int num = 1;
public A getA(int num) {
A a = new A();
a.num = num;
return a;
}
}
打印:
1
100
抽象类名作为返回值类型
如果你以后看到一个方法的返回值类型,要一个抽象类 类型,你就返回一个该抽象类的子类对象
public class MyTest {
public static void main(String[] args) {
Zi zi = new Zi();
Fu fu = zi.getFu(zi, 109);
System.out.println(zi.num);
System.out.println(fu.num);
}
}
abstract class Fu {
int num = 10;
}
class Zi extends Fu {
public Fu getFu(Fu fu, int num) {
fu.num = num;
return this;
}
}
打印:
109
109
接口名作为返回值类型
如果你以后看到一个方法的返回值类型,要一个接口类型,你就返回该接口的一个子类对象
例:
public class MyTest {
public static void main(String[] args) {
MyClass myClass = new MyClass();
int num=2;
MyInterface myInterface = get(myClass, num);
myClass.show(109);
System.out.println(myClass.num);
System.out.println(myInterface.NUM);
}
public static MyInterface get(MyClass myClass,int num){
myClass.num=num;
return myClass;
}
}
interface MyInterface{
int NUM=100;
void show(int num);
}
class MyClass implements MyInterface{
int num=1;
@Override
public void show(int num) {
this.num=num;
}
}
打印:
109
100
package关键字的概述及作用
A:包的概述: 就是文件夹
B:包的作用: 用来解决同一个路径下不能存在同名文件的问题(分类管理)
C:包的划分:
按照功能
按照模块
包的定义及注意事项:
A:定义包的格式
package 包名;
多级包用.分开即可
B:定义包的注意事项
A:package语句必须是程序的第一条可执行的代码
B:package语句在一个java文件中只能有一个
C:如果没有package,默认表示无包名
C:案例演示
包的定义及注意事项
import关键字的概述和使用
A:导包的概述
不同包下的类之间的访问,我们发现,每次使用不同包下的类的时候,都需要加包的全路径。比较麻烦。这个时候,java就提供了导包的功能
B:导包格式
import 包名;
注意:
这种方式导入是到类的名称。
虽然可以最后写*,但是不建议。
四种权限修饰符的测试
本类 同一个包下(子类和无关类) 不同包下(子类) 不同包下(无关类)
private Y
默认 Y Y
protected Y Y Y
public Y Y Y Y
类及其组成所使用的常见修饰符
A:修饰符:
权限修饰符:private,默认的,protected,public
状态修饰符:static,final
抽象修饰符:abstract
B:修饰类的关键字:
权限修饰符:默认修饰符,public
状态修饰符:final
抽象修饰符:abstract
用的最多的就是:public
C:修饰成员变量的关键字:
权限修饰符:private,默认的,protected,public
状态修饰符:static,final
用的最多的就是:private
D:修饰构造方法的关键字:
权限修饰符:private,默认的,protected,public
用的最多的就是:public
E:修饰成员方法的关键字:
权限修饰符:private,默认的,protected,public
状态修饰符:static,final
抽象修饰符:abstract
用的最多的就是:public
F:除此以外的组合规则:
成员变量:public static final
成员方法:public static
public abstract
public final
内部类
内部类概述和访问特点
概述:
把类定义在其他类的内部,这个类就被称为内部类。
特点:
a:内部类可以直接访问外部类的成员,包括私有。
b:外部类要访问内部类的成员,必须创建对象。
内部类分类及成员内部类的直接使用
A:按照内部类位置分类
成员位置:在成员位置定义的类,被称为成员内部类。
局部位置:在局部位置定义的类,被称为局部内部类。
B:成员内部类
如何在测试类中直接访问内部类的成员。
格式: 外部类名.内部类名 对象名 = 外部类对象.内部类对象;
成员内部类的常见修饰符及应用
A:成员内部类的修饰符:
private 为了保证数据的安全性
static 为了方便访问数据
注意事项:
a:静态内部类访问的外部类数据必须用静态修饰。
b: 成员方法可以是静态的也可以是非静态的
B:成员内部类被静态修饰后的访问方式是:
格式: 外部类名.内部类名 对象名 = new 外部类名.内部类名();
局部内部类访问局部变量的问题
A: 可以直接访问外部类的成员,包括私有
B: 可以创建内部类对象,通过对象调用内部类方法,来使用局部内部类功能
C:局部内部类访问局部变量必须用final修饰
为什么呢?
因为局部变量会随着方法的调用完毕而消失,这个时候,局部对象并没有立马从堆内存中消失,还要使用那个变量。
为了让数据还能继续被使用,就用fianl修饰,这样,在堆内存里面存储的其实是一个常量值。
成员内部类:
class Outer {
class Inner{
public void show(){
System.out.println("这是成员内部类的show方法");
}
}
}
class InnerClassDemo {
public static void main (String[] args) {
Outer.Inner inner = new Outer().new Inner();
inner.show();
}
}
匿名内部类
匿名内部类的格式和理解
A:匿名内部类: 就是局部内部类的简化写法。
B:前提: 存在一个类或者接口;这里的类可以是具体类也可以是抽象类。
C:格式:
new 类名或者接口名(){
重写方法;
} ;
D:本质是什么呢?
是一个继承了该类或者实现了该接口的子类匿名对象。
例题:
按照要求,补齐代码
interface Inter { void show(); }
class Outer { //补齐代码 }
class OuterDemo {
public static void main(String[] args) {
Outer.method().show();
}
}
要求在控制台输出”HelloWorld”
补完如下:
interface Inter {
void show();
}
class Outer {
public static Inter method(){
return new Inter() {
@Override
public void show() {
System.out.println("HelloWorld");
}
};
}
}
class OuterDemo {
public static void main(String[] args) {
Outer.method().show();
}
}
类中定义接口
概述:
在一个类中可以定义一个接口
例:
public class Mytest {
public static void main(String[] args) {
Outer outer = new Outer();
outer.method();
}
}
class Outer{
interface Inner{
void show();
}
public void method(){
new Inner(){
@Override
public void show() {
System.out.println("重写了接口中的show方法");
}
}.show();
}
}
总结: 主要学习了方法参数类型以及返回值类型问题,还有内部类,以及匿名内部类的运用。