探索吧 > 百科 > final的用法

final的用法

导读final的用法优质回答final的用法如下:(1)修饰变量用final关键字修饰的变量,只能进行一次赋值操作,并且在生存期内不可以改变它的值。final 修饰的变量可以先声明,后赋值。final修...

今天探索吧就给我们广大朋友来聊聊方法参数final,以下关于观点希望能帮助到您找到想要的答案。

final的用法

优质回答final的用法如下:

(1)修饰变量

用final关键字修饰的变量,只能进行一次赋值操作,并且在生存期内不可以改变它的值。final 修饰的变量可以先声明,后赋值。

final修饰基本类型时,起到常量的作用,基本类型的值不可变。

final修饰引用类型时,不能再指向其他的对象,但被引用的对象的值是可以改变的(引用变量的值实际上是它所引用的对象的地址)。

当用final作用于类的成员变量时,成员变量(局部变量只需要保证在使用之前被初始化赋值即可)必须在定义时或者构造器中进行初始化赋值。

(2)修饰方法参数

编写方法时,可以在参数前面添加final关键字,它表示在整个方法中,不会(实际上是不能)改变参数的值,具体类似于修饰数据。

即不能改变参数的值,但是可以改变引用类型参数的对象的值。同时,即使没有final的修饰,参数的改变也不会影响到方法外的变量。

(3)修饰方法

final关键字修饰方法,它表示该方法不能被覆盖(重写)。另外,类中所有的private方法都隐式地指定为是final的,由于无法在类外使用private方法,所以也就无法覆盖它。

此时可以在子类中定义相同的方法名和参数,这种情况不再产生重写与final的矛盾,而是在子类中重新定义了新的方法。可以对private方法添加final修饰符,但并没有添加任何额外意义。

(4) 修饰类

用final修饰的类是无法被继承的。且final类中的所有成员方法都会被隐式地指定为final方法。

final关键字在java中有哪些用法

优质回答1、final类

final类不能被继承,因此final类的成员方法没有机会被覆盖,默认都是final的。在设计类时候,如果这个类不需要有子类,类的实现细节不允许改变,并且确信这个类不会载被扩展,那么就设计为final类。

2、final方法

如果一个类不允许其子类覆盖某个方法,则可以把这个方法声明为final方法。

使用final方法的原因有二:

第一、把方法锁定,防止任何继承类修改它的意义和实现。

第二、高效。编译器在遇到调用final方法时候会转入内嵌机制,大大提高执行效率。

3、final变量(常量)

用final修饰的成员变量表示常量,值一旦给定就无法改变!

final修饰的变量有三种:静态变量、实例变量和局部变量,分别表示三种类型的常量。

另外,final变量定义的时候,可以先声明,而不给初值,这中变量也称为final空白,无论什么情况,编译器都确保空白final在使用之前必须被初始化。但是,final空白在final关键字final的使用上提供了更大的灵活性,为此,一个类中的final数据成员就可以实现依对象而有所不同,却有保持其恒定不变的特征。

4、final参数

当函数参数为final类型时,你可以读取使用该参数,但是无法改变该参数的值。

5、static和final一块用表示什么

static final用来修饰成员变量和成员方法,可简单理解为“全局常量”!

对于变量,表示一旦给值就不可修改,并且通过类名可以访问。

对于方法,表示不可覆盖,并且可以通过类名直接访问。

为什么匿名内部类方法参数要使用final

优质回答基础语法:如果定义一个匿名内部类,并且希望它使用一个在其外部定的对象,那么编译器会要求其参数引用是final的。

1.匿名内部类肯定是局部内部类(在一个方法里面定义的内部类),因为在java中,语句必须写在方法里,而匿名内部类其实就是一条特殊的语句;

2.外部给定的对象就是所有外来的对象:外部方法的形参、局部变量、基本类型或自定义类型等。

3.内部类很微妙,它可以直接访问外部类的privatefield,这打破了类的封装。但是内部类又有它自身的好处,比如简洁,可见性等,于是就把它定位成“只读”,也就是final。不过这个保护也非常脆弱!

