java里from和to有什么区别(java:forward 和redirect的区别是什么)
大家好,今天来为大家解答java里from和to有什么区别这个问题的一些问题点,包括java:forward 和redirect的区别是什么也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~
java中几种Map在什么情况下使用,并简单介绍原因及原理
一、Map用于保存具有映射关系的数据,Map里保存着两组数据:key和value,它们都可以使任何引用类型的数据,但key不能重复。所以通过指定的key就可以取出对应的value。Map接口定义了如下常用的方法:
1、void clear():删除Map中所以键值对。
2、boolean containsKey(Object key):查询Map中是否包含指定key,如果包含则返回true。
3、boolean containsValue(Object value):查询Map中是否包含指定value,如果包含则返回true。
4、Set entrySet():返回Map中所包含的键值对所组成的Set集合,每个集合元素都是Map.Entry对象(Entry是Map的内部类)。
5、Object get(Object key):返回指定key所对应的value,如Map中不包含key则返回null。
6、boolean isEmpty():查询Map是否为空,如果空则返回true。
7、Set keySet():返回该Map中所有key所组成的set集合。
8、Object put(Object key,Object value):添加一个键值对,如果已有一个相同的key值则新的键值对覆盖旧的键值对。
9、void putAll(Map m):将指定Map中的键值对复制到Map中。
10、Object remove(Object key):删除指定key所对应的键值对,返回可以所关联的value,如果key不存在,返回null。
11、int size():返回该Map里的键值对的个数。
12、Collection values():返回该Map里所有value组成的Collection。
Map中包含一个内部类:Entry。该类封装了一个键值对,它包含了三个方法:
1、Object getKey():返回该Entry里包含的key值。
2、Object getValeu():返回该Entry里包含的value值。
3、Object setValue(V value):设置该Entry里包含的value值,并返回新设置的value值。
二、HashMap和Hashtable实现类:
1、HashMap与HashTable的区别:
1)同步性:Hashtable是同步的,这个类中的一些方法保证了Hashtable中的对象是线程安全的。而HashMap则是异步的,因此HashMap中的对象并不是线程安全的。因为同步的要求会影响执行的效率,所以如果你不需要线程安全的集合那么使用HashMap是一个很好的选择,这样可以避免由于同步带来的不必要的性能开销,从而提高效率。
2)值:HashMap可以让你将空值作为一个表的条目的key或value,但是Hashtable是不能放入空值的。HashMap最多只有一个key值为null,但可以有无数多个value值为null。
2、性能:HashMap的性能最好,HashTable的性能是最差(因为它是同步的)
3、注意:
1)用作key的对象必须实现hashCode和equals方法。
2)不能保证其中的键值对的顺序
3)尽量不要使用可变对象作为它们的key值。
三、LinkedHashMap:
它的父类是HashMap,使用双向链表来维护键值对的次序,迭代顺序与键值对的插入顺序保持一致。LinkedHashMap需要维护元素的插入顺序,so性能略低于HashMap,但在迭代访问元素时有很好的性能,因为它是以链表来维护内部顺序。
四、TreeMap:
Map接口派生了一个SortMap子接口,SortMap的实现类为TreeMap。TreeMap也是基于红黑树对所有的key进行排序,有两种排序方式:自然排序和定制排序。Treemap的key以TreeSet的形式存储,对key的要求与TreeSet对元素的要求基本一致。
1、Map.Entry firstEntry():返回最小key所对应的键值对,如Map为空,则返回null。
2、Object firstKey():返回最小key,如果为空,则返回null。
3、Map.Entry lastEntry():返回最大key所对应的键值对,如Map为空,则返回null。
4、Object lastKey():返回最大key,如果为空,则返回null。
5、Map.Entry higherEntry(Object key):返回位于key后一位的键值对,如果为空,则返回null。
6、Map.Entry lowerEntry(Object key):返回位于key前一位的键值对,如果为空,则返回null。
7、Object lowerKey(Object key):返回位于key前一位key值,如果为空,则返回null。
8、NavigableMap subMap(Object fromKey,boolean fromlnclusive,Object toKey,boolean toInciusive):返回该Map的子Map,其key范围从fromKey到toKey。
9、SortMap subMap(Object fromKey,Object toKey);返回该Map的子Map,其key范围从fromkey(包括)到tokey(不包括)。
10、SortMap tailMap(Object fromkey,boolean inclusive):返回该Map的子Map,其key范围大于fromkey(是否包括取决于第二个参数)的所有key。
11、 SortMap headMap(Object tokey,boolean inclusive):返回该Map的子Map,其key范围小于tokey(是否包括取决于第二个参数)的所有key。
五、WeakHashMap:
WeakHashMap与HashMap的用法基本相同,区别在于:后者的key保留对象的强引用,即只要HashMap对象不被销毁,其对象所有key所引用的对象不会被垃圾回收,HashMap也不会自动删除这些key所对应的键值对对象。但WeakHashMap的key所引用的对象没有被其他强引用变量所引用,则这些key所引用的对象可能被回收。WeakHashMap中的每个key对象保存了实际对象的弱引用,当回收了该key所对应的实际对象后,WeakHashMap会自动删除该key所对应的键值对。
六、IdentityHashMap类:
IdentityHashMap与HashMap基本相似,只是当两个key严格相等时,即key1==key2时,它才认为两个key是相等的。IdentityHashMap也允许使用null,但不保证键值对之间的顺序。
七、EnumMap类:
1、EnumMap中所有key都必须是单个枚举类的枚举值,创建EnumMap时必须显示或隐式指定它对应的枚举类。
2、EnumMap根据key的自然顺序,即枚举值在枚举类中定义的顺序,来维护键值对的次序。
3、EnumMap不允许使用null作为key值,但value可以。望采纳,谢谢。
Java 语言有哪三个分支,之间的区别是什么
Java语言有哪三个分支,之间的区别是什么
JAVA平台只要有以下三个大类
Java平台有三个版本,这使软件开发人员、服务提供商和设备生产商可以针对特定的市场进行开发:
* Java SE(Java Platform,Standard Edition)。Java SE以前称为 J2SE。它允许开发和部署在桌面、服务器、嵌入式环境和实时环境中使用的 Java应用程序。Java SE包含了支持 Java Web服务开发的类,并为 Java Platform,Enterprise Edition(Java EE)提供基础。
* Java EE(Java Platform,Enterprise Edition)。这个版本以前称为 J2EE。企业版本帮助开发和部署可移植、健壮、可伸缩且安全的服务器端 Java应用程序。Java EE是在 Java SE的基础上构建的,它提供 Web服务、组件模型、管理和通信 API,可以用来实现企业级的面向服务体系结构(service-oriented architecture,SOA)和 Web 2.0应用程序。
* Java ME(Java Platform,Micro Edition)。这个版本以前称为 J2ME。Java ME为在移动设备和嵌入式设备(比如手机、PDA、电视机顶盒和打印机)上运行的应用程序提供一个健壮且灵活的环境。Java ME包括灵活的用户界面、健壮的安全模型、许多内置的网络协议以及对可以动态下载的连网和离线应用程序的丰富支持。基于 Java ME规范的应用程序只需编写一次,就可以用于许多设备,而且可以利用每个设备的本机功能。
现在还有其他的分支,包括JINI和 JAVA CARD等不过最有影响的还是以上的三个大类
vb,javahe和c语言之间的区别是什么?javahe是什么语言?
只用过Java
vb和Java是面向对象的编程语言
这种语言你只要告诉计算机“做什么”而不用告诉它“怎么做”
vb中的v是visual的意思
就是可视化的
比方说你要建一个对话框
只需要把对话框“拖”去就是
不用考虑那对话框是如何实现的
c语言是面向过程的编程语言
你必须把计算1+2+3……+98+99+100的过程告诉(这个程序的设计相信你不陌生吧)
下面的网页上是面向对象语言的介绍,上面有和传统语言的区别,感兴趣的话可以去看看
:baike.baidu./view/125370.htm
C语言的.obj.out.exe之间的区别是什么C, obj,exe C是你自己编写的程序
是你想让计算机做的
obj是计算机能识别的语言,EXE是计算机运行的
c语言指针和结点之间的区别是什么指针是指针,它是存放地址的,而链表中的结点使用了指针表示每一个结点的地址,比如你在创建一个结点时struct student{ char name[20]; int age; struct student*next;}(struct student)malloc(sizeof(struct student));这就是你创建的一个结点的大小而成员next则是一个指针用来指向下一个节点的地址,所以每一个结点存放的是一个student的信息。
except,except for,apart from三个词之间的区别是什么?except用于同类之间。
except for用于不同类的。
apart from在同类或不同类都能用
except:除...外,例: Except him, we all went to the theatre.(把我们和他分成两部分)except for:除了...外,除去,例:This position is good, except for some spelling mistakes.(整体中除去一部分) apart from:除...外(别无)、若不是,例:Apart from going home, we cannot go anywhere.(两个不一定一样事物)
Какой,каком,какая之间的区别是什么?这是同一个疑问代词——Какой的不同形式。
Какой是疑问代词,也可以称为疑问形容词,它是修饰名词的,要与名词保持性、数、格的一致,意思是“什么样的”,“哪一个”。例如:
Какой——用于阳性单数第一、四格名词前、阴性单数第二、三、五、六格的名词前。
каком——用于阳性单数第六格的名词前,它是用在介系词的后面的。
какая——用于阴性单数第一格的名词前。
希望我能帮助你解疑释惑。
在Scala(和Java)类和类之间的区别是什么1.当你说“型”我要去静态类型居多。但我会谈谈动态类型不久。静态类型是可以静态地证明(“没有运行它”)中的程序的一部分的属性。在静态类型语言中,每个表达式都有一个类型无论你写与否。例如,在CISH“诠释x=A* B+C-D”,A,B,c和d具有类型,A* B有一个类型 CodeGo.,一个* B+C有一个类型与A* B+C-D都有一个类型。但我们只注明x其中一个类型。在其他语言,比如Scala,C#,Haskell中,SML,和F#,即使这样,也没有必要。究竟什么样的属性是可证明取决于类型检查。 Scala的样式类,而另一方面,仅仅是规范的一组对象。该规范包括,包括了很多,代表性的细节,例如机构和private领域等在Scala中的类还指定模块的border。许多语言都有类型,但不具有类和许多语言都有课,但没有(静态)类型。有类型和类之间的一些细微的差别。列表[字符串]是一种类型,但不是一类。在Scala中列出的是类,但通常不是一个类型(它实际上是一个更高的kinded型)。在C#中列出的是不是一个类型的任何一种,并在Java中这是一个“原始类型”。 Scala提供结构类型。{foo的高清:pubs}指可证明有一个返回pubs,不分阶级的任何对象。它是一个类型,但不是一个类。类型可以是类型当你写DEF为foo [T](X:T)=...,那么foo的体内T是一个类型。但T是不是一类。类型可以是虚拟的scala(即“抽象类,但是,今天(不能是虚拟与scala虽然有一个样板沉重的方式来虚拟类编码现在,动态类型。动态类型对象执行某些操作之前,会自动检查的性质。在动态类型的基于类的OO语言有类型和类之间有很强的相关性。事情发生在JVM语言比如Scala和Java具有只可以动态地检查,如反射和投射操作。在这些语言中,“类型擦除”更多的还是大多数对象的动态类型是因为他们的阶级。更多或更少。这不是真正的,例如,它们通常不被擦除,使之可以告诉数组[INT]和数组[字符串]之间的区别数组。但我的宽泛定义的“动态类型对象的自动检查的性质。”当反射也能够发送到的对象。如果对象支持则一切正常了。是有意义的谈话,可以嘎嘎如鱼得水作为一个动态类型的所有对象,即使它不是一个类。这是一个什么样的Python和调用的本质“鸭打字。”此外,通过我的宽泛定义,甚至“zeroness”是一个动态的类型在某种意义上说,在大多数语言中,会自动检查号码,以确保你不被零除。有一个非常,非常少的语言,可以证明,静态地使零(或不为零)的静态类型。最后,其他的也有类型,例如int不具有一个类作为一个细节,类型,如Null和任何这是一个有点特殊,但可能有类和不和类型,如没有它甚至没有任何值更何况是一个类。
2.好吧,我会咬...有一个很好的答案,所以我要去尝试不同的技巧和提供一个更下降到地球的观点。广义地说,一类是可被实例化。单例对象(scala)性状(scala)和接口(scala)被认为是类。这是有道理的,因为单身仍然实例化(代码)和一个接口可以被实例化一个子类的一部分。其中第二点.class是设计在大多数面向对象语言的基本单位(虽然不是基于原型的,如JavaScript)的。多态性与子类在类术语界定.class还提供了一个和可见性控制。类型是一个非常不同的野兽,该系统能够表达每一个可能的值将具有一种或多种类型,并且这些可以等同于类,例如:(Int)=> String both the type and class are Function1[Int,String]
"hello world" class and type are String
您还可以得到scala和Java之间有趣差异:7 both the class and type are Int in Scala
in Java there's no class and the type is Integer.TYPE
println("hello world") the return type is Unit, of class Unit
Java has void as a type, but no corresponding class
error("oops") the type and class are both"Nothing"
而真正有趣的类型不属于类的。例如,this.type始终指的unique类型this。这是唯一的一个实例,是不是与类的其他实例。也有抽象类型和类型,例如:type A'A' is an undetermined abstract type
to be made concrete in a subclass
class Seq[T]{...} T is a type, but not a class
Seq有趣的是,因为它是一个类,而不是一个类型。更准确地说,它是一个“类的构造函数”,这将构建一个有效的类型时,提供必要的类型提供的类型构造器的另一个术语是“高kinded类型”,我个人不喜欢这个词,因为“型构造”思在供应类型像任何其他表单的条款-模型,有良好的scala。“高kinded”正确地暗示Seq有一个“种”,这是*=>*,这个符号指出,Seq将采取单一的类型和产生一个单一的类型(这类似于用于描述函数柯里表示法)。通过这样的一种Map是*=>*=>*它需要两个类型
3. A型可通过本身,没有任何实例.a个例子这就是所谓的“幽灵式”。下面是Java的一个例子:在这个例子中,我们有public static class Initializer<HA, HB>,其中HA和HB取类型(由抽象类代表TRUE和FALSE),而没有beeing实例化。我希望这表明,类型和类是不同的,并且类型可以通过本身。
4.(仅限于Java),我会说,一类是一组对象。对象o是类型X如果o是集X.class型X是的子类型Y,如果设置X的一个子集Y。对于每一个C类(不是接口)有一组对象,从创建new C(...)。有趣的是,我们很少在乎这一套。(但每一个对象不属于一组这样的事实,这可能对于每一个C类,有一种类型t(C)一般方称为“C型”,这是一组可从被创建的所有对象的new S(...)其中,S是C或C的子类类似地,对于每一个接口I,有一种类型的t(I),“I型”,这是一组可从被创建的所有对象的new S(...)其中S一如果类S是的一个子类C,S型是C型的类似接口的子类型I有一个空值类型,它是空集。 NULL类型是每个类型的子类型。有一组中的所有对象,这是Object类型。这是一个超类型每一种类型的。到目前为止,这种表单主义是A型基本上是在一个类或接口,以及亚型的关系基本上是子类/子关系。在平凡是一件好事,语言是可以理解的!但进入仿制药,有型,而像类型的并,交运算.class型不再只类和接口,以及亚型关系更丰富,更难理解。
语言和言语之间的区别是怎样的语言的范围比较宽泛,包括书面语言、口头语言等等。而言语只是说话之意。
sum total之间的区别是什么?sum是名词,指加总后的和,可以说pay a large sum, sum to 2300
total原为adj,指总共有...,可以说 total 2300 pieces, total has 2300 pieces
java:forward 和redirect的区别是什么
forward方式:request.getRequestDispatcher("/somePage.jsp").forwardrequest, response);
redirect方式:response.sendRedirect("/somePage.jsp");
forward是服务器内部重定向,程序收到请求后重新定向到另一个程序,客户机并不知道;redirect则是服务器收到请求后发送一个状态头给客户,客户将再请求一次,这里多了两次网络通信的来往。当然forward也有缺点,就是forward的页面的路径如果是相对路径就会有些问题了。 forward会将 request state, bean等等信息带往下一个 jsp
redirect是送到 client端后再一次 request,所以资料不被保留.
使用 forward你就可以用 getAttribute()来取的前一个 jsp所放入的 bean等等资料
在网上看到一些帖子,总结了一些区别,可以从以下几个方面来看:
1.从地址栏显示来说
forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址.
redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.所以redirect等于客户端向服务器端发出两次request,同时也接受两次response。
2.从数据共享来说
forward:转发页面和转发到的页面可以共享request里面的数据.
redirect:不能共享数据.
redirect不仅可以重定向到当前应用程序的其他资源,还可以重定向到同一个站点上的其他应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源.
forward,方法只能在同一个Web应用程序内的资源之间转发请求.forward是服务器内部的一种操作.
redirect是服务器通知客户端,让客户端重新发起请求.
所以,你可以说 redirect是一种间接的请求,但是你不能说"一个请求是属于forward还是redirect"
3.从运用地方来说
forward:一般用于用户登陆的时候,根据角色转发到相应的模块.
redirect:一般用于用户注销登陆时返回主页面和跳转到其它的网站等.
4.从效率来说
forward:高.
redirect:低.
5.jsp语法
<jsp:forward page={"relativeurl"|"<%= expression%>"}/>
或者这样写:
<jsp:forward page={"relativeurl"|"<%= expression%>"}>
<jsp:param name="parametername" value="{parametervalue|<%= expression%>}"/>+
</jsp:forward>
6.例子
<jsp:forward page="/servlet/login.jsp"/>
<jsp:forward page="/servlet/login.jsp">
<jsp:param name="username" value="jsmith"/>
</jsp:forward>
描述
<jsp:forward>标签从一个jsp文件向另一个文件传递一个包含用户请求的request对象.<jsp:forward>标签以下的代码,将不能执行.
你能够向目标文件传送参数和值,在这个例子中我们传递的参数名为username,值为scott,如果你使用了<jsp:param>标签的话,目标文件必须是一个动态的文件,能够处理参数.
如果你使用了非缓冲输出的话,那么使用<jsp:forward>时就要小心。
如果在你使用<jsp:forward>之前,jsp文件已经有了数据,那么文件执行就会出错.
属性
page="{relativeurl|<%= expression%>}"
这里是一个表达式或是一个字符串用于说明你将要定向的文件或url.这个文件可以是jsp,程序段,或者其它能够处理request对象的文件(如asp,cgi,php).
<jsp:param name="parametername" value="{parametervalue|<%= expression%>}"/>+
向一个动态文件发送一个或多个参数,这个文件一定是动态文件.
如果你想传递多个参数,你可以在一个jsp文件中使用多个<jsp:param>。name指定参数名,value指定参数值.
<jsp:forward>例子
<%@ page contentType="text/html;charset=gb2312"%>
<html>
<head>
<title>test</title>
</head>
<body>
<jsp:forward page="forwardTo.jsp">
<jsp:param name="userName" value="riso"/>
</jsp:forward>
</body>
</html>
forwardTo.jsp
<%@ page contentType="text/html;charset=gb2312"%>
<!--forwardTo.jsp-->
<%
String useName=request.getParameter("userName");
String outStr="谢谢光临!";
outStr+=useName;
out.println(outStr);
%>
redirect的例子:
譬如:client通过XXX\index.jsp?name=gauss&pwd=123访问index.jsp,而index.jsp中有< jsp:forward page="login.jsp"/>,则在login.jsp中可以通过request.getParameter()得到name和pwd,而<%response.sendRedirect("login.jsp");%>得不到。
--------------------------------------------------------------------------------------------------
在Java Web开发中,经常会用到跳转页面的方法,一般有下面两种方法。
Java代码
HttpServletResponse response= new HttpServletResponse();
response.sendRedirect(location);
RequestDispatcher rd= new RequestDispatcher();
rd.forward(request, response);
跳转方式
http://localhost:8080/Test应用
运用forward方法只能重定向到同一个Web应用程序中的一个资源。而sendRedirect方法可以让你重定向到任何URL。
表单form的action=“/uu“;sendRedirect(“/uu“);表示相对于服务器根路径。如http://localhost:8080/Test应用(则提交至http://localhost:8080/uu);
Forward代码中的“/uu“则代表相对与WEB应用的路径。如http://localhost:8080/Test应用(则提交至http://localhost:8080/Test/uu);
(运用RequestDispatcher接口的Forward)方法
forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件,
同时forward()无法在后面带参数传递,比如servlet?name=frank,这样不行,可以程序内通过response.setAttribute(“name“,name)来传至下一个页面.
重定向后浏览器地址栏URL不变.
只有在客户端没有输出时才可以调用forward方法。如果当前页面的缓冲区(buffer)不是空的,那么你在调用forward方法前必须先清空缓冲区。
“/“代表相对与web应用路径
RequestDispatcher rd= request.getRequestDispatcher(“/ooo“);
rd.forward(request, response);提交至http://localhost:8080/Test/ooo
RequestDispatcher rd= getServletContext().getRequestDispatcher(“/ooo“);
rd.forward(request, response);提交至http://localhost:8080/Test/ooo
RequestDispatcher rd=getServletContext().getNamedDispatcher(“TestServlet“);(TestServlet为一个<servlet-name>)
rd.forward(request, response);提交至名为TestServlet的servlet
如果在<jsp:forward>之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意。
另外要注意:它不能改变浏览器地址,刷新的话会导致重复提交
从http://localhost:8080/Test/gw/page.jsp中转发
<jsp:forward page=“OtherPage.jsp“/>在JSP页面被解析后转换成pageContext.forward(“OtherPage.jsp [...]
--------------------------------------------------------------------------------------------------
清空当前缓存:
在之前撰写JSP的例子中,实用了out这个对象,这个对象您不用事先宣告,就可以在JSP网页中使用,这是JSP所提供的隐含对象
(Implicit Object),在转译为Servlet之后,out会转换为对应于javax.servlet.jsp.JspWriter型态的对象。
JspWriter直接继承自java.io.Writer,您可以使用println()、print()方法将指定的数据以字符的方式传送至客户端,println()会
在送出数据之后进行换行,而print()则否,注意换行指的是在HTML原始码中设定换行字符,而不是输出<br>标签使得在网页中可以
换行。
out(JspWriter)具有缓冲区功能,HTTP的特性是为了要取得一份资源,就进行一份协议沟通,如果资源数目很多(例如一份HTML文件
还包括了许多的小图片),而每份资源的容量实际上很小,那么为了要取得完整的资源,将会花费很多通讯在协议往来上,假设如果
out(JspWriter)不具有缓冲功能,则每一次out.println(),就会直接将数据送出至客户端,那么单要完成一个完整网页的传送,就
会花费不少的网络资源,每一个JSP网页预设上都会具有缓冲,您可以使用page指令元素的autoFlush属性来设定是否使用缓冲区功能
。
在Tomcat5上,预设为每一个JSP网页备有8192字节的缓冲区(您可以使用page指令元素的buffer属性来自缓冲区的大小),在缓冲区还
没有满之前,数据不会真正被送出至客户端,在这之前,您还有机会重设送出的数据,如果缓冲区满了,数据将会被清出并送至客户
端,可以使用下面这个程序来示范:
buffer.jsp
<%@page contentType="text/html;charset=Big5"%>
<%
out.println("预设缓冲区大小:"+ out.getBufferSize()+"<br>");
out.flush();
//下面的文字不会出现在客户端
out.println("您看的到这段文字吗?");
out.clearBuffer();
out.println("这段您可以看到!");
%>
您可以使用flush()直接清出缓冲区的内容,而clearBuffer()会将缓冲区的内容清除,所以第二段文字不会出现在客户端的网页上,
而最后一段会整个JSP网页执行完整后自动送出至客户端,执行结果如下:
预设缓冲区大小:8192
这段您可以看到!
您可以使用page指令元素的autoFlush来设定JSP页面是否使用缓冲区自动清出功能,out(JspWriter)以一种方式与
HttpServletResponse的PrintWriter建立关系,两者之间的行为关系取决于是否使用缓冲区自动清出,如果使用缓冲区自动清出,则
在缓冲区满之前,或是使用flush()之前不会建立PrintWriter对象来对客户端进行输出,如果不使用缓冲区自动清出,则写入out
(JspWriter)对象的数据会直接写入PrintWriter对象,然后在指定flush()之后输出至客户端。
如果您将autoFlush设定为false,则您必须明确的使用flush()来输出数据,否则缓冲区满了的话,就会发生IOException例外,使用
缓冲区有其好处,但由于缓冲区在满之前,数据并不会真正送出客户端,所以会有响应延迟的问题,如果您要实时性将结果响应至客
户端,则可以关闭缓冲区。
下面这个程序测试缓冲区关闭之后,如果缓冲区满了,会有什么结果:
buffer.jsp
<%@page contentType="text/html;charset=Big5"%>
<%
for(int i=0; i<2000; i++){
out.println("test");
//out.flush();
}
%>
如果没有移开out.flush()的批注符号,则会响应一下的错误讯息:
HTTP Status 500-
type Exception report
message
description The server encountered an internal error() that prevented it from fulfilling this request.
exception
java.io.IOException: Error: JSP Buffer overflow
......
关于java里from和to有什么区别和java:forward 和redirect的区别是什么的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。