以下操作符 都是按照优先级顺序从左到右,从上到下的方式来列出的
描述 | 操作符 |
---|---|
一元后缀 | expr++(递增) expr–(递减) () [] . ?. |
一元前缀 | -expr(负号) !expr (取反) ~expr(按位补码 0变为1;1变为0) ++expr(递增) --expr (递减) |
乘除 | * / %(取模) ~/(除号,但是返回值为整数) |
加减 | + - |
转移 | << >> |
按位与 | & |
位异或 | ^ |
按位或 | 竖线 |
关系和类型测试 | >= > <= < as is is! |
平等 | == != |
逻辑和 | && |
逻辑或 | 双竖线 |
if null | ?? |
条件选择 | expr1 ? expr2 : expr3 |
级联操作 | `` |
赋值操作 | = *= /= ~/= %= += -= <<= >>= &= ^= |
示例:
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:支持递增++,递减–前缀和后缀,+=,*= ·····
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:对??的解释
a = value; // 给 a 变量赋值
b ??= value; // 如果 b 是 null,则赋值给 b;
// 如果不是 null,则 b 的值保持不变
小注4:条件表达式
condition ? expr1 : expr2
如果 condition 是 true,执行 expr1 (并返回执行的结果); 否则执行 expr2 并返回其结果。
expr1 ?? expr2
如果 expr1 是 non-null,返回其值; 否则执行 expr2 并返回其结果。
//赋值
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:级联操作解释
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 成员 |