"0 1 + 1"到底是等于 0 还是 1?
昨天碰上这个问题,着实把我坑惨了,花了一个晚上搞明白,python 和 golang 按位移动运算符的优先级居然不一样
python:
print(0 << 1 + 1)
输出:0
golang:
import "fmt"
func main() {
fmt.Println(0 << 1 + 1)
}
输出:1
为了让python和golang的行为一致,我只好为表达式里的"0 << 1"加了括号
感谢提醒,但像我这种菜鸟都是一堆括号的,如果有人说括号看晕,他是连工具都不会用的比我更菜的鸟。
感觉 0 好理解一点儿…
凡是有歧义的一律加括号
不加括号的话 Java 的计算结果也是 0
不同类型的操作符混合肯定是要加括号,就算自己能肯定顺序别人也不一定明白。
Pascal 里面 and 和 or 优先级比数学运算还高(因为同时被视为位运算符
判断条件就一直一堆括号,习惯了除了日常习惯的(基本就是四则运算)或者倒错就会立刻严重出错(比如 4/2-2 ,或者矩阵运算)的或者符合结合律的运算以外都加括号。
因为只有 go 的操作符优先级是 移位优先于加减 的
其他 java python c 都是 加减优先于移位
头像不错
我猜一会就有人跳出来说基本功 balabala 的
不用在意这种事,加括号解决完事,大家看着都清晰方便。
这种一般只有某些考试里会考,真使用时用不上这些知识。
工作这么多年除了之前写嵌入式用到了位移,现在写 WEB 基本没用过
看具体的语言吧,本人只熟悉 C ,C 里面+
> <<
,所以结果上述结果是 0 。
一般除了加减乘除这种运算,一律加括号
位移运算必加括号,血(不是)的教训。
fmt.Println(0<<1 + 1)
go 会按优先级自动格式化,建议其他语言学习
我看谁还嘲笑 lisp 括号罗嗦
加个括号很难么?别人不知道,要是我在实际生产环境中发现这种代码,直接开骂
i+++++i-----的变种? 这种不直接打残?
即使很熟悉运算符优先级,在书写可能有歧义的数学表达式时也尽可能加上括号
没必要纠结这种东西,啥,你说面试有人问?我反手就给他一巴掌
这种的意义是啥, 就像 ++i+++=++i++, 没有任何意义
“嘲笑 lisp 括号罗嗦”本来就是菜鸟行为
本站就不少。
涉及到位运算的,还是都加上括号吧。位运算本身就不是非常优美,多加点括号啰嗦一下也没什么事。
不同语言运算符优先级不一样,位运算在 C 系里优先级很低的
遇事不决加括号,编程不仰赖记忆力
先乘除后加减,其他尽量都上括号,
都说加括号,我不太一样,我宁可多用一个变量然后分两步写,位运算尽量分开,方便 debug
直接上括号,但凡你会一种以上的语言,深究这种语法细节有啥意义
developer.apple.com/documentation/swift/swift_standard_library/operator_declarations
用正确的思路 设计正确的程序
我不想,我直接加括号。
这个看具体的代码类型。
如果是表示的是具体的业务,特别是现实中的商务订单处理这类,当然应该尽量分开。
如果是对一张照片里的每个图素都进行一次变换操作,这么写代价就太大了。
我从来不考虑这个。像 Index.py 的路由,我至今记不清优先级,于是我都是
app.router << ("/client" // client_routes) << ("/auth" // auth_routes)
😓另外,考这个的多少有点魔怔了
不同语言的操作符优先级有可能不一致。反正加括号最保险,也更容易阅读。
楼主说的是 不同语言 运算符优先顺序不一样的问题,结果一堆“加括号”的评论,这不是废话吗?这是常识,就像乘号优先于加号一样。不应该讨论下为什么位运算符优先级不同语言不一样?
这里的存活,指的是还有很多人用。 你会提名什么软件?( 2 个) Linux 一定会,git 也许会 ping 会 jdk im 类的 ... linux 什么时候成…
初衷 这是前几天看到隔壁帖子吵得热闹,一时兴起写的,还没大规模测试,感兴趣的同学欢迎来 issue/pr 骚扰。 隔壁帖子: /t/859178 项目地址 github.co…
如何取的Java源代码文件中文件名和行号:) 在C/C++的程序,编译器提供了两个宏来支持取得源文件中的行号和文件名,这两个宏是__FILE__,__LINE__ 你可以如下的…