魏晓东 发表于 7 天前

步伐人生——Java中类、对象及方法的建议(1)

https://i-blog.csdnimg.cn/blog_migrate/594dc1eade291a3d6706be94cc80bffd.png


引出

步伐人生——Java中类、对象及方法的建议(1)
类、对象及方法

建议31:在接口中不要存在实现代码



[*]可以通过在接口中声明一个静态常量s,其值是一个匿名内部类的实例对象,可以实现接口中存在实现代码
建议32:静态变量肯定要先声明后赋值



[*]也可以先利用后声明,因为静态变量是类初始化时首先被加载,JVM会去查找类中全部的静态声明,然后分配空间,分配到数据区(Data Area)的,它在内存中只有一个拷贝,不会被分配多次,注意这时间只是完成了地点空间的分配还没有赋值,之后JVM会根据类中静态赋值(包罗静态类赋值和静态块赋值)的先后顺序来实行,背面的操作都是地点稳固,值改变
建议33:不要覆写静态方法



[*]一个实例对象有两个类型:表面类型和实际类型,表面类型是声明时的类型,实际类型是对象产生时的类型。对于非静态方法,它是根据对象的实际类型来实行的,即实行了覆写方法。而对于静态方法,首先静态方法不依赖实例对象,通过类名访问;其次,可以通过对象访问静态方法,如果通过对象访问,JVM则会通过对象的表面类型查找到静态方法的入口,继而实行
建议34:构造函数只管简化



[*]通过new关键字天生对象时肯定会调用构造函数。子类实例化时,首先会初始化父类(注意这里是初始化,可不是天生父类对象),也就是初始化父类的变量,调用父类的构造函数,然后才会初始化子类的变量,调用子类本身的构造函数,最后天生一个实例对象。构造函数太复杂有可能造成,对象利用时还没完成初始化
建议35:制止在构造函数中初始化其他类



[*]有可能造成不断的new新对象的死循环,直到栈内存被消耗完抛出StackOverflowError非常为止
建议36:利用构造代码块精炼步伐



[*]四种类型的代码块:

[*]**1、普通代码块:**在方法背面利用“{}”括起来的代码片断;
[*]**2、静态代码块:**在类中利用static修饰,并利用“{}”括起来的代码片断;
[*]**3、同步代码块:**利用synchronized关键字修饰,并利用“{}”括起来的代码片断,表示同一时间只能有一个县城进入到该方法;
[*]**4、构造代码块:**在类中没有任何的前缀或后缀,并利用“{}”括起来的代码片断。编译器会把构造代码块插入到每个构造函数的最前端。
[*]构造代码块的两个特性:1、在每个构造函数中都运行;2、在构造函数中它会首先运行

建议37:构造代码块会想你所想



[*]编译器会把构造代码块插入到每一个构造函数中,有一个特殊情况:如果遇到this关键字(也就是构造函数调用自身其他的构造函数时)则不插入构造代码块。如果遇到super关键字,编译器会把构造代码块插入到super方法之后实行
建议38:利用静态内部类进步封装性



[*]Java嵌套内分为两种:1、静态内部类;2、内部类;静态内部类两个优点:增强了类的封装性和进步了代码的可读性。静态内部类与普通内部类的区别:1、静态内部类不持有外部类的引用,在普通内部类中,我们可以直接访问外部类的属性、方法,即使是private类型也可以访问,这是因为内部类持有一个外部类的引用,可以自由访问。而静态内部类,则只可以访问外部类的静态方法和静态属性,其他则不能访问。2、静态内部类不依赖外部类,普通内部类与外部类之间是相互依赖的关系,内部类不能脱离外部类实例,同声同死,一起声明,一起被垃圾回收器回收。而静态内部类可以独立存在,即使外部类灭亡了;3、普通内部类不能声明static的方法和变量,注意这里说的是变量,常量(也就是final static修饰的属性)照旧可以的,而静态内部类形似外部类,没有任何限制
建议39:利用匿名类的构造函数



