JAVA面试题

jsp中<%%> 与<%!%>的区别是什么?

一、翻译不同

1、<%%> :<%%> 的内容会翻译在Servlet的Service方法中。

2、<%!%>:<%!%>的内容会直接翻译在Servlet类中。
二、定义不同

1、<%%> :<%%> 定义局部变量或者调用方法,但不能定义方法。

2、<%!%>:<%!%>不可以定义局部变量和方法。
三、声明不同

1、<%%> :<%%>不可以声明方法、属性、全局变量。

2、<%!%>:<%!%> 可以声明方法、属性、全局变量。

在一个.java文件里面,可以有多个类吗,有什么限制?

可以
限制:一个文件中只能有一个public类,并且此public类必须与文件名相同

java如何获取字符串编码格式?

一般采用一种编码方式解码之后再编码,如果和原来的一样,那么就是说这个是这个编码方式。具体实现方法是
String code=“GB2312”;//编码方式
String str=“测试” ; //是你要判断的字符串
boolean flag = str.equals(new String(str.getBytes(code), code))
如果返回的是true ,就说明是这种编码,你可以采用很多种编码循环测试

java中String、StringBuffer和StringBuilder的区别?

执行速度:在这方面运行速度快慢为:StringBuilder(最快) , StringBuffer(中) ,String(最慢)
tips:
String最慢的原因:String为字符串常量,而StringBuilder和StringBuffer均为字符串变量,即String对象一旦创建之后该对象是不可更改的,但后两者的对象是变量,是可以更改的。
线程安全
  线程安全:StringBuilder是线程不安全的,而StringBuffer是线程安全的

tips:如果一个StringBuffer对象在字符串缓冲区被多个线程使用时,StringBuffer中很多方法可以带有synchronized关键字,所以可以保证线程是安全的,但StringBuilder的方法则没有该关键字,所以不能保证线程安全,有可能会出现一些错误的操作。所以如果要进行的操作是多线程的,那么就要使用StringBuffer,但是在单线程的情况下,还是建议使用速度比较快的StringBuilder。
  (一个线程访问一个对象中的synchronized(this)同步代码块时,其他试图访问该对象的线程将被阻塞)

页面间传值有哪几种几种方式简单说明

  1. QueryString传值:最简单的传值方式,但缺点是传的值会显示在浏览器的地址栏中且不能传递对象,只适用于传递简单的且安全性要求不高的整数值.
  2. Server.Transfer传值:避免了要传递的值显示在浏览器的地址栏中.
  3. Cookie对象变量:Cookie是针对每一个用户而言的,是存放在客户端的 ,Cookie的使用要配合ASP.NET内置对象Request来使用
  4. Session对象变量:Session也是针对每一个用户而言的,是存放在服务器端的 ,Session不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed 后,变量才会消失
  5. Application对象变量: Application对象的作用范围是整个全局,也就是说对所有用户都有效。其常用的方法用Lock和UnLock,

链接: 页面间传值的五种方式的具体使用.

cookie与session区别,如何使用

同上

hashcode() 与equals()区别

hashcode() 与equals()是判断两个对象是否相等的两种方法
1. equal()相等的两个对象他们的hashCode()肯定相等,也就是用equal()对比是绝对可靠的。
2. hashCode()相等的两个对象他们的equal()不一定相等,也就是hashCode()不是绝对可靠的。
详细:链接:Java 中的 ==, equals 与 hashCode 的区别与联系

==与equals()区别,简单说明

同上

Forward和Redirect区别,简单说明

直接转发方式(Forward),客户端和浏览器只发出一次请求,Servlet、HTML、JSP或其它信息资源,由第二个信息资源响应该请求,在请求对象request中,保存的对象对于每个信息资源是共享的。

间接转发方式(Redirect)实际是两次HTTP请求,服务器端在响应第一次请求的时候,让浏览器再向另外一个URL发出请求,从而达到转发的目的。
  Forward和Redirect的区别

在servlet里面实现页面跳转的几种方式,简单说明

同上

显示查询学生表中30-41条的记录

select * from employees where rownum between 30 and 41;

查询有两门课程不及格的学生

SELECT s.sno,s.sname
from student s
LEFT JOIN sgrade g on s.sno=g.sno
WHERE g.sgrade<60
GROUP BY s.sno HAVING COUNT(s.sno)>2

查询选了两门课程的学生

SELECT stu.* FROM score s,course c,student stu WHERE s.c_id=c.c_id AND stu.s_id=s.s_id GROUP BY s.s_id HAVING COUNT(*)=2

平均成绩大于60分的学生并且按照年龄倒序排列

SELECT
‘sid’,AVG(’score‘) AS ‘avg_sc’
FROM
‘sc’
GROUP BY
‘sid’
HAVING
‘avg_sc’ > 60;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Azure97

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值