java相关问题

jvm如何判断一个同一个对象?
全类名相同 类加载器相同

final 能修饰什么
不可被继承类
不可覆盖的方法
只能初始化一次的变量

interface默认修饰级别
默认的修饰级别是public, 子类的等级不能小于超类

接口与子类
类只能单继承 接口可以多实现

private default protect public区别
什么都不写,默认的是default 不需要书写
public: Java语言中du访问限制最宽的修饰符,一般称之为“公共的”。被其修饰的类、属性以及方法不仅可以跨类访问,而且允许跨包(package)访问。本对象 同包 子类 跨类
protect: 介于public 和 private 之间的一种访问修饰符,一般称之为“保护形”。被其修饰的类、属性以及方法只能被类本身的方法及子类访问,即使子类在不同的包中也可以访问。本对象 同包 子类
default:即不加任何访问修饰符,通常称为“默认访问模式“。该模式下,只允许在同一个包中的类进行访问。本对象 同包
private: Java语言中对访问限制的最窄的修饰符,一般称之为“私有的”。被其修饰的类、属性以及方法只能被本身的对象访问,其子类不能访问,更不能允许跨包访问 本对象
在这里插入图片描述
default 和 protected区别在于子类能不能用,他两并不是没有区别

java中 哪里用到了值引用 哪里用到了值传递
Java中其实还是值传递的,只不过对于对象参数,值的内容是对象的引用。
https://blog.csdn.net/bjweimengshu/article/details/79799485

下面全是值传递
int 200 integer 200 string “” new string new object{string}

equals()与‘’的区别
默认情况下也就是从超类Object继承而来的equals方法与‘
’是完全等价的,比较的都是对象的内存地址,但我们可以重写equals方法,使其按照我们的需求的方式进行比较,如String类重写了equals方法,使其比较的是字符的序列,而不再是内存地址。

为什么重写equal要重写hashcode
java规定equal是hashcode的充分条件,hashcode是equal的必要条件,即equal相同,hashcode也要相同
其次是向hashmap中用到了hashcode,作为生成key的条件,如果自己重写的equal相同使两个对象相同,而没重写hashcode,还是用父类的hashcode,那相同的对象在map中的位置也是不一样的。

String,StringBuffer,StringBuilder的区别
string 换产生新的对象
StringBuilder线程不安全
如果要操作少量不变的数据,用String ;
单线程操作大量频繁变更的数据,用StringBuilder ;
多线程操作大量频繁变更数据,用StringBuffer。

string不可变重新分配空间,stringbuffer线程安全synchronized
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值