




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Java软件工程师综合面试题
方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。假如在子类中定义某方法与其父类有一样的名称和参数,我们说该方法被重写(Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义犹如被”屏蔽”了。假如在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading)。Overloaded的方法是可以转变返回值的类型。
2.代码查错:
a)留意考虑,声明在接口中的对象是静态常量,不允许被修改。所以假如在继承接口的子类中,修改了引用,则会报错
b)在一个类中,文件名可以与类名不一样,但是这个类必需是非public的.
3.面象对象三大特征。
1.抽象:抽象就是忽视一个主题中与当前目标无关的那些方面,以便更充分地留意与当前目标有关的方面。抽象并不准备了解全部问题,而只是选择其中的一局部,临时不用局部细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
2.继承:继承是一种联结类的层次模型,并且允许和鼓舞类的重用,它供应了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特别的需要。
3.封装:封装是把过程和数据包围起来,对数据的访问只能通过已定义的界面。面对对象计算始于这个根本概念,即现实世界可以被描绘成一系列完全自治、封装的对象,这些对象通过一个受爱护的接口访问其他对象。
4.多态性:多态性是指允许不同类的对象对同一消息作出响应。多态性包括参数化多态性和包含多态性。多态性语言具有敏捷、抽象、行为共享、代码共享的优势,很好的解决了应用程序函数同名问题。
4.hashMap和hashtable的区分:
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区分在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。
HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。
HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。由于contains方法简单让人引起误会。
Hashtable继承自Dictionary类,而HashMap是Java1.2引进的Mapinterface的一个实现。(继承自AbstractMap类).
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap就必需为之供应外同步。
Hashtable和HashMap采纳的hash/rehash算法都也许一样,所以性能不会有很大的差异。
5.启动线程用什么方法?
start();
6.画出模版模式图
7.写一段jdbc查询代码:
privateConnectioncon=null;
privatePreparedStatementpstmt=null;
privateResultSetrs=null;
publicvoidgetQuery(){
try{
Class.forName(“com.jdbc.mysql.Driver”);
con=(Connection)DriverManager.getConnection(“jdbc:mysql://localhost:3306/test”,“root”,“root”);
pstmt=(PreparedStatement)con.prepareStatement(“select*formtabName”);
rs=(ResultSet)pstmt.executeQuery();
while(rs.next()){
System.out.println(rs.getObject(1));
}
}catch(Exceptione){
e.printStackTrace();
}finally{
try{
if(rs!=null){rs.close();}
if(pstmt!=null){pstmt.close();}
if(con!=null){if(!con.isClosed()){con.close();}con=null;}
}catch(SQLExceptione){
e.printStackTrace();
}
}
}
8.索引的优缺点:
这是由于,创立索引可以大大提高系统的性能。
第一,通过创立唯一性索引,可以保证数据库表中每一行数据的唯一性。
其次,可以大大加快数据的检索速度,这也是创立索引的最主要的缘由。
第三,可以加速表和表之间的连接,特殊是在实现数据的参考完整性方面特殊有意义。
第四,在使用分组和排序子句进展数据检索时,同样可以显著削减查询中分组和排序的时间。
第五,通过使用索引,可以在查询的过程中,使用优化隐蔽器,提高系统的性能。
二、建立方向索引的不利因素(缺点)
或许会有人要问:增加索引有如此多的优点,为什么不对表中的每一个列创立一个索引呢?这种想法当然有其合理性,然而也有其片面性。虽然,索引有很多优点,但是,为表中的每一个列都增加索引,是特别不明智的。这是由于,增加索引也有很多不利的一个方面。
第一,创立索引和维护索引要消耗时间,这种时间随着数据量的增加而增加。
其次,索引需要占物理空间,除了数据表占数据空间之外,每一个索引还要占肯定的物理空间,假如要建立聚簇索引,那么需要的空间就会更大。
第三,当对表中的数据进展增加、删除和修改的时候,索引也要动态的维护,这样就降低了数据的维护速度。
三、创立方向索引的准则
索引是建立在数据库表中的某些列的上面。因此,在创立索引的时候,应当认真考虑在哪些列上可以创立索引,在哪些列上不能创立索引。
一般来说,应当在这些列上创立索引。
第一,在常常需要搜寻的列上,可以加快搜寻的速度;
其次,在作为主键的列上,强制该列的唯一性和组织表中数据的排列构造;
第三,在常常用在连接的列上,这些列主要是一些外键,可以加快连接的速度;
第四,在常常需要依据范围进展搜寻的列上创立索引,由于索引已经排序,其指定的范围是连续的;
第五,在常常需要排序的列上创立索引,由于索引已经排序,这样查询可以利用索引的排序,加快排序查询时间;
第六,在常常使用在WHERE子句中的列上面创立索引,加快条件的推断速度。
同样,对于有些列不应当创立索引。一般来说,不应当创立索引的的”这些列具有以下特点:
第一,对于那些在查询中很少使用或者参考的列不应当创立索引。这是由于,既然这些列很少使用到,因此有索引或者无索引,并不能提高查询速度。相反,由于增加了索引,反而降低了系统的维护速度和增大了空间需求。
其次,对于那些只有很少数据值的列也不应当增加索引。这是由于,由于这些列的取值很少,例如人事表的性别列,在查询的结果中,结果集的数据行占了表中数据行的很大比例,即需要在表中搜寻的数据行的比例很大。增加索引,并不能明显加快检索速度。
第三,对于那些定义为text,image和bit数据类型的列不应当增加索引。这是由于,这些列的数据量要么相当大,要么取值很少。
第四,当修改性能远远大于检干脆能时,不应当创立索引。这是由于,修改性能和检干脆能是相互冲突的。当增加索引时,会提高检干脆能,但是会降低修改性能。当削减索引时,会提高修改性能,降低检干脆能。因此,当修改性能远远大于检干脆能时,不应当创立索引。
四、创立索引的方法
创立索引有多种方法,这些方法包括直接创立索引的方法和间接创立索引的方法。
第一,直接创立索引,例如使用CREATEINDEX语句或者使用创立索引向导。
其次,间接创立索引,例如在表中定义主键约束或者唯一性键约束时,同时也创立了索引。
9.truncate和delete,drop的区分:
不同点:
1.truncate和delete只删除数据不删除表的构造(定义)
drop语句将删除表的构造被依靠的约束(constrain),触发器(trigger),索引(index);依靠于该表的存储过程/函数将保存,但是变为invalid状态.
2.delete语句是dml,这个操作会放到rollbacksegement中,事务提交之后才生效;假如有相应的trigger,执行的时候将被触发.
truncate,drop是ddl,操作马上生效,原数据不放到rollbacksegment中,不能回滚.操作不触发trigger.
3.delete语句不影响表所占用的extent,高水线(highwatermark)保持原位置不动
明显drop语句将表所占用的空间全部释放
truncate语句缺省状况下见空间释放到minextents个extent,除非使用reusestorage;truncate会将高水线复位(回到最开头).
4.速度,一般来说:drop;truncate;delete
5.安全性:当心使用drop和trunc
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 叉车资产转让与维护保养合同
- 成都金融服务外包企业股权收购与业务拓展合同
- 财产保全担保合同(知识产权许可纠纷执行担保)
- 传统制茶工艺传承与人才培养合同
- 租赁铲车合同(4篇)
- 浙江中医药大学金华研究院招聘考试真题2024
- 联合促销活动方案(27篇)
- 加油站操作员中级工复习试题
- 气瓶复习试题含答案
- 大学生出纳顶岗实习总结(4篇)
- 最简单装修合同协议书
- DB32/T 4622.4-2023采供血过程风险管理第4部分:血液成分制备和供应风险控制规范
- 2025年供应链管理专业考试试题及答案
- 2025山东能源集团营销贸易限公司招聘机关部分业务人员31人易考易错模拟试题(共500题)试卷后附参考答案
- 2024年漳州市招聘中小学幼儿园教师真题
- 2025河南中考:政治必背知识点
- 互联网公司网络安全工程师入职培训
- 2025年中南出版传媒集团湖南教育出版社分公司招聘笔试参考题库含答案解析
- 广东惠州事业单位招聘医疗卫生岗考试模拟题带答案2025年
- 2025春 新人教版美术小学一年级下册致敬平凡
- 学美容管理制度
评论
0/150
提交评论