javaload
1. java中重载和重写的区别是什么
重载: 发生在同一个类中,方法名必须相同,参数类型不同、个数不同、顺序不同,方法返回值和访问修饰符可以不同,发生在编译时。
重写: 发生在父子类中,方法名、参数列表必须相同,返回值范围小于等于父类,抛出的异常范围小于等于父类,访问修饰符范围大于等于父类;如果父类方法访问修饰符为 private 则子类就不能重写该方法。
2. java中重载与重写的区别
java中有两个东西,一个是 方法重载 一个是 成员覆写 ,
方法重载 是指 一个类里面可以有多个方法,而且方法名称相同,但是方法的参数类型或者参数个数不同,功能也可以不同。
成员覆写 是指子类继承父类后,可以覆盖掉父类的 方法 和 属性。子类的方法和属性名称类型与父类的一样,就覆盖掉父类的属性和方法。
重载只能是方法,在同一个类中。
覆写是子类与父类之间,属性与方法都可以覆写。
其实重写就是重载,而令一个是覆写。
3. Java多线程内存读写 —— 内存屏障的理解
在多核CPU环境下,Java通过JMM内存模型为了解决并发编程中的指令乱序与不可见性问题,引入了四个内存屏障指令:LoadLoad、StoreStore、LoadStore和StoreLoad。这些屏障的主要作用是确保在多核处理器中的程序执行结果与单线程环境下的顺序性一致,即遵守as-if-serial原则。
内存屏障分为两个主要效果:顺序性和可见性。由于缓存的存在,即使指令按顺序执行,数据一致性也可能受到挑战。读屏障(如LoadLoad)确保前后读取的数据顺序,而写屏障(如StoreStore)保证写入数据对其他处理器的可见性。LoadStore和StoreLoad则处理读写操作的顺序,确保读操作在数据写入可见后进行,避免脏读和缓存一致性问题。
在物理实现层面,内存屏障对应于CPU中的StoreBuffer、InvalidQueue以及读写屏障操作。例如,在x86体系中,除了StoreLoad需要特定指令支持外,其他屏障在x86处理器中通常为no-op,因为其缓存机制已能保证顺序性。然而,这些no-op指令仍对性能有所影响,尽管代价较低。
在Java编程中,正确使用内存屏障至关重要,尤其是在多线程并发操作中,以确保数据的一致性和正确执行。理解并根据JMM内存模型的需求选择适当的屏障指令,可以避免潜在的并发问题。