4.local inner class访问local var时,那个var必须是final的。因为可以通过enclosing class访问那个local var,也可以通过inner class访问,可能造成问题,所以就必须是final的

5.匿名内部类为什么只能用final.是变量的作用域的问题,因为匿名内部类是出现在一个方法的内部的,如果它要访问这个方法的参数或者方法中定义的变量,则这些参数和变量必须被修饰为final。因为虽然匿名内部类在方法的内部,但实际编译的时候,内部类编译成Outer.Inner,这说明内部类所处的位置和外部类中的方法处在同一个等级上,外部类中的方法中的变量或参数只是方法的局部变量,这些变量或参数的作用域只在这个方法内部有效。因为编译的时候内部类和方法在同一级别上,所以方法中的变量或参数只有为final,内部类才可以引用。

6.例子

public class LocalInnerClassTest{

public static void main(String[] args){

Outer obj=new Outer(); //生成一个外部类对象

//调用外部类中的outer()方法,返回一个SuperInner类型对象赋值给si

SuperInner si=obj.outer();

si.m1(); //调用被覆盖的方法m1(),输出:Inner's m1() 20

}

}

/**

*定义一个接口SuperInner,内部定义一个抽象方法m1(),无返回类型

*/

interface SuperInner{

public void m1();

}

/**

*定义一个类Outer,内部只定义一个方法outer(),返回类型为SuperInner

*/

class Outer{

public SuperInner outer(){

int a=10; //方法中定义一个局部变量a,并赋值为10

final int b=20; //再定义一个final局部变量b,初始化为20

//在outer()方法中定义一个局部内部类Inner,实现接口SuperInner

class Inner implements SuperInner{

public void m1(){ //类中只有一个覆盖接口SuperInner的方法m1()

System.out.println("Inner's m1()"+a); //编译报错

//编译通过,输出:Inner's m1() 20

System.out.println("Inner's m1() "+b);

}

}

return new Inner();

}

}

我们先从主方法开始看代码的执行顺序,先生成一个Outer类对象obj,obj调用本类中方法outer();程序开始跳到outer()方法内执行程序语句,先后生成局部变量a和b,再定义一个局部内部类Inner,返回一个SuperInner类型的对象。将返回的SuperInner类型对象地址传给SuperInner类型对象si。si再调用m1()方法,因为已经在局部内部类中覆盖了接口中的m1()方法,所以将调用局部内部类中的m1() 方法,程序跳到局部内部类中m1()方法内执行程序语句,先输出一段字符串和a,结果编译报错,先 将这条程序语句隐藏,执行下面的语句,你会发现编译通过而且输出Inner's m1() 20!

为什么会这样呢大家都知道局部变量仅仅在一个范围内有效,在方法调用完就被内存释放,在Outer类对象obj调用outer()方法时,a和b才产生,调用结束后被内存释放,那么b这个值也就不复存在了,为什么还会输出20呢难道局部变量被final修饰就不会被内存释放而保留其实有部分操作对于程序员是透明的,那是JAVA语言开发者的小把戏,在定义a和b 时JVM(JAVA虚拟机)做了程序员看不到的操作,他将b拷贝了一份给局部内部类,也就是说JVM在局部内部类中定义了一个final int b=20;这个操作程序员是不知道的!当调用m1()方法时输出的20并不是原来outer()方法中定义的b,而仅仅是JVM拷贝的一个副本。那么为什么a没被打印出呢那是因为JVM并没有拷贝它,因为没有final修饰,说明它可以被修改,如果把a 改为 a++,此时JVM就不知道拷贝a还是a++了,所以对于无final修饰的局部变量JVM是不会拷贝传给局部内部类的,自然无法打输出!

在Java中,final修饰符要如何使用

优质回答final,字面上的意思是“最后的,最终的”,在Java中表示同样的含义。

final可以用来修饰变量、方法和类。

1.final修饰类

final修饰类时表示此类是“最后的、最终的”,即不能被继承,不能拥有自己的子类。

如果试图对一个已经用final修饰的类进行集成,则会在编译期间发生错误。

2.final修饰方法

