位运算符

    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​位运算符

算术运算符     

 +  -     *(乘)    /(除)   %(取余,模运算)    +(连接符)

+(连接符):

例1:

class DemoFn

{

    ​    ​public static void main(String[] args){

    ​    ​    ​    ​System.out.println("5+5="+5+5);//结果5+5=55

    ​    ​}


class DemoFn1

{

    ​ ​public static void main(String[] args){

    ​    ​    ​int   a=5,b=6;{​

    ​    ​    ​    ​System.out.println("a="a+a",b="+b);//结果是a=5,b=6.

    ​    ​      ​​} ​

   ​   ​}

}


++      --

    ​  ++  ​(自增):就是在原有数据基础上+1,在赋给原有数据。

例1:

class  DemoFn2

{

    ​public static void main(String[] args){

    ​    ​int   a=3;

    ​    ​++a;{

    ​    ​    ​    ​System.out.println("a="+a);//结果a=4;

    ​    ​}

    ​}

}

例2:

class  DemoFn3

{

    ​public static vodi main(String[] args){

    ​    ​int  a=3,b;

    ​    ​b=a++;{

    ​    ​    ​    ​System.out.println("a="+a+",b="+b);//结果a=4,b=3;

    ​    ​}

    ​}

}


赋值运算符:

=   +=   -=   *=   /=   %=

特点:

+=:将左右两边的和赋给左边

 -=:将左右两边的差赋给左边

*=将左右两边的积赋给左边

/=将左右两边的商赋给左边

%=将左右两边的余数赋给左边



面试题:

class DemoFn4

{

    ​public static void main(String[] args){

    ​    ​short  s  =3;

    ​    ​s+=4;——>这个在底层做了自动转换。

    ​    ​{

    ​        ​    ​  System.out.println("s="+s)"  ;

    ​    ​}

    ​}

}

class DemoFn4

{    ​public static void main(String[] args){

    ​    ​short   s=3;

    ​    ​s=s+4;

    ​    ​ //这个叫两次运算,这样不行。

    ​    ​  //改成这样就可以s=(short)(s+4);

​    ​    ​    ​{

    ​    ​    ​    ​System.out.println("s="+s);

    ​    ​    ​}

    ​}

}


答:一个编译通过,一个编译失败。失败的原因是他进行了自动类型的提升,类型

已经不能赋给第一空间类型。因为会出现精度丢失。s+=4,为什么他可以,因为他

在底层做了自动转换。


<think>好的,用户的问题是关于单片机中的“三位运算符”的使用说明或示例。首先,我需要确认用户是否指的是“三目运算符”或者是否存在其他可能的误解。因为在编程中,常见的位运算符通常是按位与(&)、按位或(|)、按位异或(^)、按位取反(~)、左移(<<)和右移(>>),这些通常被称为位运算符,而“三位运算符”这个术语并不常见,可能是用户输入时的笔误。 接下来,我会考虑用户提到的参考引用内容,其中提到了位运算符的种类,如左移、右移、按位取反等。用户可能将“三目运算符”误写为“三位运算符”,或者可能是指三个位的操作。但根据常见的编程知识,三目运算符(条件运算符)是存在的,形式为条件 ? 表达式1 : 表达式2,用于条件判断。而位运算符中并没有三位的运算符,因此需要进一步澄清。 然后,我需要检查单片机编程中常用的运算符。在C语言中,单片机常用的位运算符是上述提到的那些,每个运算符处理的是单个位或多个位的组合。例如,按位与用于屏蔽某些位,按位或用于设置某些位,移位运算用于乘以或除以2的幂次方。用户可能想了解如何使用这些位运算符进行三位的操作,比如同时操作三个位,或者处理三位的数据。 另外,用户可能是在问三目运算符在单片机中的应用,比如条件判断的简洁写法。但根据用户的引用内容,他们之前的问题是关于位运算符的,所以更可能是在询问位运算符相关的三位操作。例如,如何用位运算符提取或设置三个连续的位。 考虑到用户可能的混淆,回答中需要先澄清可能的术语误解,然后分别解释三目运算符和位运算符中的三位操作。同时,需要提供具体的示例代码,说明在单片机编程中如何应用这些运算符,比如寄存器操作中的位掩码设置、状态标志的读取或修改等。 最后,生成相关问题,帮助用户进一步理解相关概念,比如三目运算符与if语句的区别、位运算优化技巧等。</think>[系统级回答] 关于单片机编程中"三位运算符"的说明如下: 1. 术语澄清: "三位运算符"实际为术语混淆,可能指以下两种运算符: - 三目运算符(条件运算符):唯一的三操作数运算符$条件 ? 真值表达式 : 假值表达式$ - 位运算符:处理二进制位的运算符,如$&, |, ^, ~, <<, >>$等[^1] 2. 三目运算符示例: ```c // 设置GPIO输出电平 GPIO_PIN = (电压 > 2.5V) ? HIGH : LOW; // 计算PWM占空比 uint8_t duty_cycle = (温度 > 30) ? 75 : 50; ``` 3. 位运算符的三位操作: ```c // 定义3位状态寄存器(假设使用低3位) #define STATE_MASK 0x07 // 二进制00000111 // 设置后三位状态 PORT |= (new_state & STATE_MASK); // 保留其他位,设置低3位 // 读取中间三位(假设位3-5) uint8_t sensor_val = (ADC_DATA >> 3) & 0x07; // 三位置换操作 value = (value & 0xF8) | (new_bits & 0x07); // 保持高5位不变,替换低3位 ``` 4. 复合位运算示例: ```c // LED阵列控制(假设每3位控制一组RGB LED) uint32_t led_ctrl = 0; led_ctrl |= (red << 0) | (green << 1) | (blue << 2); // 设置第一组颜色 led_ctrl |= (模式 ? 0x38 : 0x07) << 3; // 根据模式设置第二组颜色 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值