zoukankan      html  css  js  c++  java
  • Java知识复习(三)

    Set里的元素是不能重复的那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?contains来区分是否有重复的对象。还是都不用。

    在比较时先调用hashCode方法,如果不相同,证明不相等。

    如果相同,再调用equals方法,如果equals方法相同,证明相等,不相同,证明不相等。

    ==:主要用在基本数据类型及引用

    Equals:主要是对象或对象引用的比较。

    集合中是否包含某一个元素用contains来判断。

    &和&&的区别?

    &:与: 左边若为false右边还执行。

    &&:短路与,左边若为false右边不执行。

    final, finally, finalize的区别?

    final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。

    finally是异常处理语句结构的一部分,表示总是执行。

    finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法,可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。

    什么时候用assert?

    assertion (断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制。在实现中,assertion就是在程序中的一条语句,它对一个 boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,系统将给出警告或退出。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,assertion检查通常是关闭的。

    try {}里有一个return语句那么紧跟在这个try后的finally {}里的code会不会被执行什么时候被执行return前还是后?

    会执行,在return前执行。

    java中有几种类型的流?JDK为每种类型的流提供了一些抽象类以供继承,请说出他们分别是哪些类?

    字节流,字符流。字节流继承于InputStream OutputStream,字符流继承于Reader Writer。在java.io包中还有许多其他的流,低层流与调层流,高层流主要是为了提高性能和使用方便。

    启动一个线程是用run()还是start()?

    启动一个线程是调用start()方法,启动线程并调用run方法。

    多线程有几种实现方法,都是什么?同步有几种实现方法,都是什么? 用什么关键字修饰同步方法? stop()和suspend()方法为何不推荐使用?

    多线程有两种实现方法,分别是继承Thread类与实现Runnable接口

    同步的实现方面有两种,分别是synchronized,wait与notify

    反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在。suspend()方法容易发生死锁。调用suspend()的时候,目标线程会停下来,但却仍然持有在这之前获得的锁定。此时,其他任何线程都不能访问锁定的资源,除非被"挂起"的线程恢复运行。对任何线程来说,如果它们想恢复目标线程,同时又试图使用任何一个锁定的资源,就会造成死锁。所以不应该使用suspend(),而应在自己的Thread类中置入一个标志,指出线程应该活动还是挂起。若标志指出线程应该挂起,便用wait()命其进入等待状态。若标志指出线程应当恢复,则用一个notify()重新启动线程。

    sleep() 和 wait() 有什么区别?

    — 拥有对象不同 

    — wait可以释放对象锁,sleep保留对象锁 

    — wait可以是任意对象来调用,sleep只能当前线程调用 

    — wait可以通过notify随时唤醒,sleep只能等待设定时间结束后自然唤醒,否则将引发异常 

    — wait必须在同步方法或同步块中进行调用,sleep可以在任意位置调用

    简述你对Statement,PreparedStatement,CallableStatement的理解

    statement用于执行静态 SQL 语句并返回它所生成结果的对象,在执行时确定sql。 

    PreparedStatement表示预编译的 SQL 语句的对象。 SQL 语句被预编译并且存储在 PreparedStatement 对象中。然后可以使用此对象高效地多次执行该语句,可以传参数,在得到PreparedStatement对象时确定sql.

    CallableStatement用于执行 SQL 存储过程的接口。如果有输出参数要注册说明是输出参数。

    jdbc访问Oracle数据库

    Class.forName(“oracle.jdbc.driver.OracleDriver”);

    Connection con=DriverManager.openConnection(“jdbc:oracle:thin:@localhost:1521:DataBase ”,” UserName”,”Password ”)

  • 相关阅读:
    oracle和mysql功能相同的函数
    五个人二个月为什么不等于十个人一个月
    Oracle—RMAN完全恢复
    UVA 208 Firetruck
    sql server2005 express和Northwind数据库安装
    机器学习理论与实战(十一)关联规则分析Apriori
    JavaScript前世今生
    Maclean Liu对Oracle Database 12c新特性研究汇总
    amcharts报表制作
    HDU 4274 Spy's Work (树 DFS)
  • 原文地址:https://www.cnblogs.com/timePasser-leoli/p/7526141.html
Copyright © 2011-2022 走看看