在网上偶尔看到一个关于寄存器某位清零的操作,有人指出如题写法并不健壮,此博客记录。
问题的关键在于 ~1 的值,假设值 1 占8位(由编译器决定),
二进制表示为 0000 0001
那么~1的值为 1111 1110
此时与一个寄存器 & ,确实可以将第 0 位清零,且确保[7:1]位不变。
但是如果该寄存器超过8位,比如16位,
那么在做&操作时 ~1 会被在前自动补0,
此时 ~1 == 0000 0000 1111 1110。
这样reg与16位寄存器 位与&, 有可能改变寄存器高8位的值。