`
akunamotata
  • 浏览: 378685 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

直观作用域

阅读更多

从显示的结果来看,我们可以直观的得出结论:

  1. page里的变量没法从index.jsp传递到test.jsp。只要页面跳转了,它们就不见了。

  2. request里的变量可以跨越forward前后的两页。但是只要刷新页面,它们就重新计算了。

  3. session和application里的变量一直在累加,开始还看不出区别,只要关闭浏览器,再次重启浏览器访问这页,session里的变量就重新计算了。

  4. application里的变量一直在累加,除非你重启tomcat,否则它会一直变大。

    而作用域规定的是变量的有效期限。

    1. 如果把变量放到pageContext里,就说明它的作用域是page,它的有效范围只在当前jsp页面里。

      从把变量放到pageContext开始,到jsp页面结束,你都可以使用这个变量。

    2. 如果把变量放到request里,就说明它的作用域是request,它的有效范围是当前请求周期。

      所谓请求周期,就是指从http请求发起,到服务器处理结束,返回响应的整个过程。在这个过程中可能使用forward的方式跳转了多个jsp页面,在这些页面里你都可以使用这个变量。

    3. 如果把变量放到session里,就说明它的作用域是session,它的有效范围是当前会话。

      所谓当前会话,就是指从用户打开浏览器开始,到用户关闭浏览器这中间的过程。这个过程可能包含多个请求响应。也就是说,只要用户不关浏览器,服务器就有办法知道这些请求是一个人发起的,整个过程被称为一个会话(session),而放到会话中的变量,就可以在当前会话的所有请求里使用。

    4. 如果把变量放到application里,就说明它的作用域是application,它的有效范围是整个应用。

      整个应用是指从应用启动,到应用结束。我们没有说“从服务器启动,到服务器关闭”,是因为一个服务器可能部署多个应用,当然你关闭了服务器,就会把上面所有的应用都关闭了。

      application作用域里的变量,它们的存活时间是最长的,如果不进行手工删除,它们就一直可以使用。

      与上述三个不同的是,application里的变量可以被所有用户共用。如果用户甲的操作修改了application中的变量,用户乙访问时得到的是修改后的值。这在其他scope中都是不会发生的,page, request, session都是完全隔离的,无论如何修改都不会影响其他人的数据。

       

      我们使用public Object getAttribute(String name)获得变量值,使用public void setAttribute(String name, Object value)将变量值保存到对应作用域中。举个pageContext的例子就是:

      // page
      Integer countPage = (Integer) pageContext.getAttribute("countPage");
      if (countPage == null) {
          pageContext.setAttribute("countPage", 1);
      } else {
          pageContext.setAttribute("countPage", countPage + 1);
      }

      这里先从pageContext中取出名为countPage的整数,因为返回的都是java.lang.Object类型,所以需要强制转换成我们需要的整形。这里取得的变量如果不存在就会返回null,通过判断countPage == null来辨别变量是否存在,如果不存在就设置为1,如果存在就进行累加,最后使用setAttribute()方法将修改后的变量值放入pageContext。

      将其中的pageContext换成request, session, application就可以操作其他三个作用域中的变量。

      在显示这些变量值的时候,我们没有写<%=pageContext.getAttribute("countPage")%>而是使用了${countPage}的形式,这种${}的形式叫做el表达式,是jsp-2.0规范的一部分,tomcat里正好可以使用。

      使用el有以下几个好处:

      1. 代码量小,并且不需要使用尖括号。

      2. 支持从pageContext, request, session, application中取值,它会自动检查四个作用域,不需要特别指定。

      3. 如果变量不存在,会输出空字符串"",而不是null,省去了手工判断的工作。

         

         

分享到:
评论

相关推荐

    第四章示例代码__对象的作用域

    通过这些例子,开发者将能更直观地看到作用域规则的实际应用,并学会在实际项目中灵活运用。 总结来说,对象的作用域是编程中不可或缺的一部分,它决定了对象的可见性和生命周期。深入理解和熟练掌握对象作用域,...

    JavaScript 基础函数_深入剖析变量和作用域

    JavaScript是一种广泛用于网页开发的脚本语言,它的函数和作用域是实现代码逻辑结构和模块化的重要元素。在JavaScript中,函数是可执行的代码块,能够被多次调用,并且可以返回数据到调用它的地方。同时,变量作为...

    javascript作用域链(Scope Chain)初探.docx

    ### JavaScript作用域链(Scope Chain)初探 #### 一、引言 JavaScript的作用域链是一个重要的概念,尤其是在深入理解JavaScript执行机制时不可或缺的一部分。本文将通过对几个具体例子的分析来探讨JavaScript作用域...

    Python中作用域的深入讲解

    Python的作用域规则简单直观,有助于防止命名冲突并管理程序中的数据。以下是对Python作用域的详细讲解: 1. **作用域的层次** - **局部作用域(Local)**:在函数内部定义的变量,只在该函数内部有效。例如`def f...

    2023-04-06-项目笔记 - 第六十八阶段 - 4.4.2.66全局变量的作用域-66 -2024.03.10

    为了更直观地理解全局变量的作用域,下面通过一个简单的C语言程序示例来说明: ```c #include // 定义全局变量 int globalVar = 10; void func1() { printf("func1: globalVar = %d\n", globalVar); } void ...

    js代码-es5块级作用域实现

    在JavaScript的世界里,作用域是变量和函数定义的可见范围,它决定了这些定义可以在哪里被访问。...然而,对于新的项目,建议使用ES6或更高版本,因为它们提供了更强大且直观的作用域管理工具,如`let`和`const`。

    从组件封装看Vue的作用域插槽的实现

    作用域插槽不是那么直观的一个概念。Vue文档使用了一段描述性的话来解释作用域插槽: 有的时候你希望提供的组件带有一个可从子组件获取数据的可复用的插槽 …… 但是在我们应用的某些部分,我们希望每个独立的待办项...

    javascript 嵌套的函数(作用域链)

    嵌套的函数(作用域链) 当你进行函数的嵌套时,要注意实际上作用域链是发生变化的,这点可能看起来不太直观。你可把下面的代码置入firebug监视值的变化。 代码如下: var testvar = ‘window属性’; var o1 = {test...

    Python中的作用域规则详解

    Python是一种解释型编程语言,它在设计上是静态作用域...总结来说,Python的作用域规则相对直观,但处理嵌套作用域时与C等其他静态作用域语言有所差异。理解这些作用域的规则对于编写清晰、高效的Python代码至关重要。

    关于Javascript作用域链的八点总结

    通过一个简单的示例,我们可以更直观地理解作用域链的工作原理。例如,在`assignEvents`函数中,匿名函数(Closure)在执行时,它的作用域链包括`assignEvents`的活动对象(包含`id`变量),以及`assignEvents`自身...

    php代码-参数作用域

    全局作用域是程序开始到结束时始终存在的作用域,其中定义的变量在整个脚本中都可访问,除非被特定函数或块级作用域覆盖。在函数外部定义的变量默认为全局变量,但在函数内部无法直接修改它们,除非使用`global`...

    JavaScript变量的作用域全解析

    对象属性的作用域非常直观,因为对象属性可以在对象的作用域内直接访问。例如: ```javascript var scope = "global"; var obj = new Object(); obj.scope = "object"; obj.checkScope = function() { var scope =...

    浅谈js的解析顺序 作用域 严格模式

    在作用域与变量提升结合时,容易产生一些非直观的行为。例如: ```javascript alert(a); // 输出 undefined,而不是报错,因为变量a被提升到了函数作用域的顶部 var a = 1; ``` 如果函数中有同名的函数声明和变量...

    js代码-JS 作用域和闭包例子

    JS主要有两种作用域:全局作用域和局部作用域。 1. **全局作用域**:当变量在任何函数外部声明时,它就在全局作用域中。这意味着该变量在整个程序中都是可见的,可以在任何地方被引用。 2. **局部作用域**:在函数...

    Angularjs全局变量被作用域监听的正确姿势

    本文将深入探讨如何正确地在作用域上监听全局变量,并解决可能遇到的问题。 首先,我们要了解AngularJS中的作用域(Scope)机制。作用域是AngularJS中的一个核心概念,它是应用程序数据模型和视图之间的桥梁。在...

    js代码-异步、作用域、闭包

    在JavaScript中,异步处理、作用域和闭包是三个核心概念,对于理解和编写高效、可维护的代码至关重要。 **异步编程** JavaScript是一种单线程语言,这意味着在任何给定时刻,它只能执行一个任务。为了处理耗时操作...

    北航程序设计语言原理题目与参考答案

    由于词法作用域较为直观并且易于理解,大多数现代编程语言都采用词法作用域。 然后,参数机制描述了在过程调用中,参数是如何传递的。传值是将实际参数的值复制到形式参数上,不改变实际参数的值。传名(传值调用)...

    C语言的变量PPT课件.pptx

    C语言中的变量是编程的基础,理解变量的生存期和作用域对于编写高效、无误的代码至关重要。在C语言中,变量分为全局变量和局部变量,这两种变量在内存中的存储方式和可访问范围都有所不同。 3.1 变量的生存期: ...

    JavaScript Variable Performance

    4. **将激活对象添加到作用域链的前端**:最后,激活对象被添加到执行上下文的作用域链的最前端,这意味着局部变量总是最先被查找。 #### 三、标识符解析 标识符解析是指在执行上下文中查找变量名的过程。解析过程...

    详细讲解C++的课件,直观易懂。

    - **函数原型作用域**:函数参数的作用域始于函数声明,结束于声明结束。 - **文件作用域**:全局变量和静态外部对象在整个源文件中可见。 - **全局作用域**:未在任何函数内部声明的变量在整个程序中可见。 - *...

Global site tag (gtag.js) - Google Analytics