牛客 - Java专项练习题知识点整理(四)

目录

构造方法修饰符

泛型

Java线程之间的通信

for语句执行流程

异常类Throwable

String classFile = "com.jd.".replaceAll(".","/")+"MyClass.class";

子类调用父类构造函数

进制的表现形式

HashMap如何解决hash冲突

Java是从哪个语言改进而来的

Java回收算法

ArrayList构造函数

Spring AOP 增强

对象的加载方式

URL地址


构造方法修饰符

构造方法不能被 static、final、synchronized、abstract、native修饰,但可以被 public、private、protected修饰。

构造函数不能被继承,只能被显式或隐式的调用。

泛型

1. 创建泛型对象的时候,一定要指出类型变量T的具体类型。争取让编译器检查出错误,而不是留给JVM运行的时候抛出类不匹配的异常。

2. JVM如何理解泛型概念 — 类型擦除。

        事实上,JVM并不知道泛型,所有的泛型在编译阶段就已经被处理成了普通类和方法。 处理方法很简单,我们叫做类型变量T的擦除(erased) 。

总结

1. 虚拟机中没有泛型,只有普通类和方法。

2. 在编译阶段,所有泛型类的类型参数都会被Object或者它们的限定边界来替换。(类型擦除)

3. 在继承泛型类型的时候,桥方法的合成是为了避免类型变量擦除所带来的多态灾难。 无论我们如何定义一个泛型类型,相应的都会有一个原始类型被自动提供。原始类型的名字就是擦除类型参数的泛型类型的名字。

补充:桥方法

Java中的类型擦除与桥方法

Java线程之间的通信

        Java线程之间的通信由Java内存模型(简称为JMM)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象的角度来看,JMM定义了线程和主内存之间的抽象关系:线程之间的共享变量存储在主内存(main memory)中,每个线程都有一个私有的本地内存(local memory),本地内存中存储了该线程以读/写共享变量的副本。本地内存是JMM的一个抽象概念,并不真实存在。它涵盖了缓存,写缓冲区,寄存器以及其他的硬件和编译器优化。

        volatile变量的读写可以实现线程之间的通信。

        从内存语义的角度来说,volatile与监视器锁有相同的效果:volatile写和监视器的释放有相同的内存语义;volatile读与监视器的获取有相同的内存语义。

for语句执行流程

for(条件1;条件2;条件3) {

    //语句

}

执行顺序是:条件1->条件2->语句->条件3->条件2->语句->条件3->条件2........

如果条件2为true,则一直执行。如果条件2为false,则for循环结束

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值