服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

类型转化与final修饰符

1.final修饰符

    有时候,你不希望别人坐享其成,通过继承你写的类得到他自己所需要的类,怎么办呢?这个时候你就可以在你的class之前加上final这个修饰府,例如public final class test{……},加上了这个修饰符之后,别人在继承这个类的话就会编译出错,提示他这个类不能构建子类。从这我们可以看出,final修饰符和abstract修饰符是不能同时使用的,因为abstract类可以说是专门用来继承的,而final类则不能用于继承。

    那么如果是在方法的前面加上final修饰符有什么作用呢?比如说a类中有个声明为final的方法a(){….},那么b继承a的时候,b就不能覆盖方法a(){….},否则编译出错,提示cannot override the final method from a。此外,如果一个类声明为final类的话,它里面所有的方法都自动成为final类型的。

    自然的,你肯定会问,如果一个域申明为final的时候有什么作用?一个属性声明为final之后,你不能在对它重新进行赋值,否则编译报错,the final field ×× cannot be assigned。另外,请注意,类声明为final的时候,仅仅它的方法自动变为final,而属性则不会。

2.类型转化:

    类型转换是java编程中比较常见的一种操作,特别是基本数据类型之间的转换,如long型转化为int型,int转化为long等等。

    类型的转化可以分成两类:强制转化与自动转化,例如long i=1;这个就叫自动转化,而int i=(long)1l,就是强制转化,这里我们主要讨论类对象之间的转化,还是以下面的代码为例:

public class polymorphictest {
       public polymorphictest() {       }
       public void setname(string n){
                     this.name=n;
                      system.out.println(“在父类中”); 
                                      } 
 public string getname(){
               return this.name;
                             }
                                    private string name;}

public class polymorphicchild extends polymorphictest {
       public void setarea(string a){
              this.area=a;              }
       public string getarea(){ 
             return this.area;              }
//public void setname(string n){//   super(“n”);
//   system.out.pirngln(“在子类中”);
//   }
       public static void main(string[] args) {
              polymorphicchild child=new polymorphicchild(); 
             polymorphictest test[]=new polymorphictest[2]; 
             test[0]=child; 
       polymorphicchild cast=(polymorphicchild)test[0]; 
       test[0].setname(“zhukai”);
              test[1]=new polymorphictest();       } 
      private string area;}

polymorphicchild同时包含了两种转化,test[0]=child是自动转化,而

polymorphicchild cast=(polymorphicchild)test[0]就是强制转化,如果没有

(polymorphicchild)的话编译就会出错,

    cannot convert from polymorphictest to polymorphicchild,那么是不是polymorphictest类型的对象都可以强制转化成polymorphicchild类型的呢?例如,我们有这么一行代码:

    polymorphicchild cast=(polymorphicchild)test[1]会不会出错呢?结果是编译不会出错,但是运行的时候会出错,classcastexception。那么什么时候才可以进行强制类型转化呢?

    首先,它们必须是同一个家族的,之间有继承关系;

    其次,假设有a的对象a,b的对象b,b是a的子类,什么条件下才能把a强制转化成b型别呢?a必须指向(refer to)b或者其子类的一个对象,即进行下运算a instanceof b即可,若返回值为ture即可,否则有错误。在本例中如果system.out.println(test[1] instanceof polymorphicchild)将会输出“false”,system.out.println(test[0] instanceof polymorphicchild)将会输出“true”。

3.抽象类

抽象类的用处是十分大的,特别是对于oop而言,关于抽象类,总结几点:

a.  抽象类不能实例化,即不能对其用new运算符;

b.  类中如果有一个或多个abstract方法,则该类必须声明为abstract;

c.  抽象类中的方法不一定都是abstract方法,它还可以包含一个或者多个具体的方法;

d.  即使一个类中不含抽象方法,它也可以声明为抽象类;

扫描关注微信公众号