statusjava的简单介绍
本篇文章给大家谈谈statusjava,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、STATUS 在Java哪个标签库里?
- 2、java中System.exti(int status)麻烦帮我举例列举一下 status到底是填什么的。
- 3、java web开发中 varStatues="status" 中参数status是啥作用和意思呢?这个参数的设置有啥要求呢?
- 4、java的showStatus()方法是在哪里定义的?
- 5、java中status1和status2的区别?
- 6、java自定义httpstatus枚举值
STATUS 在Java哪个标签库里?
jsp 中有一个c:forEach item="" var="" status=""/c:forEach迭代器
其中有个一个参数就是status
java中System.exti(int status)麻烦帮我举例列举一下 status到底是填什么的。
1. System.exit(0)是将你的整个虚拟机里的内容都停掉了 ,而dispose()只是关闭这个窗口,但是并没有停止整个application exit() 。无论如何,内存都释放了!也就是说连JVM都关闭了,内存里根本不可能还有什么东西
2. System.exit(0)是正常退出程序,而System.exit(1)或者说非0表示非正常退出程序
3. System.exit(status)不管status为何值都会退出程序。和return 相比有以下不同点:return是回到上一层,而System.exit(status)是回到最上层
java web开发中 varStatues="status" 中参数status是啥作用和意思呢?这个参数的设置有啥要求呢?
java web开发中 varStatues="status" 中参数status的含义:
估计不错的话,说的这个是c:forEachjstl循环标签的一个属性,varStatus属性就拿varStatus=“status”来说,事实上定义了一个status名的对象作为varStatus的绑定值
该绑定值也就是status封装了当前遍历的状态,比如,可以从该对象上查看是遍历到了第几个元素:${status.count}。
c:forEach varStatus="status"中 varStatus的属性简介:
我们常会用c标签来遍历需要的数据,为了方便使用,varStatus属性可以方便我们实现一些与行数相关的功能,如:奇数行、偶数行差异;最后一行特殊处理等等。先就varStatus属性常用参数总结下:
${status.index} 输出行号,从0开始。
${status.count} 输出行号,从1开始。
${status.current} 当前这次迭代的(集合中的)项
${status.first} 判断当前项是否为集合中的第一项,返回值为true或false
${status.last} 判断当前项是否为集合中的最后一项,返回值为true或false
begin、end、step分别表示:起始序号,结束序号,跳跃步伐。
如:c:forEach begin='1' end='5' step='2' items='${list}' var='item'
表示:操作list集合汇中1~5条数据,不是逐条循环,而是按每2个取值。即操作集合中的第1、3、5条数据。
下面是我从网上找的图,觉得挺好,收藏了:
c:forEach varStatus属性
current当前这次迭代的(集合中的)项
index当前这次迭代从 0 开始的迭代索引
count当前这次迭代从 1 开始的迭代计数
first用来表明当前这轮迭代是否为第一次迭代的标志
last用来表明当前这轮迭代是否为最后一次迭代的标志
begin属性值
end属性值
step属性值
写个最近使用过的小例子:
c:forEach items="${command.modelList}" var="model" varStatus="abc"
tr
tdc:out value="${abc.count}"//td
td class="model"
form:checkbox path="select" value="${abc.index}"/
label for="model1"${model.modelName}/label
p${model.modelDesc}/p
/td
td
form:select path = "modelList[${abc.index}].positionIdx" onchange="selectPoss(this);"
option value=""请选择/option
form:option value="A" label="位置A"/
form:option value="B" label="位置B"/
form:option value="C" label="位置C"/
form:option value="D" label="位置D"/
form:option value="E" label="位置E"/
form:option value="F" label="位置F"/
/form:select
/td
td
a href="#" onclick="getModelDetail(${model.modelID});"img src="%=request.getContextPath()%/images/edit.gif" alt="编辑"//a
a href="#" onclick="deleteModel(${model.modelID});"img src="%=request.getContextPath()%/images/delete.gif" alt="删除" //a
/td
/tr
/c:forEach
c:forEach varStatus属性
index当前这次迭代从 0 开始的迭代索引
count当前这次迭代从 1 开始的迭代计数
first用来表明当前这轮迭代是否为第一次迭代的标志
last用来表明当前这轮迭代是否为最后一次迭代的标志
begin属性值
end属性值
step属性值
例:
表格偶数行与奇数行颜色交替效果
c:forEach items="${queryPromotionList}" var="vPromotion" varStatus="vstatus"
c:choose
c:when test="${vstatus.index%2==0}"
tr bgcolor="#FFFFFF" height="40"
/c:when
c:otherwise
tr bgcolor="#F3F3F5" height="40"
/c:otherwise
/c:choose
table class=table_body_bg cellspacing=1 cellpadding=1
width="100%" align=center border=0
c:forEach items="${list}" var="a" varStatus="vs"
c:if test="${vs.count%5==1}"
tr align="left" height="20"
/c:if
td class=table_body_td width="20%"a href="/aam/degree/advisorAnswer.do?sfid=${a.sfid }"${a.xm }(${a.sfid })/a/td
c:set var="count" value="${vs.count}"/ //${vs.count}只在c:forEach/c:forEach的范围内有值 外部引用需要把值传出去
/c:forEach
c:if test="${count%5==1}"
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
/tr
/c:if
c:if test="${count%5==2}"
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
/tr
/c:if
c:if test="${count%5==3}"
td class="table_body_td" width="20%"/td
td class="table_body_td" width="20%"/td
/tr
/c:if
c:if test="${count%5==4}"
td class="table_body_td" width="20%"/td
/tr
/c:if
c:if test="${count%5==0}"
/tr
/c:if
/table
不论是对整数还是对集合进行迭代, c:forEach 剩余的属性 varStatus 所起的作用相同。和 var 属性一样, varStatus 用于创建限定了作用域的变量。不过,由 varStatus 属性命名的变量并不存储当前索引值或当前元素,而是赋予 javax.servlet.jsp.jstl.core.LoopTagStatus 类的实例。
java的showStatus()方法是在哪里定义的?
命名空间java.applet类applet的类成员方法: showstatus
请求将参数字符串显示在“状态窗口”中。很多浏览器和 applet viewer 提供这种窗口,应用程序可以通过该窗口将其当前状态通知给用户。
java中status1和status2的区别?
Struts1和Struts2的区别和对比:
Action 类:
Struts1要求Action类继承一个抽象基类。Struts1的一个普遍问题是使用抽象类编程而不是接口。
Struts 2 Action类可以实现一个Action接口,也可实现其他接口,使可选和定制的服务成为可能。Struts2提供一个ActionSupport基类去实现 常用的接口。Action接口不是必须的,任何有execute标识的POJO对象都可以用作Struts2的Action对象。
线程模式:
Struts1 Action是单例模式并且必须是线程安全的,因为仅有Action的一个实例来处理所有的请求。单例策略限制了Struts1 Action能作的事,并且要在开发时特别小心。Action资源必须是线程安全的或同步的。
Struts2 Action对象为每一个请求产生一个实例,因此没有线程安全问题。(实际上,servlet容器给每个请求产生许多可丢弃的对象,并且不会导致性能和垃圾回收问题)
Servlet 依赖:
Struts1 Action 依赖于Servlet API ,因为当一个Action被调用时HttpServletRequest 和 HttpServletResponse 被传递给execute方法。
Struts 2 Action不依赖于容器,允许Action脱离容器单独被测试。如果需要,Struts2 Action仍然可以访问初始的request和response。但是,其他的元素减少或者消除了直接访问HttpServetRequest 和 HttpServletResponse的必要性。
可测性:
测试Struts1 Action的一个主要问题是execute方法暴露了servlet API(这使得测试要依赖于容器)。一个第三方扩展--Struts TestCase--提供了一套Struts1的模拟对象(来进行测试)。
Struts 2 Action可以通过初始化、设置属性、调用方法来测试,“依赖注入”支持也使测试更容易。
捕获输入:
Struts1 使用ActionForm对象捕获输入。所有的ActionForm必须继承一个基类。因为其他JavaBean不能用作ActionForm,开发者经常创建多余的类捕获输入。动态Bean(DynaBeans)可以作为创建传统ActionForm的选择,但是,开发者可能是在重新描述(创建)已经存在的JavaBean(仍然会导致有冗余的javabean)。
Struts 2直接使用Action属性作为输入属性,消除了对第二个输入对象的需求。输入属性可能是有自己(子)属性的rich对象类型。Action属性能够通过 web页面上的taglibs访问。Struts2也支持ActionForm模式。rich对象类型,包括业务对象,能够用作输入/输出对象。这种 ModelDriven 特性简化了taglib对POJO输入对象的引用。
表达式语言:
Struts1 整合了JSTL,因此使用JSTL EL。这种EL有基本对象图遍历,但是对集合和索引属性的支持很弱。
Struts2可以使用JSTL,但是也支持一个更强大和灵活的表达式语言--"Object Graph Notation Language" (OGNL).
绑定值到页面(view):
Struts 1使用标准JSP机制把对象绑定到页面中来访问。
Struts 2 使用 "ValueStack"技术,使taglib能够访问值而不需要把你的页面(view)和对象绑定起来。ValueStack策略允许通过一系列名称相同但类型不同的属性重用页面(view)。
类型转换:
Struts 1 ActionForm 属性通常都是String类型。Struts1使用Commons-Beanutils进行类型转换。每个类一个转换器,对每一个实例来说是不可配置的。
Struts2 使用OGNL进行类型转换。提供基本和常用对象的转换器。
校验:
Struts 1支持在ActionForm的validate方法中手动校验,或者通过Commons Validator的扩展来校验。同一个类可以有不同的校验内容,但不能校验子对象。
Struts2支持通过validate方法和XWork校验框架来进行校验。XWork校验框架使用为属性类类型定义的校验和内容校验,来支持chain校验子属性
Action执行的控制:
Struts1支持每一个模块有单独的Request Processors(生命周期),但是模块中的所有Action必须共享相同的生命周期。
Struts2支持通过拦截器堆栈(Interceptor Stacks)为每一个Action创建不同的生命周期。堆栈能够根据需要和不同的Action一起使用。
Struts1流程:
(1)用户的请求以HTTP方式传输到服务器上,接受请求的是ActionServlet.
(2)ActionServlet接收到请求后,会查找Struts-config.xml文件来确定服务器上是否有用户请求的操作,此处用户请求操作应为登陆操作。如果没有,则返回一个用户请求无效的出错信息。
(3)当ActionServlet请求找到用户请求的Action后,首先将用户输入的表单参数打包成一个ActionFrom对象,这个ActionFrom对象其实也就是一个JavaBean,里面包含两个字段,分别是用户名和密码。接着ActionServlet再根据struts-config.xml中的配置信息决定是否要执行ActionFrom对象中的Validate方法。若Validate方法执行有错,则返回。否则,继续下一步。
(4)系统生成一个用户所请求的Action的实例对象,将前面的ActionFrom对象传递给它,运行它的Execute()方法。这一步其实就是用户登陆的控制器,在执行exectue()方法时,可以调用后台模型验证登陆名和密码是否正确等信息。
(5)execute()执行结束前会生成ActionForward类型的对象并将之返回给ActionServlet
struts1的处理器
processMultipart()要是提交方式为post而且类型为Multipart则返回重新包装的HttpServletRequest对象
processPath()获取url路径以便选择struts Action组件
processLocale()把用户提交的Locale信息保存到session中
processContent()设置response.setContentType的值
processNoCache()设置报头Cache-Control Pragma Expires的值
processPreprocess()直接返回true 子类可以覆盖该方法实现己的操作
processMapping()查找对应的ActionMapping 不存在则返回错误信息
processRoles()判断对应的Action是否配置了安全角色 用户是否有权限
processActionForm()查找ActionMapping是否配置ActionForm 有则查找该实例不存在则创建
processPopulate()查找ActionMapping是否配置ActionForm 有则调用reset方法清空再装载表单数据
processValidate()调用ActionForm的validate方法返回ActionErrors 要是存在ActionMessage对象则验证失败
processForward()查找ActionMapping是否配置forward 有则采用forward结束流程
processInclude()查找ActionMapping是否配置include 有则采用include结束流程
processActionCreate()查找是否有对应的Action实例 不存在则创建
processActionPerform()调用Action的execute方法
processForwardConfig() 处理跳转
struts2的执行流程
1、客户端发起一个请求
2、主控器FilterDispatcher拦截请求.
3、主控器通过ActionMapper判断请求是否交给action
处理.如果是,那么判断请求的action是否存在,如果 不存在,报404错误.如果不是交给action处理,那么将
请求转发给对应的web组件.
4、主控器创建ActionProxy对象,这个对象全权负责 action的执行.
5、ActionProxy通过ConfigurationManager对象获得当 前访问的action的相关配置信息.
6、ActionProxy根据获得的action的配置信息,创建
ActionInvocation对象.
7、ActionInvocation对象负责执行action前面的拦截器
以及action对象,并且处理action执行后的结果.
8、action前面的拦截器被执行,最后执行action.
9、ActionInvocation得到action执行后的逻辑视图,根 据逻辑视图找到物理视图,然后转发请求.
java自定义httpstatus枚举值
由于每个程序员在开始编程时一般会首先学习C/C++,然后再学习Java,在C++中枚举是可以定义枚举值为特定的整数的,但这在Java中却没有得到支持,大概C/C++中的枚举代表了数值型常量多一些,而Java中枚举值,更确切的说为枚举类型对象。在Java中定义一个简单的枚举类如下所示。
关于statusjava和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。