• 【面试笔试】Java常见面试笔试总结


    Java 基础

    1、有哪些数据类型
    Java定义了8种简单类型:byte、short、int、long、char、float、double和boolean。

    2、面向对象的语言特征
    封装、继承、多态

    3、有几种訪问机制?
    这里写图片描写叙述

    4、面向对象的多态性在JAVA中怎么实现的
    方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。假设在子类中定义某方法与其父类有相同的名称和參数。我们说该方法被重写 (Overriding)。子类的对象使用这种方法时,将调用子类中的定义,对它而言。父类中的定义如同被“屏蔽”了。假设在一个类中定义了多个同名的方法,它们或有不同的參数个数或有不同的參数类型。则称为方法的重载(Overloading)。Overloaded的方法是能够改变返回值

    5、Java I/O中字符流和字节流的差别
    字节流是传递0~255的整数而Java中有一些(如unicode代码)不能使用字符流,是特殊的字节流,

    6、说出ArrayList,Vector, LinkedList的存储性能和特性
    ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便添加和插入元素。它们都同意直接按序号索引元素,可是插入元素要涉及数组元素移动等内存操作。所以索引数据快而插入数据慢,Vector因为使用了synchronized方法(线程安全),通常性能上较ArrayList差,而LinkedList使用双向链表实现存储,按序号索引数据须要进行前向或后向遍历,可是插入数据时仅仅须要记录本项的前后项就可以,所以插入速度较快。

    7、HashTable和HashMap的差别
    HashTable和HashMap类有三个重要的不同之处。第一个不同主要是历史原因,HashTable是基于陈旧的Dictionary类,而HashMap是Java1.2引进的Map接口的一个实现
    HashTable的方法是同步的,而HashMap的方法不是,这就意味着。尽管你能够採用不论什么的行为就可在一个多线程的应用程序中使用一个HashTable,但你必须相同地为HashMap提供外同步,一个方便的方法就是利用Collection类的静态的SynchronizedMap()方法,它创建了一个线程安全的Map对象,并把它作为一个封装的对象来返回,这个对象的方法能够让你同步訪问潜在的hashmap,这么做的结构就是当你不须要同步时,你不能切断HashTable中的同步(比方在一个单线程的应用程序中)并且同步添加了非常多处理法费用。
    第三不同是。仅仅有HashMap能够让你装空值作为一个表的条目和Key和Value,Hashmap中仅仅有一条记录能够是一个空白的Key。但随意数量的条目能够是空白Value。

    这就是说,假设一个表中没有发现搜索,或者假设发现了搜索键,可是它是一个空值。那么get()将返回Null,假设有必要。用ContainKey()方法来差别这两种情况。

    8、Http协议是长连接还是短链接
    Http协议是无状态连接,所以是段连接。

    9、java的基本数据类型有哪些,String是不是基本类型
    boolean,int,byte,char,short,long,float,double,void,
    String不是基本类型。

    10、String 和StringBuffer的差别
    STRING的长度是不可变的。STRINGBUFFER的长度是可变的。假设你对字符串中的内容经常进行操作,特别是内容要改动时,那么使用StringBuffer,假设最后须要String。那么使用StringBuffer的toString()方法

    11、执行时异常与一般异常有何异同?
    异常表示程序执行过程中可能出现的非正常状态。执行时异常表示虚拟机的通常操作中可能遇到的异常。是一种常见执行错误。java编译器要求方法必须声明抛出可能发生的非执行时异常。可是并不要求必须声明抛出未被捕获的执行时异常。

    12.说出一些经常使用的类,包,接口,请各举5个
    经常使用的类:
    BufferedReader BufferedWriter FileReader FileWirter String Integer
    经常使用的包:java.lang java.awt java.io java.util java.sql
    经常使用的接口:Remote List Map Document NodeList

    13、怎样避免多个socket的读写阻塞,jdk1.4新增了哪些方法来解决问题?
    在JDK1.4曾经的版本号中,要避免阻塞发生,有发下面两种方法:
    採用多线程处理不同的socket操作,假设一个线程处理读,一个处理写.
    使用第三方程序库,non-JDK方法.
    在JDK1.4及以后的版本号中引入了NIO,引入了非阻塞socket,能够不用阻塞进行网络操作.

    14、servlet的生命周期 
    (1)载入 / 实例化:
    Servlet容器查找并载入所有的servlet类.当Servlet引擎启动时或者说在客户http请求托付时实例一个Servle或多个Servlet类
    (2)初始化
    这里在客户请求托付代理之前,使用init()方法进行初始化.
    (3)请求处理
    当初始化完毕之后这时就能够处理客户http请求了.这里使用service()这种方法来完毕并把其作參数进行传递,这里的參数包括了httpServletRequest()和httpServletResponse()两个方法分别相应于请求和回应它们也会抛出servletException和IOException然后针对不同的http请求(四个上面说过,get,post,put,head)由doGet(),doPost(),doPut(),doHead(),这四个不同的方法块里的处理单元来处理…
    (4)删除Sevlet
    有时出于一些原因须要对Sevlet容器中的servlet实例进行删除,这时就能够调用destroy()方法进行, 执行了这种方法之后,这时Sevlet就不能再执行其他客户机的请求了…而这时它也就成了JAVA垃圾回收机的回收对象了!

    15、JSP中有哪些重定向方法,它们的差别?

    <jsp:forward page=&rdquo;url&rdquo;/>
    <jsp:include file=&rdquo;url&rdquo;/>

    前者将当前页面重定向到指定的URL的页面,而后者是在当前页面中包括指定的URL的页面。

    16、Jsp有哪些内置对象?作用各自是什么地?
    request:用户端请求,此请求会包括来自GET/POST请求的參数
    getParameter() 、setAttribute()、 getAttribute()、reponse():网页传回用户端的回应
    encode()、 sendRedirect() 、setContextf()、pageContext: 网页的属性是在这里管理
    getServletContext()、 getSessin() 、setAttribute()、session :与请求有关的会话期
    getAttribute() 、setAttribute() 、invalidate()、application() :servlet正在执行的内容
    setAttribute()、 getAttribute():config servlet的构架部件
    getServletContext() 、getServletName() 、getINitParameter():out 用来传送回应的输出(用来向client输出数据)
    println() flush() 、close():page Jsp网页本身
    exception针对错误网页,未捕捉的例外(异常)

    17、Jsp有哪些动作?作用各自是什么?
    jsp共同拥有下面6个动作:
    Jsp:include::在网页被请求的时候引入一个文件
    Jsp:useBean:寻找或者实例化一个javaBean
    Jsp:setProperty :设置某个javaBean的属性
    Jsp:getProperty:输出某个javaBean的属性
    Jsp:forward:把请求转到一个新的页面。
    Jsp:plugin:依据浏览器类型为java插件或生成object或embed标记

    18、jsp中动态的include与静态的include的差别?
    动态的include用jsp:include动作实现

    它总是会检查所含文件的变化,适合用于包括动态页面,并且能够带參数
    静态include用include伪码实现定不会检查。所含文件的变化,适用于包括静态页面

    19、XML 有哪些解技术?差别是什么?
    有DOM。SAX。STAT
    DOM处理大型文件时其性能下降非常厉害。

    这个问题是由DOM的树型结构所造成的,这样的结构占用的内存较多,并且DOM必须在解析文件之前把整个文档装入内存。适合XML的随机訪问
    SAX不同DOM文档驱动型,SAX是事件驱动型XML解析方式。它顺序读取XML文件,不须要一次所有装载整个文件。当遇到像文件开头,文档结束,或者标签开头与标签结束时。它会触发一个事件。

    用户通过在其回调事件。用户通过在其回调事件写入处理代码来处理XML文件,适合对XML的顺序訪问
    STAX:StreamingAPI for XMl(STAX)

    20、你在项目中用到XML技术的哪些方面?怎样实现的?
    用到了 数据存贮,信息配置两个方面
    在做数据交换平台时。将数据源数据组装XML文件。然后XML文件压缩打包加密后通过网络传送给接收都,接收解密与名解压缩后再对XML文件里还原的相关信息进行处理。


    在做软件配置时,利用XML能够非常方便。软件和各种配置參数都贮存在XML文件里

    21、连接池的解决方式,它有哪些长处?
    解决方式:在应用程序启动时建立足够的数据库连接,并将这些连接组成一个连接池。由应用程序动态地对池中的连接进行申请。使用。和释放。

    对于连接池的并发请求,应在请求队列中排队等待。并应用程序可依据池中连接的使用率,动态地添加或降低池中的连接数。
    长处,尽可能多地重用沙消耗内存的资源,大大地节省了内存。提高了服务器的服务效率,能够支持很多其他的客户服务,通过使用连接池。将大大的提高程序执行效率。同一时候,我们能够通过其自身的管理机制监视数据库的数量。使用情况等。

    22、JDBC的过程 
    (1)载入JDBC驱动程序
    Class.forName(“com.mysql.jdbc.Driver”);//MySQL载入JDBC驱动程序方法
    Class.forName(“org.postgresql.Driver”);//PostgreSQL
    Class.forName(“oracle.jdbc.driver.OracleDriver”);//Oracle
    Class.forName(“com.ibm.db2.jdbc.net.DB2Driver”);//DB2
    Class.forName(“com.sybase.jdbc2.jdbc.SybDriver”);//Sybase
    Class.forName(“com.microsoft.jdbc.sqlserver.SQLServerDriver”);//SQLServer
    (2)建立数据库连接
    与MySQL数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:mysql://MyDbComputerNameOrIP:3306/myDBName”,ID,Pwd);
    与PostgreSQL数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:postgresql://MyDbComputerNameOrIP:3306/myDBName”,ID,Pwd);
    与Oracle数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:oracle:thin:@MyDbComputerNameOrIP:1521:ORCL”,ID,Pwd);
    与Sybase数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:sybase:Tds:MyDbComputerNameOrIP:2638”,ID,Pwd);
    与SQL Server数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:microsoft:sqlserver://MyDbComputerNameOrIP:1433;databaseName=master”,ID,Pwd);
    与DB1数据库建立连接的方法:
    Connectioncon=DriverManager.getConnection(“jdbc:db2://MyDbComputerNameOrIP/myDBName”,ID,Pwd);
    (3)创建并执行SQL语句
    用Connection.createStatement()方法来创建一个Statement对象。Statement对象执行一个查询并从DBMS返回一个包括响应结果的ResultSet对象。
    (4)处理从DBMS返回的数据
    查询处理后从DBMS收到的查询结果赋给java.sql.ResultSet对象。该对象包括一些用来从结果集中获取数据存到Java变量中的方法,以便进行进一步处理。
    (5)关闭数据库连接
    使用与数据库有关的对象所消耗的内存是非常大的,因此在完毕数据库訪问后要及时关闭数据库连接,同一时候还应关闭Connection中返回的内容。包括Statement对象和ResultSet对象。

  • 相关阅读:
    JAVA识别字符串是数字(英文)还是汉字,web页面进行字符截断的帮助类
    linux不解压超大日志gz包直接查找特定内容
    Caffe学习系列(11):图像数据转换成db(leveldb/lmdb)文件
    Caffe学习系列(10):命令行解析
    Caffe学习系列(9):运行caffe自带的两个简单例子
    Caffe学习系列(8):solver优化方法
    Caffe学习系列(7):solver及其配置
    Caffe学习系列(6):Blob,Layer and Net以及对应配置文件的编写
    Caffe学习系列(5):其它常用层及参数
    Caffe学习系列(4):激活层(Activiation Layers)及参数
  • 原文地址:https://www.cnblogs.com/mthoutai/p/7354426.html
Copyright © 2020-2023  润新知