final修饰方法表示此方法已经是“最后的、最终的”含义,即此方法不能被重写,但是可以被重载。PS:重写的前提是子类可以继承父类的方法,如果父类中final修饰的方法同时设置权限为private,则会导致子类不能继承此方法。但是,可以在子类中重新定义相同方法名和参数的方法,此时不会产生重写与final的矛盾。而是在子类中重新定义了新的方法。因为父类中及被private又被final修饰的那个方法根本没有被继承,子类在重新定义这个同名同参数方法时不会发生编译错误。

3.final修饰变量

final修饰的变量表示此变量是“最后的、最终的”。一旦定义了final变量并且在为其显示初始化后,final修饰的变量值不可被改变。

注意Attention:

1、final修饰的变量,无论是类属性、对象属性、形参还是局部变量,这些变量都需要程序员显示初始化,系统不会对final成员边来那个进行隐式初始化。

final修饰局部变量,与为被final修饰的变量一样,都需要显示初始化。即局部变量都需要显示初始化。

对一般的类属性和对象属性而言,首先都是先进行默认初始化,然后在对有显示赋值的变量进行显示初始化。

2、Java规定final修饰的类属性和变量熟悉感必须要进行显示初始化赋值。

3、无论是度与基本数据类型还是引用数据类型,final修饰的变量都是首次显示初始化后就不能修改的。对于final修饰的基本数据类型,由于在编译时就能确定该变量的至,于是吧该变量当做常量来处理。(常量命名规则:多个有意义的单词连接是,所有字符大写,单词之间用下划线分割)。对于final修饰的是引用数据类型,由于无法在编译是获得值,只能在运行时获得值。引用变量指向的是实际的对象,但是存储的是所指向对象的地址,因此,气质不能修改以为着其所指向的对象不能修改,即指向哪一个只能一直指向他,不能指向别的对象,但是可以修改这个对象内的属性。

在方法参数中使用final有什么用?

优质回答1常量(final)的设置是不是只是为了防止程序员在以后修改程序时,忘记这个值是不能修改的?如果假设“程序员一定记得”这个值不允许改变,那么就可以不设为final吧?x0dx0ax0dx0a程序员工作不是一个人的工作,你设置为final,别人将来维护的时候一看就知道这个变量不能修改,而不需要去记忆这个是不能变化的值,是常量。这个是代码规范。x0dx0a另外final常量一般设置为static的,一定程度上节省了内存开销。x0dx0ax0dx0a2有些方法的参数中会声明参数为final,这样用有什么用?例如publicA(finalMapmap);x0dx0a参数声明为final就是标明这个对象的内存地址不允许修改。即就是如果你在方法里面修改为x0dx0amap=newHashMap();是不允许的。但是map里面的值可以修改。x0dx0a举一个例子x0dx0apublicclassTest{x0dx0ax0dx0apublicstaticvoidmain(String[]args){x0dx0ax0dx0aMapmap=newHashMap();x0dx0ax0dx0aprocess(map);x0dx0ax0dx0aSystem.out.println(map.keySet().iterator().next());//结果输出aaax0dx0a}x0dx0ax0dx0aprivatestaticvoidprocess(finalMapmap){x0dx0amap.put("aaaa","1111");//尽管map为final,但是只是地址不变x0dx0a//map里面的内容可以改变x0dx0a//map=newHashMap();//当从新为final变量map分配内存地址,x0dx0a//引起编译错误,因为final修饰的map内存地址不可以改变。x0dx0ax0dx0a}x0dx0ax0dx0a}

明白final的用法的一些要点,希望可以给你的生活带来些许便利,如果想要了解其他内容,欢迎点击探索吧的其他栏目。

本文来自网络,不代表本站立场,转载请注明出处:https://www.tsc-b.com/baike/141754.html

作者: 探索吧

探索吧为您提供最全面的生活百科网站大全,主要为您提供数码、汽车、财经、美食、财经、科技、健康、教育、创业、电商、影视、百科等资讯信息,在这里可以找到您所需的答案,解决您所困惑的问题。
土质检测收费标准表。土质检测费用
腰椎压迫神经怎么治疗最有效
联系我们

联系我们

0898-88881688

在线咨询: QQ交谈

邮箱: email@wangzhan.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部