- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当在函数调用中定义变量和函数时,我无法理解它们的作用域我试着搜索这个范围,但找不到合适的答案(或者可能是在搜索错误的东西),所以我决定自己编写一些函数来测试:
(defun test-scope1 ()
(setf myvar 1)
(defun set-var1 ()
(setf myvar 2))
(set-var1))
(test-scope1)
之前,命令
myvar
和
(set-var)
会给出错误信息在调用
(test-scope1)
之后,我可以在解释器中运行
myvar
和
(set-var)
,得到2。
(defun test-scope2 ()
(let ((myvar 10))
(defun set-var2 ()
(setf myvar 20))
(set-var2)))
myvar
被困在let块的范围内,但无法猜测
set-var2
它可能被困在let块中,也可能被全局定义运行
(test-scope2)
后,我尝试访问
myvar
并获取2这意味着这个新函数有自己的myvar,因为它仍然是前一个函数的2我试着跑
(set-var2)
得到20分。
(defun test-scope3 ()
(let ((myvar (if (ignore-errors myvar)
myvar
100)))
(defun set-var3 ()
(setf myvar (+ myvar 100)))
(set-var3)))
(test-scope3)
之后,我完全惊讶地看到102显然,我的test-scope3从运行test-scope1中找到了myvar的值但是,在检查了解释器中myvar的值之后,它仍然是2。接下来,我运行
(set-var3)
并得到返回值202。好吧,所以它又增加了100倍再次调用它将返回302,依此类推但是,再次调用
(test-scope3)
会将该值重置回102。
(defun test-scope4 ()
(let () ; or ((myvar 50))
(let ((myvar (if (ignore-errors myvar)
myvar
2000)))
(defun set-var4 ()
(setf myvar (+ myvar 1000)))
(set-var4))))
myvar
时,它从何而来从我的第四个例子推测,它在当前作用域中查找符号myvar,然后检查一个更高的级别,直到找到它的值。
(defun outer-function (start)
(let ((x start))
(defun increment-to-ten ()
(setf x (+ x 1))
(if (< x 10)
(increment-to-ten)))
(increment-to-ten)
(print x)))
(defun increment-to-ten-recursive (x)
(if (< x 10)
(increment-to-ten-recursive (+ x 1))
10))
最佳答案
为什么很难讨论你看到的效果:
您所做的事情在Common Lisp中是未定义的:在test-scope1
:myvar
中设置未声明的变量从那时起就不清楚下面的代码是如何运行的。
未声明的变量
当设置了未声明的变量foo
时,未定义它有什么影响实现允许它有些人会发出警告SBCL公司:
* (setf foo 10)
; in: SETF FOO
; (SETF FOO 10)
; ==>
; (SETQ FOO 10)
;
; caught WARNING:
; undefined variable: FOO
;
; compilation unit finished
; Undefined variable:
; FOO
; caught 1 WARNING condition
DEFPARAMETER
和
DEFVAR
定义局部变量由
LET
,
LET*
和函数参数定义。由于
DEFPARAMETER
和
DEFVAR
定义了全局特殊(使用动态绑定)变量,因此通常将它们写成
*some-variable*
-请注意其周围的
*
,这是符号名的一部分,而不是特殊语法这是一个特殊变量的约定。
DEFUN
s不用于普通Lisp
DEFUN
是一个顶级表单,用于设置全局函数要定义本地函数,请使用
FLET
和
LABELS
您可以嵌套
DEFUN
表单,但它的样式不好,而且在实际的Lisp代码中找不到它不要嵌套
DEFUN
表单。注意:这与Scheme不同,Scheme可以嵌套
DEFINE
表单由于没有使用nested
DEFUNs
,因此讨论其效果没有什么意义将示例转换为使用由
FLET
或
LABELS
定义的本地函数。
DEFUN
定义了全局函数这就是它的目的。
关于scope - Lisp函数和/或let语句中的函数和变量的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26231194/
我在这里有我的 javascript 代码: define(['controllers/controllers', 'services/alerts'], function(module) {
的意义是什么scope = scope-token *( SP scope-token ) scope-token = 1*( %x21 / %x23-5B / %x5D-7E ) 在 RFC6749
我是 AngularJS 的新手。我试图找出这两个 Controller 定义之间的区别: app.controller('simpleController', ['$scope', function
似乎所有 Guice 的开箱即用 Scope 实现本质上都是基于线程的(或完全忽略线程): Scopes.SINGLETON和 Scopes.NO_SCOPE忽略线程并且是边缘情况:全局范围和无范围。
如果这个问题涉及的是一个常见问题,我很抱歉,但我发现这个问题非常抽象,并且无法真正为其构建一个好的 Google 搜索词。 我试图理解并找到 Maven 中提供的依赖项的用例。我的想法是这样的: 假设
假设我有以下 Controller angular.module('scopeExample', []) .controller('MyController', ['$scope', func
当前在TmThemeEditor上注册的243种配色方案中, 我注意到几乎没有人使用范围选择器运算符。 对于以下情况,运算符非常有用: (text.html | text.xml) & (meta.t
我有一些行为不符合预期的代码......我在 AngularJS Controller 中有一个事件监听器,如下所示: $scope.$on("newClipSelected", function(e
首先,如果帖子太长,我深表歉意。另外,为了以防万一这会以某种方式干扰您可能给我的答案,我不会以通常的方式定义我的 Controller 。相反,我关注http://www.technofattie.c
我有一个模式,其中许多项目类型都是“可编辑的”。这意味着我有很多模板(每种可编辑项目类型一个),这些模板期望具有唯一的字段,但具有通用功能(编辑、保存、取消编辑、删除等)。这些常见功能导致 Contr
$evalAsync 和 $applyAsync 之间有什么区别?我的理解是,当我从指令中使用 $evalAsync 时,表达式将在浏览器呈现之前进行计算。 举个例子,如果我想滚动到页面上的特定位置但
我试图为一个 $scope 变量提供另一个 $scope 变量的值。有人能告诉我出了什么问题吗?查看简单的 plunker 了解详细信息: http://plnkr.co/edit/TlKnd2fM5
我有以下一段 Angular 代码 $scope.prepare = function(){ $scope.elems = [1,2,3]; }; $scope.action = functio
我正在关注 Angularjs 的官方教程,但我陷入了第 2 步。 这是一个片段,我不明白 $scope:scope 的含义, describe('PhoneListCtrl', function()
根据文档, Global: Component is shared among all users. Session: Separate instances of the component are
显示作用域变量,类似于 Angularjs 中的 ng-repeat 元素 这些是我的范围变量 $scope.published = true; $scope.count = 3; 我还有一个名为 l
我是 Angular 的新手,我想在普通的 javascript 中做一些非常简单的事情,但我无法找到如何在 Angular 中正确地做到这一点! 我想设置一个通用函数来清除输入文本字段: 我有这个
在article中发现了这样一个idea : Notice how the value function takes the scope as parameter (without the $ in
注释部分将位于 $scope.$on 下。我需要将 options 返回到我保存 $scope.$emit 的地方。请帮助!!! if (gridConfig.Batch) {
我有一个带有 2 个作用域的 Controller : app.controller('search', function($scope) { $scope.value1 = '';
我是一名优秀的程序员,十分优秀!