<jsp:include page=""/>
共同点:两者都是在请求时包含另一个页面进来!
不同点:
前者:不合适包含动态页面,因为用它包含动态页面时,它并不会去检查所包含文件所发生的变化!所以适应于html页面,不能传任何参数。
后者:合适包含动态页面,它会去定时检查所包含文件的变化,适应用jsp等动态页面,并且可以传参数。
JSP中包含文件有两种写法:
1.<%@ include file="import.jsp"%>
2.<jsp:include page="import.jsp" flush="true" ></jsp:include>
使用第一种写法时,包含的文件是以静态的形式合并到当前JSP文件中的。即,先将要包含的文件内容插入到include语句的位置,再对该文件进行编译解释。而被包含的文件本身则是没有进行编译解释的。
在Tomcat的工作目录下可以看到,import.jsp没有被自动编译为.java文件。
包含.jsp和.htm文件对于这种方式是没有区别的。
使用第二种写法时。是先编译解释import.jsp,然后将执行import.jsp的输出结果包含入当前文件中。
参数flush为true时,每次执行都将重新解释被包含文件import.jsp。每次访问这个页面时,都会重新编译包含文件,会影响速度。
参数flush为false时,以后执行时将从缓存中读取,访问页面时,响应速度快,但是当修改包含文件时,不能及时反应出来,需要重启应用服务器(Tomcat)或删除工作目录下的包含文件(import_jsp.java)。
在Tomcat的工作目录下可以看到import.jsp被自动编译成import_jsp.java。
包含.jsp文件,则是将执行结果包含,而.htm文件,则直接将文件内容包含。
<%@ include %>是编译时包含,<jsp:include>是运行时包含。前者就相当于宏,编译时替代,后者相当于函数,运行时返回。
Session的常用方法:
例如:session.setAttribute(“myname”,”tom”);
例如: session.getAttribute(“myname”);
例如:session.removeAttribute(“myname”);
toString()方法就是把对象转换成String类型,转换的算法根据类型和实际需要而定。 比如一个Integer对象的toString方法就是把这个对象表示的整数转化成字符串,133就成了"133"。
图形用户界面(Graphical User Interface,简称 GUI,又称图形用户接口)是指采用图形方式显示的计算机操作用户界面。
try-catch只能捕获一个错误是对的,不论后面跟着多少个catch都一样,try-catch语句是这样执行的:首先逐个从上到下执行try块中的java语句,如果没有发生异常,则执行完try块后跳过catch块(不论有多少个catch都跳过)。如果try块中某条语句存在异常,则跳到相对应的catch块中(发生什么异常,就跳到什么catch里,如果没有准确对应的,就跳到父类异常的catch中),执行完该catch块中的语句,然后跳过其它的catch块,接着往下走,明白了么?总之,try-catch只能处理一个异常,这就是为什么后面通常跟finally,要有一个统一的出口。 如果还不明白,你就在环境下用一段代码试试就好了,不要着急,随便找两个异常一试就OK! 比如: try{ int b=25/0; Thread.sleep(2000); } catch(ArithmeticException e){ System.out.println("除零错误!"); } catch(InterruptedException e){ System.out.println("延时错误!"); } 上面这个例子就会在屏幕上显示"除零错误!"四个字,因为众所周知,任何数字不能除0,所以25/0是错的,它抛出ArithmeticException(数学异常),则直接跳进第一个catch块内,而没有进入第二个块,尽管Thread.sleep(2000);也有异常。首先要清楚,如果没有try的话,出现异常会导致程序崩溃。 而try则可以保证程序的正常运行下去,比如说: try{ int i = 1/0; }catch(Exception e){ ........ } 一个计算的话,如果除数为0,则会报错,如果没有try的话,程序直接崩溃。用try的话,则可以让程序运行下去,并且输出为什么出错! try的话,配合log4j使用会对程序的日后维护帮助很大。