如下操做符 都是按照优先级顺序从左到右,从上到下的方式来列出的web
描述 | 操做符 |
---|---|
一元后缀 | expr++(递增) expr–(递减) () [] . ?. |
一元前缀 | -expr(负号) !expr (取反) ~expr(按位补码 0变为1;1变为0) ++expr(递增) --expr (递减) |
乘除 | * / %(取模) ~/(除号,可是返回值为整数) |
加减 | + - |
转移 | << >> |
按位与 | & |
位异或 | ^ |
按位或 | 竖线 |
关系和类型测试 | >= > <= < as is is! |
平等 | == != |
逻辑和 | && |
逻辑或 | 双竖线 |
if null | ?? |
条件选择 | expr1 ? expr2 : expr3 |
级联操做 | `` |
赋值操做 | = *= /= ~/= %= += -= <<= >>= &= ^= |
示例:ide
assert(2 + 3 == 5); assert(2 - 3 == -1); assert(2 * 3 == 6); assert(5 / 2 == 2.5); // Result is a double assert(5 ~/ 2 == 2); // Result is an integer assert(5 % 2 == 1); // Remainder print('5/2 = ${5~/2} r ${5%2}'); // 5/2 = 2 r 1
小注1:支持递增++,递减–前缀和后缀,+=,*= ·····svg
var a, b; a = 0; b = ++a; // Increment a before b gets its value. assert(a == b); // 1 == 1 a = 0; b = a++; // Increment a AFTER b gets its value. assert(a != b); // 1 != 0 a = 0; b = --a; // Decrement a before b gets its value. assert(a == b); // -1 == -1 a = 0; b = a--; // Decrement a AFTER b gets its value. assert(a != b); // -1 != 0 var a = 2; // Assign using = a *= 3; // Assign and multiply: a = a * 3 assert(a == 6);
小注2:使用 == 操做符测试两个对象表明的是否为一样的内容。(在某些状况下,你须要知道两个对象是不是同一个对象, 使用 identical(object,object) 方法。)测试
小注3:对??的解释ui
a = value; // 给 a 变量赋值 b ??= value; // 若是 b 是 null,则赋值给 b; // 若是不是 null,则 b 的值保持不变
小注4:条件表达式.net
condition ? expr1 : expr2
若是 condition 是 true,执行 expr1 (并返回执行的结果); 不然执行 expr2 并返回其结果。code
expr1 ?? expr2
若是 expr1 是 non-null,返回其值; 不然执行 expr2 并返回其结果。xml
//赋值 var finalStatus = m.isFinal ? 'final' : 'not final';
// 是否为null String toString() => msg ?? super.toString();
把这个写复杂点就是对象
// Slightly longer version uses ?: operator. String toString() => msg == null ? super.toString() : msg; // Very long version uses if-else statement. String toString() { if (msg == null) { return super.toString(); } else { return msg; } }
小注5:级联操做解释blog
querySelector('#button') // Get an object. ..text = 'Confirm' // Use its members. ..classes.add('important') ..onClick.listen((e) => window.alert('Confirmed!'));
意思是(省略了下面的button):
var button = querySelector('#button'); button.text = 'Confirm'; button.classes.add('important'); button.onClick.listen((e) => window.alert('Confirmed!'));
也能够嵌套操做
final addressBook = (new AddressBookBuilder() ..name = 'jenny' ..email = 'jenny@example.com' ..phone = (new PhoneNumberBuilder() ..number = '415-555-0100' ..label = 'home') .build()) .build();
其余操做符:
操做符 | 解释 |
---|---|
() | 表明调用一个方法 |
[] | 访问 list 中特定位置的元素 |
. | 访问元素,例如 foo.bar 表明访问 foo 的 bar 成员 |
?. | 和 . 相似,可是左边的操做对象不能为 null,例如 foo?.bar 若是 foo 为 null 则返回 null,不然返回 bar 成员 |