方法:
方法的调用:
类与对象的创建:
使用new关键字创建对象
类只包括属性与方法,类是抽象的,需要实例化
构造器的详解:
一个类即使什么都不写,也会存在一个构造器(方法)。
作用:1、使用new关键字,本质是在调用构造器
2、初始化对象的值
注意点:
1、定义有参构造之后,如果想使用无参构造,显示定义一个无参的构造
alt+insert 快速生成有参/无参构造函数
this. 代表当前类,后面=为传进来的值
package KuangJava.gouzaoq;
public class Person {
String name;
int age;
//无参构造
public Person() {
}
//有参构造
public Person(String name, int age) {
this.name = name;
this.age = age;
}
}
/*
public class Application {
public static void main(String[] args) {
Person person = new Person("kuangshen",23);
System.out.println(person.age+" "+person.name);
}
}
*/
创建对象内存分析:
总结:
面向对象三大属性:
一、封装
特点:大多是对于属性;属性私有,get/set:提供操作属性的方法
通常应禁止直接访问一个对象中数据的实际表现,而应通过操作接口来访问,这称为信息隐藏。
高内聚:该露的露,该藏的藏,类的内部数据操作细节主要隐藏在内部自己完成,不允许外部干预;低耦合:仅暴漏少量的方法给外部使用。
可以在方法里面写一些限制,安全性的验证。使得数据合法。
作用:1.隐藏代码实现的细节 2.提高程序的安全性,保护数据 3.统一接口 4.系统可维护性增加了
二、继承:
特点:大多是对于属性;属性私有,get/set:提供操作属性的方法
通常应禁止直接访问一个对象中数据的实际表现,而应通过操作接口来访问,这称为信息隐藏。
高内聚:该露的露,该藏的藏,类的内部数据操作细节主要隐藏在内部自己完成,不允许外部干预;低耦合:仅暴漏少量的方法给外部使用。
子类继承了父类,就会拥有父类的全部方法
若父类定义成private则子类不能使用
一般为了封装都会设置成private,但是可以通过写public方法来调用
Ctrl + H:查看当前类
在java中,所有的类,都默认直接或间接继承object类(里面有很多方法)。
java 中四个修饰符:public、private、protected、default(没有设置修饰符时默认的)
二、1)super:
私有的无法被继承,super也不能使用。
二、2)方法重写:
没有static的情况:
重写只跟非static方法有关
重写与父类长的一样,只是重写的方法不同。并且在子父类才有,子类继承了父类才可以重写。
三、多态:
通过父类去new子类:父类的引用指向子类
package KuangJava.gouzaoq;
public class Application {
public static void main(String[] args) {
Student s1= new Student();
Person s2 = new Student();
}
}
若子类重写了父类的方法,就会调用子类。
((Student) s2).eat;//换成这种形式才可以
多态注意事项:
1.多态是方法的多态,属性没有多态
2.父类和子类,有联系 。 类型转换异常:ClassCastException!
3.存在条件:继承关系,方法需要重写,父类引用指向子类对象!Father f1 = new Son();
不能重写的类型:
1.static 方法,属于类,它不属于实例
2.final 常量,不可修改
3.private 方法
三、1)instanceof和类型转换
两边有关系返回true,没关系返回false
System.out.println(x instanceof y);//能不能通过编译,取决于X跟Y是否存在父子关系
子类转换成父类,可能丢失自己本来的一些方法。
三、2)static:
要很多类去操作的话就要用static; 多线程。
四、抽象类
除非子类也是abstract
五、接口(interface)
必须要重写里面的方法。
六、内部类
静态内部类:
七、异常:
七.(1) 异常处理机制:
异常处理五个关键字:
try、catch、finally、throw、throws、
Ctrl + Alt + T: 自动生成try代码
抛出异常一般在方法里面用
package KuangJava.exception;
public class Demo01 {
public static void main(String[] args) {
try{
new Demo01().Test(1,0);
}catch(ArithmeticException e)
{
System.out.println("出现错误");
e.printStackTrace();
}
}
//假设这方法中处理不了这个异常,方法上抛出异常
public void Test(int a,int b) throws ArithmeticException
{
if(b==0)
{
throw new ArithmeticException();//主动输出异常,一般在方法中使用
}
}
}
有try及时错误也会继续运行,想办法在catch里面处理掉就好了。
七.(2)自定义异常:
package KuangJava.exception;
//自定义的异常类,继承Exception
public class Demo02 extends Exception{
//传递数字大于10
private int detail;
public Demo02(int a) {
this.detail = a;
}
//alt+insert
//toString:异常的打印信息
@Override
public String toString() {
return "Demo02{" + "detail=" + detail + '}';
}
}
package KuangJava.exception;
public class Test {
//可能会存在异常的方法
static void test(int a) throws Demo02 {
System.out.println("传递是参数为:"+a);
if (a>10)
{
throw new Demo02(a);//抛出
}
System.out.println("OK");
}
public static void main(String[] args) {
try {
test(1);//11
} catch (Demo02 demo02) {//捕获了上面的抛出,使用了Demo02里面的toString方法
//增加一些处理异常的代码
System.out.println("Demo02=>"+demo02);
}
}
}