Day 3
- 逻辑运算符的 “短路” 特性
#include < stdio.h>
#include <stdlib.h>
int main()
{
int a=1, b=2, c=3 , d=4;
int n=1, m=1;
( m =a>b) && ( n=c>d );
printf( “m=%d \n n=%d\n”, m , n);
exit(0);
}
这里会出现 && 后()中的运算式不会结果的情况 之前在工程中我的方法是 讲括两个括号中的内容颠倒位置 设立flag 分别检测两个方向的内容 以求得更加精细地状态的判断
由=号衍生出的扩展的赋值运算
#include < stdio.h>
#include <stdlib.h>
int main()
{
int a=6;
a -= a *= a +=3;
/*
从右至左计算
a=a+3 -> a=6+3=9
a=a*9 -> a=9*9=81
a=a-81 -> a=81-81=0
*/
exit(0);
}
- 在嵌入式开发中 位运算的意义重大 为了节省内存 一个8位二进制就可以 相当于8个 布尔flag 这在以往的开发中非常常见 但是存在一个问题 C语言并不能直接定义二进制的数 所以一般情况下还是使用八进制或者十六进制 就以往的经验来看 十六进制使用的比较多
/*
int i=B1100 ;这样的写法在很多状况下显然是不合法的
*/
而且要十分注意 ①位运算在嵌入式开发中的开关功能 IO组可以通过& |上特定的值对特定的位进行单独或批量的操作 例如通过 | 将某一位置1 ② 取出一个指定宽度的数中的某几位