HAL_GetTick()内部就是一个32位的uwTick,每隔1个tick ++一次,
如果tick设置为1ms,wuTick 49天会溢出。 ...
没有问题的。
你自己试一下吧。
0x00000000 - 0xffffffff = 1
以前没想过这个问题,乍一看也认为溢出会有问题。
经楼上两位点拨,发现自己还是脑回路太短,太容易被带偏了。 记录一下:
有人认为,HAL_Delay每隔49天左右就会出问题(我一开始也这么以为),原因是uint32每49天会溢出一次,这种观点是错误的。因为即便溢出了,两个unsigned数相减的结果也不会出错,正如11#所言:0x00000000 - 0xffffffff = 1。
HAL_Delay在延时超过49天时才会出错,但没有人会这么干,所以这个函数基本可以认为是没问题的。 我记得曾经也看过有人讨论过这个问题
其实不止是这里,有一些库也用过类似的无符号数相减的特性来优化计算的 我是熊猫大仙 发表于 2018-7-5 14:44
我记得曾经也看过有人讨论过这个问题
其实不止是这里,有一些库也用过类似的无符号数相减的特性来优化计算 ...
无符号数相减是个什么结果 ??可以利用这个来做什么优化? select326 发表于 2018-7-5 16:05
无符号数相减是个什么结果 ??可以利用这个来做什么优化?
跟HAL_Delay这样类似的,不需要去判断溢出,直接相减
例子就看jjbboox举的就是 我是熊猫大仙 发表于 2018-7-5 16:41
跟HAL_Delay这样类似的,不需要去判断溢出,直接相减
例子就看jjbboox举的就是 ...
unsigned char a,b,c;
a = 0x00000000;
b = 0xffffffff;
c = a - b;
printf("c=%d\n",c);
以上代码是在X64机器上编译:
gcc b.c -o bb
b.c: 在函数‘main’中:
b.c:7: 警告:大整数隐式截断为无符号类型
这个警告的意义是什么? select326 发表于 2018-7-6 14:24
unsigned char a,b,c;
a = 0x00000000;
b = 0xffffffff;
给unsigned char赋值0xffffffff,这个警告很明显呀。。。。 我是熊猫大仙 发表于 2018-7-6 14:34
给unsigned char赋值0xffffffff,这个警告很明显呀。。。。
我明白子了,unsigned char最大是0xff , 这种代码都是大神们写的,尽管不能说大神们就不会犯错,但是这么久经考验的代码一般都是值得信赖的。
如果想不通,可以先自己验证一把,然后就能学到很多。
页:
1
[2]