`

笔试题之框架与新技术部分

阅读更多
流行的框架与新技术

谈谈你对Struts的理解。
答:
1. struts是一个按MVC模式设计的Web层框架,其实它就是一个大大的servlet,这个Servlet名为ActionServlet,或是ActionServlet的子类。我们可以在web.xml文件中将符合某种特征的所有请求交给这个Servlet处理,这个Servlet再参照一个配置文件(通常为/WEB-INF/struts-config.xml)将各个请求分别分配给不同的action去处理。
一个扩展知识点:struts的配置文件可以有多个,可以按模块配置各自的配置文件,这样可以防止配置文件的过度膨胀;
2. ActionServlet把请求交给action去处理之前,会将请求参数封装成一个formbean对象(就是一个java类,这个类中的每个属性对应一个请求参数),封装成一个什么样的formbean对象呢?看配置文件。
3.要说明的是, ActionServlet把formbean对象传递给action的execute方法之前,可能会调用formbean的validate方法进行校验,只有校验通过后才将这个formbean对象传递给action的execute方法,否则,它将返回一个错误页面,这个错误页面由input属性指定,(看配置文件)作者为什么将这里命名为input属性,而不是error属性,我们后面结合实际的运行效果进行分析。
4.action执行完后要返回显示的结果视图,这个结果视图是用一个ActionForward对象来表示的,actionforward对象通过struts-config.xml配置文件中的配置关联到某个jsp页面,因为程序中使用的是在struts-config.xml配置文件为jsp页面设置的逻辑名,这样可以实现action程序代码与返回的jsp页面名称的解耦。

你对struts可能还有自己的应用方面的经验,那也要一并说出来。
谈谈你对Hibernate的理解。
答:
1. 面向对象设计的软件内部运行过程可以理解成就是在不断创建各种新对象、建立对象之间的关系,调用对象的方法来改变各个对象的状态和对象消亡的过程,不管程序运行的过程和操作怎么样,本质上都是要得到一个结果,程序上一个时刻和下一个时刻的运行结果的差异就表现在内存中的对象状态发生了变化。
2.为了在关机和内存空间不够的状况下,保持程序的运行状态,需要将内存中的对象状态保存到持久化设备和从持久化设备中恢复出对象的状态,通常都是保存到关系数据库来保存大量对象信息。从Java程序的运行功能上来讲,保存对象状态的功能相比系统运行的其他功能来说,应该是一个很不起眼的附属功能,java采用jdbc来实现这个功能,这个不起眼的功能却要编写大量的代码,而做的事情仅仅是保存对象和恢复对象,并且那些大量的jdbc代码并没有什么技术含量,基本上是采用一套例行公事的标准代码模板来编写,是一种苦活和重复性的工作。
3.通过数据库保存java程序运行时产生的对象和恢复对象,其实就是实现了java对象与关系数据库记录的映射关系,称为ORM(即Object Relation Mapping),人们可以通过封装JDBC代码来实现了这种功能,封装出来的产品称之为ORM框架,Hibernate就是其中的一种流行ORM框架。使用Hibernate框架,不用写JDBC代码,仅仅是调用一个save方法,就可以将对象保存到关系数据库中,仅仅是调用一个get方法,就可以从数据库中加载出一个对象。
4.使用Hibernate的基本流程是:配置Configuration对象、产生SessionFactory、创建session对象,启动事务,完成CRUD操作,提交事务,关闭session。
5.使用Hibernate时,先要配置hibernate.cfg.xml文件,其中配置数据库连接信息和方言等,还要为每个实体配置相应的hbm.xml文件,hibernate.cfg.xml文件中需要登记每个hbm.xml文件。
6.在应用Hibernate时,重点要了解Session的缓存原理,级联,延迟加载和hql查询。
AOP的作用。
AOP通过横向抽取机制为这类无法通过纵向继承体系进行抽象的重复性代码提供了解决方案。
你对Spring的理解。
1.Spring实现了工厂模式的工厂类(在这里有必要解释清楚什么是工厂模式),这个类名为BeanFactory(实际上是一个接口),在程序中通常BeanFactory的子类ApplicationContext。Spring相当于一个大的工厂类,在其配置文件中通过<bean>元素配置用于创建实例对象的类名和实例对象的属性。
2. Spring提供了对IOC良好支持,IOC是一种编程思想,是一种架构艺术,利用这种思想可以很好地实现模块之间的解耦。IOC也称为DI(Depency Injection),什么叫依赖注入呢?
譬如,Class Programmer
{
Computer computer = null;
public void code()
{
//Computer computer = new IBMComputer();
//Computer computer = beanfacotry.getComputer();
computer.write();
}
public void setComputer(Computer computer)
{
this.computer = computer;
}
}
另外两种方式都由依赖,第一个直接依赖于目标类,第二个把依赖转移到工厂上,第三个彻底与目标和工厂解耦了。在spring的配置文件中配置片段如下:
<bean id=”computer” class=”cn.itcast.interview.Computer”>
</bean>

<bean id=”programmer” class=”cn.itcast.interview.Programmer”>
<property name=”computer”  ref=”computer”></property>
</bean>
3. Spring提供了对AOP技术的良好封装, AOP称为面向切面编程,就是系统中有很多各不相干的类的方法,在这些众多方法中要加入某种系统功能的代码,例如,加入日志,加入权限判断,加入异常处理,这种应用称为AOP。实现AOP功能采用的是代理技术,客户端程序不再调用目标,而调用代理类,代理类与目标类对外具有相同的方法声明,有两种方式可以实现相同的方法声明,一是实现相同的接口,二是作为目标的子类在,JDK中采用Proxy类产生动态代理的方式为某个接口生成实现类,如果要为某个类生成子类,则可以用CGLI B。在生成的代理类的方法中加入系统功能和调用目标类的相应方法,系统功能的代理以Advice对象进行提供,显然要创建出代理对象,至少需要目标类和Advice类。spring提供了这种支持,只需要在spring配置文件中配置这两个元素即可实现代理和aop功能,例如,
<bean id=”proxy” type=”org.spring.framework.aop.ProxyBeanFactory”>
<property name=”target” ref=””></property>
<property name=”advisor” ref=””></property>

</bean>

谈谈Struts中的Action servlet。

Struts优缺点
优点:
1. 实现MVC模式,结构清晰,使开发者只关注业务逻辑的实现.
2.有丰富的tag可以用 ,Struts的标记库(Taglib),如能灵活动用,则能大大提高开发效率
3. 页面导航
使系统的脉络更加清晰。通过一个配置文件,即可把握整个系统各部分之间的联系,这对于后期的维护有着莫大的好处。尤其是当另一批开发者接手这个项目时,这种优势体现得更加明显。
4. 提供Exception处理机制 .
5. 数据库链接池管理
6. 支持I18N
缺点
一、 转到展示层时,需要配置forward,如果有十个展示层的jsp,需要配置十次struts,而且还不包括有时候目录、文件变更,需要重新修改forward,注意,每次修改配置之后,要求重新部署整个项目,而tomcate这样的服务器,还必须重新启动服务器
二、 二、 Struts 的Action必需是thread-safe方式,它仅仅允许一个实例去处理所有的请求。所以action用到的所有的资源都必需统一同步,这个就引起了线程安全的问题。
三、 测试不方便. Struts的每个Action都同Web层耦合在一起,这样它的测试依赖于Web容器,单元测试也很难实现。不过有一个Junit的扩展工具Struts TestCase可以实现它的单元测试。
四、 类型的转换. Struts的FormBean把所有的数据都作为String类型,它可以使用工具Commons-Beanutils进行类型转化。但它的转化都是在Class级别,而且转化的类型是不可配置的。类型转化时的错误信息返回给用户也是非常困难的。
五、 对Servlet的依赖性过强. Struts处理Action时必需要依赖ServletRequest 和ServletResponse,所有它摆脱不了Servlet容器。
六、 前端表达式语言方面.Struts集成了JSTL,所以它主要使用JSTL的表达式语言来获取数据。可是JSTL的表达式语言在Collection和索引属性方面处理显得很弱。
七、 对Action执行的控制困难. Struts创建一个Action,如果想控制它的执行顺序将会非常困难。甚至你要重新去写Servlet来实现你的这个功能需求。
八、 对Action 执行前和后的处理. Struts处理Action的时候是基于class的hierarchies,很难在action处理前和后进行操作。
九、 对事件支持不够. 在struts中,实际是一个表单Form对应一个Action类(或DispatchAction),换一句话说:在Struts中实际是一个表单只能 对应一个事件,struts这种事件方式称为application event,application event和component event相比是一种粗粒度的事件


STRUTS的应用(如STRUTS架构)
Struts是采用Java Servlet/JavaServer Pages技术,开发Web应用程序的开放源码的framework。 采用Struts能开发出基于MVC(Model-View-Controller)设计模式的应用构架。 Struts有如下的主要功能: 一.包含一个controller servlet,能将用户的请求发送到相应的Action对象。 二.JSP自由tag库,并且在controller servlet中提供关联支持,帮助开发员创建交互式表单应用。 三.提供了一系列实用对象:XML处理、通过Java reflection APIs自动处理JavaBeans属性、国际化的提示和消息。

说说struts1与struts2的区别。
1.都是MVC的WEB框架,
2 struts1的老牌框架,应用很广泛,有很好的群众基础,使用它开发风险很小,成本更低!struts2虽然基于这个框架,但是应用群众并多,相对不成熟,未知的风险和变化很多,开发人员相对不好招,使用它开发项目的风险系数更大,用人成本更高!
3.struts2毕竟是站在前辈的基础设计出来,它会改善和完善struts1中的一些缺陷,struts1中一些悬而未决问题在struts2得到了解决。
4.struts1的前端控制器是一个Servlet,名称为ActionServlet,struts2的前端控制器是一个filter,在struts2.0中叫FilterDispatcher,在struts2.1中叫StrutsPrepareAndExecuteFilter。
5.struts1的action需要继承Action类,struts2的action可以不继承任何类;struts1对同一个路径的所有请求共享一个Action实例,struts2对同一个路径的每个请求分别使用一个独立Action实例对象,所有对于struts2的Action不用考虑线程安全问题。
6.在struts1中使用formbean封装请求参数,在struts2中直接使用action的属性来封装请求参数。
7.struts1中的多个业务方法放在一个Action中时(即继承DispatchAction时),要么都校验,要么都不校验;对于struts2,可以指定只对某个方法进行校验,当一个Action继承了ActionSupport且在这个类中只编写了validateXxx()方法,那么则只对Xxx()方法进行校验。

(一个请求来了的执行流程进行分析,struts2是自动支持分模块开发,并可以不同模块设置不同的url前缀,这是通过package的namespace来实现的;struts2是支持多种类型的视图;struts2的视图地址可以是动态的,即视图的名称是支持变量方式的,举例,论坛发帖失败后回来还要传递boardid。视图内容显示方面:它的标签用ognl,要el强大很多,在国际化方面支持分模块管理,两个模块用到同样的key,对应不同的消息;)


与Struts1不同,Struts2对用户的每一次请求都会创建一个Action,所以Struts2中的Action是线程安全的。

给我印象最深刻的是:struts配置文件中的redirect视图的url不能接受参数,而struts2配置文件中的redirect视图可以接受参数。


hibernate中的update()和saveOrUpdate()的区别,session的load()和get()的区别。
saveOrUpdate()方法可以实现update()的功能,但是会多些步骤,具体如下:

  如果对象在该session种已经持久化,不进行操作;对象的标识符属性(identifier property)

在数据库中不存在或者是个暂时的值,调用save()方法保存它;如果session中的另一个对象

有相同的标识符抛出一个异常;以上皆不符合则调用update()更新之。

  session.load/get方法均可以根据指定的实体类和id从数据库读取记录,get方法返回null,

而load方法会抛出一个ObjectNotFoundException;load方法可返回实体的代理类实例,

  而get方法永远直接返回实体类;load方法可以充分利用内部缓存和二级缓存中的现有数据

而get方法则仅仅在内部缓存中进行数据查找,如果没有发现对应的数据,将越过二级缓存,

直接调用sql完成数据读取。
简述 Hibernate 和 JDBC 的优缺点? 如何书写一个 one to many 配置文件.
iBatis与Hibernate有什么不同?
相同点:屏蔽jdbc api的底层访问细节,使用我们不用与jdbc api打交道,就可以访问数据。
jdbc api编程流程固定,还将sql语句与java代码混杂在了一起,经常需要拼凑sql语句,细节很繁琐。
ibatis的好处:屏蔽jdbc api的底层访问细节;将sql语句与java代码进行分离;提供了将结果集自动封装称为实体对象和对象的集合的功能,queryForList返回对象集合,用queryForObject返回单个对象;提供了自动将实体对象的属性传递给sql语句的参数。

Hibernate是一个全自动的orm映射工具,它可以自动生成sql语句,ibatis需要我们自己在xml配置文件中写sql语句,hibernate要比ibatis功能负责和强大很多。因为hibernate自动生成sql语句,我们无法控制该语句,我们就无法去写特定的高效率的sql。对于一些不太复杂的sql查询,hibernate可以很好帮我们完成,但是,对于特别复杂的查询,hibernate就很难适应了,这时候用ibatis就是不错的选择,因为ibatis还是由我们自己写sql语句。


写Hibernate的一对多和多对一双向关联的orm配置?
核心代码:
<many-to-one name="classes" column="classesId"/>
<set name="students" inverse="true" cascade="all">
      <key column="classesId" />
      <one-to-many class="Students" />
</set>

hihernate一对多关联映射(双向Classes<----->Student)

一对多双向关联映射:
    * 在一一端的集合上使用<key>,在对方表中加入一个外键指向一一端
    * 在多一端采用<many-to-one>
   
注意:<key>标签指定的外键字段必须和<many-to-one>指定的外键字段一致,否则引用字段的错误
   
如果在”一“一端维护一对多关联关系,hibernate会发出多余的udpate语句,所以我们一般在多
的一端来维护关联关系

关于inverse属性:
    inverse主要用在一对多和多对多双向关联上,inverse可以被设置到集合标签<set>上,
    默认inverse为false,所以我们可以从”一“一端和”多“一端维护关联关系,
    如果设置成inverse为true,则我们只能从多一端来维护关联关系
   
    注意:inverse属性,只影响数据的存储,也就是持久化
       
inverse和cascade
    * inverse是关联关系的控制方向
    * cascade操作上的连锁反应
一:实体类:
Classes.java代码 
1. package com.tao.hibernate.one2many2;  
2.  
3. import java.util.Set;  
4.  
5. public class Classes {  
6.     private Integer id;  
7.     private String name;  
8.     private Set<Students> students;  
9.  
10.     public Classes() {  
11.         super();  
12.     }  
13.  
14.     public Integer getId() {  
15.         return id;  
16.     }  
17.  
18.     public void setId(Integer id) {  
19.         this.id = id;  
20.     }  
21.  
22.     public String getName() {  
23.         return name;  
24.     }  
25.  
26.     public void setName(String name) {  
27.         this.name = name;  
28.     }  
29.  
30.     public Set<Students> getStudents() {  
31.         return students;  
32.     }  
33.  
34.     public void setStudents(Set<Students> students) {  
35.         this.students = students;  
36.     }  
37.  
38. } 
Students.java代码 
1. package com.tao.hibernate.one2many2;  
2.  
3. public class Students {  
4.     private Integer id;  
5.     private String name;  
6.     private Classes classes;  
7.  
8.     public Students() {  
9.         super();  
10.     }  
11.  
12.     public Integer getId() {  
13.         return id;  
14.     }  
15.  
16.     public void setId(Integer id) {  
17.         this.id = id;  
18.     }  
19.  
20.     public String getName() {  
21.         return name;  
22.     }  
23.  
24.     public void setName(String name) {  
25.         this.name = name;  
26.     }  
27.  
28.     public Classes getClasses() {  
29.         return classes;  
30.     }  
31.  
32.     public void setClasses(Classes classes) {  
33.         this.classes = classes;  
34.     }  
35.  
36. } 
二:映射文件:
Classes.hbm.xml代码 
1. <?xml version="1.0" encoding="UTF-8"?>  
2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
4.  
5. <hibernate-mapping package="com.tao.hibernate.one2many2" auto-import="false">  
6.     <class name="Classes" table="t_classes">  
7.         <id name="id" column="id" type="integer">  
8.             <generator class="native" />  
9.         </id>  
10.         <property name="name" column="name" />  
11.         <set name="students" inverse="true" cascade="all">  
12.             <key column="classesId" />  
13.             <one-to-many class="Students" />  
14.         </set>  
15.     </class>  
16. </hibernate-mapping> 
Students.hbm.xml代码 
1. <?xml version="1.0" encoding="UTF-8"?>  
2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
4.  
5. <hibernate-mapping package="com.tao.hibernate.one2many2" auto-import="false">  
6.     <class name="Students" table="t_students">  
7.         <id name="id" column="id" type="integer">  
8.             <generator class="native" />  
9.         </id>  
10.         <property name="name" column="name" />  
11.         <many-to-one name="classes" column="classesId"/>  
12.     </class>  
13. </hibernate-mapping> 
三:测试类:
Testmain.java代码 
1. package com.tao.hibernate.one2many2;  
2.  
3. import java.util.HashSet;  
4. import java.util.Iterator;  
5. import java.util.Set;  
6.  
7. import org.hibernate.Session;  
8. import org.hibernate.Transaction;  
9. import org.junit.Test;  
10.  
11. import com.tao.hibernate.HibernateUtils;  
12.  
13. public class TestMain {  
14.     Session session = HibernateUtils.getFactory().openSession();  
15.  
16.     @Test  
17.     public void testSave() {  
18.         Students s1 = new Students();  
19.         s1.setName("tao");  
20.  
21.         Students s2 = new Students();  
22.         s2.setName("war");  
23.  
24.         Classes c = new Classes();  
25.         c.setName("148班");  
26.         Set<Students> students = new HashSet<Students>();  
27.         students.add(s1);  
28.         students.add(s2);  
29.         c.setStudents(students);  
30.  
31.         s1.setClasses(c);  
32.         s2.setClasses(c);  
33.  
34.         Transaction ts = session.beginTransaction();  
35.         ts.begin();  
36.         session.save(c);  
37.         ts.commit();  
38.     }  
39.  
40.     @Test  
41.     public void testLoad() {  
42.         Session session = HibernateUtils.getFactory().openSession();  
43.         Classes c = (Classes) session.load(Classes.class, 1);  
44.         for (Iterator<Students> iter = c.getStudents().iterator(); iter  
45.                 .hasNext();) {  
46.             System.out.println(iter.next().getName());  
47.         }  
48.     }  
49.  
50.     @Test  
51.     public void testLoad2() {  
52.         Session session = HibernateUtils.getFactory().openSession();  
53.         Students s = (Students) session.load(Students.class, 1);  
54.         System.out.println(s.getName());  
55.         System.out.println(s.getClasses().getName());  
56.     }  
57.  
58. } 


hibernate的inverse属性的作用?
解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2
field2) ,然后在hql里面就可以直接生成这个bean了。

在DAO中如何体现DAO设计模式?
解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2
field2) ,然后在hql里面就可以直接生成这个bean了。

spring+Hibernate中委托方案怎么配置?
解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2
field2) ,然后在hql里面就可以直接生成这个bean了。

spring+Hibernate中委托方案怎么配置?
解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2
field2) ,然后在hql里面就可以直接生成这个bean了。

hibernate进行多表查询每个表中各取几个字段,也就是说查询出来的结果集没有一个实体类与之对应如何解决;

解决方案一,按照Object[]数据取出数据,然后自己组bean
解决方案二,对每个表的bean写构造函数,比如表一要查出field1,field2两个字段,那么有一个构造函数就是Bean(type1 filed1,type2
field2) ,然后在hql里面就可以直接生成这个bean了。
介绍一下Hibernate的二级缓存
按照以下思路来回答:(1)首先说清楚什么是缓存,(2)再说有了hibernate的Session就是一级缓存,即有了一级缓存,为什么还要有二级缓存,(3)最后再说如何配置Hibernate的二级缓存。
(1)缓存就是把以前从数据库中查询出来和使用过的对象保存在内存中(一个数据结构中),这个数据结构通常是或类似Hashmap,当以后要使用某个对象时,先查询缓存中是否有这个对象,如果有则使用缓存中的对象,如果没有则去查询数据库,并将查询出来的对象保存在缓存中,以便下次使用。下面是缓存的伪代码:
引出hibernate的第二级缓存,用下面的伪代码分析了Cache的实现原理
Dao
{
hashmap map = new map();
User getUser(integer id)
{
User user = map.get(id)
if(user == null)
{
user = session.get(id);
map.put(id,user);
}
return user;
}
}

Dao
{
Cache cache = null
setCache(Cache cache)
{
this.cache = cache
}

User getUser(int id)
{
if(cache!=null)
{
User user = cache.get(id);
if(user ==null)
{
user = session.get(id);
cache.put(id,user);
}
return user;
}

return session.get(id);
}
}
(2)Hibernate的Session就是一种缓存,我们通常将之称为Hibernate的一级缓存,当想使用session从数据库中查询出一个对象时,Session也是先从自己内部查看是否存在这个对象,存在则直接返回,不存在才去访问数据库,并将查询的结果保存在自己内部。由于Session代表一次会话过程,一个Session与一个数据库连接相关连,所以Session最好不要长时间保持打开,通常仅用于一个事务当中,在事务结束时就应关闭。并且Session是线程不安全的,被多个线程共享时容易出现问题。通常只有那种全局意义上的缓存才是真正的缓存应用,才有较大的缓存价值,因此,Hibernate的Session这一级缓存的缓存作用并不明显,应用价值不大。Hibernate的二级缓存就是要为Hibernate配置一种全局缓存,让多个线程和多个事务都可以共享这个缓存。我们希望的是一个人使用过,其他人也可以使用,session没有这种效果。
(3)二级缓存是独立于Hibernate的软件部件,属于第三方的产品,多个厂商和组织都提供有缓存产品,例如,EHCache和OSCache等等。在Hibernate中使用二级缓存,首先就要在hibernate.cfg.xml配置文件中配置使用哪个厂家的缓存产品,接着需要配置该缓存产品自己的配置文件,最后要配置Hibernate中的哪些实体对象要纳入到二级缓存的管理中。明白了二级缓存原理和有了这个思路后,很容易配置起Hibernate的二级缓存。扩展知识:一个SessionFactory可以关联一个二级缓存,也即一个二级缓存只能负责缓存一个数据库中的数据,当使用Hibernate 的二级缓存后,注意不要有其他的应用或SessionFactory来更改当前数据库中的数据,这样缓存的数据就会与数据库中的实际数据不一致。

Spring 的依赖注入是什么意思? 给一个 Bean 的 message 属性, 字符串类型, 注入值为 "Hello" 的 XML 配置文件该怎么写?
<bean name="bean的别名" class="bean的类名(带包名)">
  <property name="message" value="Hello"/>
</bean>
Jdo是什么?
JDO是Java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。JDO提供了透明的对象存储,因此对开发人员来说,存储数据对象完全不需要额外的代码(如JDBC API的使用)。这些繁琐的例行工作已经转移到JDO产品提供商身上,使开发人员解脱出来,从而集中时间和精力在业务逻辑上。另外,JDO很灵活,因为它可以在任何数据底层上运行。JDBC只是面向关系数据库(RDBMS)JDO更通用,提供到任何数据底层的存储功能,比如关系数据库、文件、XML以及对象数据库(ODBMS)等等,使得应用可移植性更强。

什么是spring的IOC  AOP
STRUTS的工作流程!
spring 与EJB的区别!!
分享到:
评论

相关推荐

    java面试笔试题库java软件设计java笔试题大集合及答案文档资料合集300MB.zip

    java面试笔试题库java软件设计java笔试题大集合及答案文档资料合集300MB“ 100家大公司java笔试题汇总.doc 125条常见的java 面试笔试题大汇总.pdf 2011最新整理java经典代码.doc 25个经典的Spring面试问答.docx 8张...

    java面试笔试资料java笔试题大集合及答案题库java笔试题汇总资料188个合集.zip

    java面试笔试资料java笔试题大集合及答案题库java笔试题汇总资料188个合集 100家大公司java笔试题汇总.doc 125条常见的java 面试笔试题大汇总.pdf 2011最新整理java经典代码.doc 25个经典的Spring面试问答.docx ...

    java面试笔试题库java学习笔记开发教程互联网公司面试资料大全合集.zip

    100家大公司java笔试题汇总.doc 125条常见的java 面试笔试题大汇总.pdf 2011最新整理java经典代码.doc 25个经典的Spring面试问答.docx 8张图解java.docx Addison.Wesley.Java.Concurrency.in.Practice.May.2006.chm ...

    java 面试笔试题

    Java就业面试题大全 包括: 1. Java基础部分 2. 特高深的Java问题 ...5. 流行的框架与新技术 9. 软件工程与设计模式 10. Linux 10. 问得稀里糊涂的题 10. 其他 真的很全啊。word 文档就 400kb.

    SSM框架测试题以及答案解析.docx

    下列关于ModelAndView的说法错误的是( )。 (选择一项) A:控制器处理方法的返回值若为: ModelAndView,则既可以包含视图信息,也可以包含模型数据 信息 B:控制器处理方法的返回值若为: ModelAndView, 在处理方法的...

    张孝祥正在整理Java就业面试题大全

    3. 笔试题之Java基础部分;4. 算法与编程;5. html&JavaScript;&ajax;部分;6. Java web部分;7. 实际项目开发;8. 数据库部分;9.XML部分;10.流行的框架与新技术;11. 软件工程与设计模式;12.j2ee部分;13.ejb...

    浙江大华笔试题Java-learn:前端学习

    浙江大华笔试题Java github 优质项目 前端技术清单,不论你是正在自学前端,还是对前端某些技术熟练掌握但某些还未涉足,我都希望这份清单能帮助你 review 一些前端的基础能力。 前端技术清单 年度报告 基础拾遗 1.1...

    高级java工程师笔试题-New-Interview-question:新面试题

    高级java工程师笔试题精彩访谈 技术面试问题列表的精选列表。 如果你想贡献,请阅读 或 。 查看我的或 . 目录 编程语言/框架/平台 安卓 . AngularJS 角 主干JS C++ C C# 。网 Clojure CSS Cucumber 姜戈 码头工人 ...

    java三大框架笔试题答案-FAQ:iOS程序员常见问题

    java三大框架笔试题答案#iOS 编程常见问题 我们搬家了! 请查看 之所以出现这个常见问题是因为我注意到很多问题都在重复出现,所以我决定在这里写下所有常见问题的简短而甜蜜的答案。 这是一个精选的列表,我正在...

    2021最新java面试合集pdf.rar

    爱奇艺2021Java方向笔试题(第一场).docx 看透springMvc源代码分析与实践.pdf 网易2021招聘笔试- 系统开发研发工程师(提前批).docx 网易2021笔试- Java 开发工程师(提前批).docx 网易2021笔试- Java 开发工程师...

    初中级程序员面试题库

    分为十二个部分进行讲解 java基础部分 算法与编程 html&javaScript;&ajax; javaweb 数据库部分 XML部分 流行框架及新技术 软件工程与设计模式 j2ee部分 EBJ部分 WebService部分

    java笔试题算法-wiki:Github上JavaScript、CSS和Nodejs的精选列表

    java笔试题算法 , , , , . 如果你发现自己陷入各种新技术、工具包围中,而纠结于该选择哪些学习,读读这篇文章,。 综合资源 资源链接汇集 - 各种主流语言的优秀项目汇集 :thumbs_down: - 资源集合的汇集 - 开发资源...

    高级java笔试题-ama:《节点全栈》问我

    高级java笔试题 《Node全栈》 做Node全栈,你合格么? 自测一下 大前端相关 基础 css 2 && 3 js && es6 http/ajax/rest git/svn/issues/pr markdown 前端框架 模块化加载seajs\requirejs\commonjs mvc/mvvm ...

    高级java笔试题-itresource:程序开发技术资源集合

    高级java笔试题 基础 [ 收藏——IO模型的4张经典图例(一看就懂) ] () java技术系列文章 [ java swing 界面统一设置字体样式 ] () [ Google Java 编程风格指南 ] () [ Quartz应用与集群原理分析 ] () [ heavyz的...

    Java后端技术面试汇总-2019

    这个整理的最新的java后端面试题分为5部分,包含J2EE基础题,数据库,缓存服务器,jvm,网络相关,主流框架以及微服务,分布式,大数据量等

    高级java笔试题-resource-index:优质的技术博客、社区推荐

    高级java笔试题 优质的技术博客、社区推荐 目前你所看到的内容由我收集并整理,如果你有优秀的博客或社区需要推荐或自荐,请点: 收到大家的提交后会及时收录与更新。 JAVA 博客 博客名称 博客简介 Spring Cloud、...

    2018 最新Java经典面试题之葵花宝典

    2018 最新 经典面试题 ,java 技术面试,java初级到java高级框架,足以应对大中小型企业的技术面试和笔试

    高级java笔试题-LeYing:机器学习

    高级java笔试题 机器学习资源与代码 开发环境如下: PyCharm 2018 Python 3.5.2 TensorFlow框架 依赖库:numpy,sklearn,pandas,matlibplot...etc 作业部落: 除了您现在看到的这个 Cmd Markdown 在线版本,您还可以...

    高级java笔试题-front-end-resources:前端资源整理收集文档,主要面对一些优秀的blog,技术文档,面试等资料

    高级java笔试题 Font-End-Resources 前端资源整理收集文档,主要面对一些优秀的blog,技术文档,面试等资料 NEW(最新更新) 前端大牛资源 计算机基础和网络 HTML CSS CSS Reset JS TypeScript Jquery NodeJs ...

    亚信java笔试题-fuzzing-tutorial:模糊教程

    亚信java笔试题 fuzzing-tutorial fuzzing 从入门到进阶,这里收录了经典的 fuzzing 书籍、历年安全顶会上有关 fuzzing 的经典论文、常用的 fuzzing 工具、可以快速入手 fuzzing 工具的博客。 Table of Contents 1 ...

Global site tag (gtag.js) - Google Analytics