[*]List l2 = new ArrayList(){}; //定义了一个继承于ArrayList的匿名类,只是没有任何的覆写方法而已
List l3 = new ArrayList(){{}}; //定义了一个继承于ArrayList的匿名类,并且包含一个初始化块,类似于构造代码块)
建议40:匿名类的构造函数很特殊



[*]匿名类初始化时直接调用了父类的同参数构造器,然后再调用本身的构造代码块
深入认识JVM

JVM内存分配,类加载

Java进阶(1)——JVM的内存分配 & 反射Class类的类对象 & 创建对象的几种方式 & 类加载(何时进入内存JVM)& 注解 & 反射+注解的案例
https://i-blog.csdnimg.cn/blog_migrate/9d86e3e499c9402c0f39ceb60d0babc4.png
创建对象的4种方法总结

Java进阶(4)——结合类加载JVM的过程理解创建对象的几种方式:new,反射Class,克隆clone(拷贝),序列化反序列化
https://i-blog.csdnimg.cn/blog_migrate/7cb8f7f19bfe1e2d7778aa3a1b112761.png
垃圾回收GC

https://i-blog.csdnimg.cn/blog_migrate/7a6a26a970996afb73168ac7c45be06b.png
Java进阶(垃圾回收GC)——理论篇:JVM内存模子 & 垃圾回收定位清除算法 & JVM中的垃圾回收器
简介:本篇博客介绍JVM的内存模子,对比了1.7和1.8的内存模子的厘革;介绍了垃圾回收的语言发展;论述了定位垃圾的方法,引用计数法和可达性分析发以及垃圾清除算法;然后介绍了Java中的垃圾回收器,由串行、到并行再到并发,最后到G1的演变;最后给出了垃圾回收器的对比和利用指引。
JVM调优,Arthas利用



[*]Java进阶(JVM调优)——阿里云的Arthas的利用 & 安装和利用 & 死锁查找案例,重新加载案例,慢调用分析
[*]Java进阶(JVM调优)——JVM调优参数 & JDK自带工具利用 & 内存溢出和死锁问题案例 & GC垃圾回收
https://i-blog.csdnimg.cn/blog_migrate/af9ffe6991dd6b43e5873656cab3a11c.png
https://i-blog.csdnimg.cn/blog_migrate/fe07dfd768e7dfbcfef3c96fd4a63c05.png
https://i-blog.csdnimg.cn/blog_migrate/0e888eb85c22c9bd072906aee6bb84c4.png
认识多线程

创建多线程方法+相识线程池

Java进阶(5)——创建多线程的方法extends Thread和implements Runnable的对比 & 线程池及常用的线程池
https://i-blog.csdnimg.cn/blog_migrate/c18f86e823ba5f47065d2ac6a7ad7a61.png
多线程下-1非原子性问题即解决

Java进阶(6)——抢购问题中的数据不安全(非原子性问题)& Java中的synchronize和ReentrantLock锁利用 & 死锁及其产生的条件
https://i-blog.csdnimg.cn/blog_migrate/ebf58c28c7159cc3d3fa105db622f033.png
再论线程,创建、生命周期

Java进阶(再论线程)——线程的4种创建方式 & 线程的生命周期 & 线程的3大特性 & 集合中的线程安全问题
紧张内容:
1.线程创建的方式,继承Thread类,实现Runable接口,实现Callable接口,接纳线程池;
2.线程生命周期: join():运行竣事再下一个, yield():暂时让出cpu的利用权,deamon():守护线程,最后竣事,sleep():如果有锁,不会让出;
3.线程3大特性,原子性,可见性,有序性;
4.list集合中线程安全问题,hash算法问题;
总结

步伐人生——Java中类、对象及方法的建议

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 步伐人生——Java中类、对象及方法的建议(1)