牛客网学习笔记(20181015)

本博文主要记录个人在牛客网做专项练习遇到的重难点,若感兴趣可自行练习!!!

网址为:https://www.nowcoder.com/intelligentTest

1.关于封装

    (1)封装就是将属性私有化,提供公有的方法访问私有属性。

    (2)通过封装,可以实现对属性的数据访问限制,同时增加了程序的可维护性。

2.关于hibernate的延迟机制

    (1)Hibernate2延迟加载实现:a)实体对象 b)集合(Collection)

    (2)hibernate3增加了属性的延迟加载功能

    (3)load方法来得到一个对象时,此时hibernate会使用延迟加载的机制来加载这个对象

    (4)get()采用立即加载方式

    (5)如果数据库中没有对应的记录,get()方法返回的是null.而load()方法出现异常ObjectNotFoundException

3.关于垃圾回收

    (1)垃圾回收在jvm中优先级相当相当低。

    (2)垃圾收集器(GC)程序开发者只能推荐JVM进行回收,但何时回收,回收哪些,程序员不能控制。

    (3)垃圾回收机制只是回收不再使用的JVM内存,如果程序有严重BUG,照样内存溢出。

    (4)进入”Dead”状态的线程,它还可以恢复,GC不会回收。

4.关于Struts1和Struts2

从action类上分析:

    (1)Struts1要求Action类继承一个抽象基类。Struts1的一个普遍问题是使用抽象类编程而不是接口。

    (2) Struts 2 Action类可以实现一个Action接口,也可实现其他接口,使可选和定制的服务成为可能。Struts2提供一个ActionSupport基类去实现常用的接口。Action接口不是必须的,任何有execute标识的POJO对象都可以用作Struts2的Action对象。

从Servlet 依赖分析:  

    (3)Struts1 Action 依赖于Servlet API ,因为当一个Action被调用时HttpServletRequest 和 HttpServletResponse 被传递给execute方法。  

    (4)Struts 2 Action不依赖于容器,允许Action脱离容器单独被测试。如果需要,Struts2 Action仍然可以访问初始的request和response。但是,其他的元素减少或者消除了直接访问HttpServetRequest 和 HttpServletResponse的必要性。

从action线程模式分析:  

     (5) Struts1 Action是单例模式并且必须是线程安全的,因为仅有Action的一个实例来处理所有的请求。单例策略限制了Struts1 Action能作的事,并且要在开发时特别小心。Action资源必须是线程安全的或同步的。  

     (6) Struts2 Action对象为每一个请求产生一个实例,因此没有线程安全问题。(实际上,servlet容器给每个请求产生许多可丢弃的对象,并且不会导致性能和垃圾回收问题)

猜你喜欢

转载自blog.csdn.net/guanmao4322/article/details/83063758