Java深入理解final ,ArrayList,LinkedList

1.final

final:不可改变的

最常见的三大回答:

1.被final修饰的类不可以被继承

2.被final修饰的方法不可以被重写

3.被final修饰的变量不可以的被修改

比较浅显的理解也就是止步于此,那么再深入研究一下:

问final修饰变量,是变量引用的内容不可改变?还是变量的引用不可改变?或者两者都不可改变???

答:final对于引用数据类型,不能改变的是引用(即:引用的首地址的值),可以改变引用的内容。

举例:

public class Demo(){

    public static void main(String[] arge){

        final StringBuffer strbuf=”hello”;

        Append() app=new Append();

        app.appendStr(strbuf);
    
        System.out.println(strbuf);

    }



}



class Append(){

    public void appendStr(final StringBuffer sb){

        sb.append(“world”);

    }



}

 

这个例子输出的是:”helloworld”.

解释:因为java是值传递(传递的是首地址的值),所以形参sb和strbuf指向相同,sb.append()追加字符后引用内容改变,但是首地址的值并没有改变。

所以final改变的是引用内容,不改变引用的地址值。

 

2.ArrayList和linkedList

ArrayList和LinkedList区别:

常规回答:

ArrayList是动态数组的数据结构,LinkedList是双向链表的数据结构。

ArrayList必须是连续内存的,LinkedList不要求连续内存。

ArrayList查询快,增加和删除慢。LinkedList是增加和删除快,查询慢。

解释:

ArrayList是连续内存且有下标,查询迅速,但是因为是连续内存所以当你从中间删除或增加一个元素时,后面的元素都要后移,耗时,耗能。相反,LinkedList采用双向链表结构且不连续,当你增加或删除,只需要改变增加元素和前后元素的链表结构就可以了。但是,当你查询的时候,需要从一端遍历到另外一端,耗时,耗能。

示意图:LinkedList

ArrayList

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值