- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
给我一个确定的、经过同行评审/维护的 Ruby 优先级表(运算符、非运算符和修饰符)。
多年来,我不得不依赖以下来源获取此信息:
1. http://phrogz.net/programmingruby/language.html#table_18.4 - Pickaxe 一书记录了 2000 年 9 月发布的 Ruby 1.6
,其中包含格式错误或拼写错误({
列为一个赋值运算符)。
2. http://www.techotopia.com/index.php/Ruby_Operator_Precedence - 上述 Pickaxe 表的近似副本,包括错误的 {
,并且不小心将 ||
描述为逻辑“AND”.
3. http://www.tutorialspoint.com/ruby/ruby_operators.htm - 也是 Pickaxe 表的近似副本,虽然它将 ||
的描述修复为逻辑“或”,但它仍然列出 {
作为赋值运算符。此外,它列出了 ::
并错误地将其描述为常量解析运算符(::
不是运营商)。
4. http://my.safaribooksonline.com/book/web-development/ruby/9780596516178/expressions-and-operators/operators - The Ruby Programming Language 一书,记录了分别于 2003 年 8 月和 2007 年 12 月发布的 Ruby 1.8
和 1.9
。这本书由 David Flanagan 和 Yukihiro Matsumoto(又名“Matz”,Ruby 的发明者)于 2008 年出版。它似乎是最新和最准确的运算符、非运算符、修饰符和支持信息列表。顺便提一下,在 2005 年左右,随着 Rails 于 2004 年 7 月发布,人们对 Ruby 的兴趣激增。
5. http://romhack.wikia.com/wiki/Ruby_operators - 还记录了 Ruby 1.9
中的运算符,并在其表中包含了非运算符和修饰符。
Ruby 2.0
was released in February 2013, and was intended to be fully backward compatible with Ruby 1.9.3
.在少数已知的不兼容性中,没有一个与运算符有关。
Ruby 2.1.0
was released on Christmas Day in 2013
,并且类似地,没有列出运营商的不兼容性。
因此,我决定包含一个基于 Flanagan/Matz 书的答案,并将其设为社区维基。
最佳答案
运算符 是一种记号,表示要对一个或多个操作数执行的操作(例如加法或比较)。操作数是表达式,运算符允许我们将这些操作数表达式组合成更大的表达式。 ( Ref )
N = arity = 运算符操作的操作数的数量。 ( Ref )
A = 关联性 = 当相同运算符(或具有相同优先级的运算符)依次出现在表达式中时的计算顺序。值 L
表示表达式从从左到右 求值。值 R
表示表达式是从从右到左求值的。而值 N
表示该运算符是非关联 并且不能在没有括号指定求值顺序的表达式中多次使用。 ( Ref )
M = definability = Ruby 将许多操作符实现为方法,允许类为这些操作符定义新的含义。 M
列指定哪些运算符是方法。标有 Y
的运算符是用方法实现的,可以重新定义,而标有 N
的运算符则不能。 ( Ref )
下表按照优先级降序排列(最高优先级在顶部)。
N A M Operator(s) Description
- - - ----------- -----------
1 R Y ! ~ + boolean NOT, bitwise complement, unary plus
(unary plus may be redefined from Ruby 1.9 with +@)
2 R Y ** exponentiation
1 R Y - unary minus (redefine with -@)
2 L Y * / % multiplication, division, modulo (remainder)
2 L Y + - addition (or concatenation), subtraction
2 L Y << >> bitwise shift-left (or append), bitwise shift-right
2 L Y & bitwise AND
2 L Y | ^ bitwise OR, bitwise XOR (exclusive OR)
2 L Y < <= >= > ordering
2 N Y == === != =~ !~ <=> equality, pattern matching, comparison
(!= and !~ may not be redefined prior to Ruby 1.9)
2 L N && boolean AND
2 L N || boolean OR
2 N N .. ... range creation (inclusive and exclusive)
and boolean flip-flops
3 R N ? : ternary if-then-else (conditional)
2 L N rescue exception-handling modifier
2 R N = assignment
2 R N **= *= /= %= += -= assignment
2 R N <<= >>= assignment
2 R N &&= &= ||= |= ^= assignment
1 N N defined? test variable definition and type
1 R N not boolean NOT (low precedence)
2 L N and or boolean AND, boolean OR (low precedence)
2 N N if unless while until conditional and loop modifiers
关于Ruby 运算符优先级表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21060234/
int x = 1; System.out.println( x++ + x++ * --x ); 上面的代码打印出“5”,但我不明白怎么办?我一直为最后一个 x 取零,然后乘以仍然为 0 的第二个
我现在正在尝试使用 Preference 类 首选项 pfrOfThis = Preferences.userNodeForPackage(this) 出现错误: “类 java.util.prefs
用下面的代码 import sys print "Hello " + sys.argv[1] if len(sys.argv) > 1 else "Joe" + "." 当我运行时 python he
我的网页包含: td { padding-left:10px; } 引用的样式表包含: .rightColumn * {margin: 0; padding: 0;} 我在 rightc
使用 JPA 我有一个关于 CascadeTypes 的问题。 例如: @ManyToMany(fetch=FetchType.LAZY, cascade={CascadeType.PERSIST,
下面的“括号”是怎么写的? val words = List("foo", "bar", "baz") val phrase = "These are upper case: " + words ma
我只是想知道,对于以下代码,编译器是否单独使用关联性/优先级或其他一些逻辑来评估。 int i = 0, k = 0; i = k++; 如果我们根据关联性和优先级进行评估,postfix ++具有比
我设置了一个 Azure FrontDoor 服务,以主/备份类型的方式将流量分配给两个 API 管理服务。就像我希望所有流量都流向我的主要 APIM 服务一样,如果我碰巧关闭该服务(假装中断),那么
这是一个简单的 CSS: /* Smartphones (portrait and landscape) ----------- */ @media only screen and (min-devi
我设置了一个 Azure FrontDoor 服务,以主/备份类型的方式将流量分配给两个 API 管理服务。就像我希望所有流量都流向我的主要 APIM 服务一样,如果我碰巧关闭该服务(假装中断),那么
来自 Programming Perl pg 90,他说: @ary = (1, 3, sort 4, 2); print @ary; 排序右侧的逗号在排序之前求值,而左侧的逗号在排序之
+----+------------+------+ | id | title | lang | +----+------------+------+ | 1 | title 1 EN |
如何使用 Java 获取 DiffServe 代码点 (DSCP) 整数的优先级部分?我预计它涉及位移位,但由于某种原因,我似乎无法获得我期望的值。 最佳答案 假设我理解正确,只需向右执行 3 位逻辑
我有下一个运行良好的 js 函数: $(function () { $(".country").click(function () { var countries = Arra
int a[3]={10,20,30}; int* p = a; cout << *p++ << endl; 根据 wikipedia ,后缀++的优先级高于解引用,*p++应该先运行p++再解引用结
我想在优先读取归档后解决这种类型的表达式 2+3/5*9+3-4 这是我尝试解决该任务的代码我该如何解决这个问题 while ( !inputFile.eof() ) { getline( inp
我正在玩 Rhino 并注意到这种奇怪的行为似乎是运算符优先级: js> {}+{} NaN js> ''+{}+{} [object Object][object Object] js> ''+({
我想遍历文件列表并检查它们是否存在,如果文件不存在则给出错误并退出。我写了下面的代码: FILES=( file1.txt file2.txt file3.txt ) for file in ${FI
我正在执行级联 SELECT: SELECT * FROM x WHERE a = 1 AND b = 2 AND c = 3 => If nothing found, try: SELECT * F
即将参加考试,我正在参加之前的考试。 问题: 当两个或多个样式表规则应用于同一元素时,以下哪种类型的规则将优先? 一个。任何来自浏览器的声明 b.有用户来源的正常声明 C。作者来源正常声明 d.文档级
我是一名优秀的程序员,十分优秀!