4761人加入学习
(15人评价)
Java编程学习第二季

制作于2018年3月14日

价格 免费

接口不能实例化,接口内不能用static关键字

[展开全文]

引入类

import com.sikiedu2.person;

包  package com.sikiedu1;

protected 在不同包是不能访问的;

 

[展开全文]

类的方法里边可以通过传参来访问类的属性。

[展开全文]

类声明对象

类为啥不能直接使用

[展开全文]

this关键字 代表当前对象

[展开全文]

对象做为成员变量

main里两个对象

引用对象为成员变量

匿名对象(直接在方法里new一个对象)

一般生成的这个对象只是用一次

两个匿名变量相互调用

在内存里的情况

然后执行完该语句后 依次空间被释放

[展开全文]

我叫王俊楠  

我叫王俊凯

我是你老表

你可以叫我老铁

或者叫我铁子

哈哈

[展开全文]

public class maxNum 
{
    public static void main(String [] arg){
    int num1=8;
    int num2=9;
    System.out.println("Max ="+max(num1,num2));
}
    static int max(int x,int y)
    {
     if(x>y)   return x;
     else
     return y;
}
}

[展开全文]

使用setter和getter的好处:

(1)防止属性被外界随意的修改

 (2)使用setter和getter方法,可以在方法中添加一些约束,使程序更具有健壮性。

    比如: public void setter(int age){

       if(age <= 0){

         System.out.println("年龄不能小于等于0");

          return;

       }

          this.age = age;

    }

 

[展开全文]

构造子类时,会默认会调用父类里面的无参构造方法,对父类的属性进行初始化 ,隐式只会调用无参构造方法,若父类定义了有参构造方法则在构造子类时需显示调用父类构造方法 例如:super(a ,b,c,d);   

[展开全文]

父类引用指向子类对象时:

1、若子类覆盖了某方法,则父类引用调用子类重新定义的新方法

2.若子类未覆盖某方法,则父类引用调用旧方法

3.若子类覆盖了某属性,则父类引用调用旧属性

4.若子类未覆盖某属性,则父类引用调用旧属性

5.父类引用无法调用,子类新定义的属性和方法,编译会报错

 

子类引用指向自身对象时

1、若子类覆盖了某方法,则子类引用调用子类重新定义的新方法

2、若子类未覆盖某方法,则子类引用调用父类本身的旧方法

3、若子类覆盖了某属性,则子类引用调用子类重新定义的新属性

4、若子类未覆盖某属性,则子类引用调用父类本身的旧属性

5、子类引用可以访问子类新定义的方法

[展开全文]

在子类构造方法可用super();关键字构造父类的属性

继承属性覆盖的问题------------------

对象的属性值取决于我们定义的对象类型,而不是创建的对象类型!即当对象类型是父类(superclass),不管我们创建的对象是子类(new thisClass),还是父类(new superClass()),都不存在属性覆盖的问题!(不考虑private权限属性)!

superClasss s=new superClass(); ----父类的属性

superClass  s= new  thisClass();  ---父类的属性

 

thisclass s=  new thisclass(); ---子类的属性

 

 

 

一、父类引用指向子类对象时

1、若子类覆盖了某方法,则父类引用调用子类重新定义的新方法

2、若子类未覆盖某方法,则父类引用调用父类本身的旧方法

3、若子类覆盖了某属性,但父类引用仍调用父类本身的旧属性

4、若子类未覆盖某属性,则父类引用调用父类本身的旧属性

5、父类引用不能访问子类新定义的属性和方法

二、子类引用指向自身对象时

1、若子类覆盖了某方法,则子类引用调用子类重新定义的新方法

2、若子类未覆盖某方法,则子类引用调用父类本身的旧方法

3、若子类覆盖了某属性,则子类引用调用子类重新定义的新属性

4、若子类未覆盖某属性,则子类引用调用父类本身的旧属性

5、子类引用可以访问子类新定义的方法

 

代码示例

public class C extends B {
 
    int a = 3;
 
    @Override
    void f1() {
        System.out.println("C.f1()");
    }
 
    void f3() {
        System.out.println("C.f3()");
    }
 
    public static void main(String[] args) {
 
        B b = new C();// 父类引用指向子类对象
        b.f1();// 子类覆盖了该方法,所以父类引用调用新方法
        b.f2();// 子类未覆盖该方法,所以父类引用调用旧方法
        // b.f3();此行去掉注释会报错,父类引用不能访问子类新定义方法
        System.out.println(b.a);// 子类覆盖了该属性,但父类引用仍旧访问旧属性
        System.out.println(b.b);// 子类未覆盖该属性,父类访问旧属性
 
        System.out.println();
 
        C c = new C();// 子类引用指向自身对象
        c.f1();// 子类覆盖了父类方法,所以调用新方法
        c.f2();// 子类未覆盖父类方法,所以调用旧方法
        c.f3();// 子类调用自己新定义的方法
        System.out.println(c.a);// 子类覆盖了该属性,所以访问新属性
        System.out.println(c.b);// 子类未覆盖该属性,所以访问旧属性
    }

--------------------- 
作者:fanchaoo 
来源:CSDN 
原文:https://blog.csdn.net/u014738304/article/details/51986733 
版权声明:本文为博主原创文章,转载请附上博文链接!

 

[展开全文]

感谢siki老师!!,随机求[6,8]的整数,之前一直是糊涂的额,没弄明白过,今天终于清楚了,感谢!!!

[展开全文]

授课教师

SiKi学院老师

课程特色

下载资料(1)
视频(87)