牛客30道Java专项练习-错题02

一、抽象类为什么不能被实例化?

抽象类确实有构造方法,但这个构造方法是用来被子类调用的,因为任何子类都必须调用从Object开始的所有父亲的构造方法,才算完成初始化工作。如果抽象类被实例化,就会报错,编译无法通过。而接口里不含构造器。自然无法被实例化。

二、in和out

out是从程序里出去的数据,in是进入到程序的数据。

三、编译时异常、运行时异常

编译时异常需要我们手动的进行捕捉处理,也就是用try-catch进行捕捉处理。运行时异常只有编译器在编译运行时才会出现,这些不需要我们手动处理。

四、接口方法用void定义,其实现类应该是public void

接口方法默认是public abstract 的

五、重载和重写/覆盖

重载的要求:方法名称必须相同,参数列表必须不同(个数不同、类型不同、参数类型排列顺序不同)
同名不同参
重写/覆盖:同名同参同返回类型

六、Math.floor() 、Math.ceil() 、Math.round()

math.floor():向下取整,返回double类型
math.ceil():向上取整,返回double类型
math.round():四舍五入,若入参为float类型,返回int;若入参为double类型,则返回long

七、Java数据库连接库JDBC使用的设计模式——>桥接模式:将抽象部分与它的实现部分分离,使他们可以独立的变化。

八、Java JVM参数配置

  • Xms:起始内存,初始堆大小
  • Xmx:最大内存,最大堆大小
  • Xmn:新生代内存,年轻代大小,包含1个eden和2个survivor
  • XX:NewRatio=n:设置年轻代和年老代的比值,表示年轻代:年老代=1:n
  • XX:SurvivorRatio=n:设置年轻代里eden和2个survivor的比值,表示eden:survivor=n:2
  • XX:MaxPermSize=n:设置持久代大小

九、枚举类有几个实例就会调用几次构造方法

十、servlet处于服务器进程中,它通过多线程方式运行其service方法,一个实例可以服务于多个请求,并且其实例一般不会销毁,而CGI对每个请求都产生新的进程,服务完成后就销毁,所以效率上低于servlet

十一、volatile

一旦一个共享变量(类的成员变量、类的静态成员变量)被volatile修饰之后,那么就具备了两层含义:

  1. 保证了不同线程对这个变量进行操作时的可见性,即一个线程修改了某个变量的值,这个新值对其他线程来说时立即可见的
  2. 禁止进行指令重排序。
    volatile只提供了保证访问该变量时,每次都是从内存中读取最新值,并不会使用寄存器缓存该值——每次都是从内存中读取。而对该变量的修改,volatile并不提供原子性的保证。由于及时更新,很可能导致另一线程访问最新变量值,无法跳出循环的情况,多线程下计数器必须使用锁保护。

十二、内部类

静态内部类,不能访问外部的非静态资源
成员内部类,可以访问外部的所有资源,但本身不可有静态属性,因为自己本身就需要依靠外部类的实例化
局部内部类:不可被访问修饰符和static修饰,只能访问final变量和形参。一般在外部类的方法中。
匿名内部类:没有构造器、没有静态资源、无法被访问修饰符和static修饰,只能创建一个匿名内部类的实例,创建的时候一定在new的后面。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值