深入了解C语言中的按位逻辑运算

了解C语言中的按位逻辑运算:

在C语言中,按位运算符是处理二进制数据的强大工具。按位运算符可以直接操控数据的每一位,这使得它们在处理低级别的数据操作、优化性能、嵌入式系统开发、加密算法等场景中变得尤为重要。在这篇博客中,我们将深入探讨几种常见的按位逻辑运算符,包括按位与 (AND)、按位或 (OR)、按位异或 (XOR)、按位取反 (NOT) 等,并展示如何在C语言中使用它们。

接下來我們就以宏定義的方式來説明:

以下是一些常见的按位逻辑运算符及其定义:

按位或 (OR): #define OR(a, b) ((a) | (b))

只要 a 或 b 的对应位有一个为 1,结果的对应位就为 1。否则为 0。
按位与 (AND): #define AND(a, b) ((a) & (b))

只有当 a 和 b 的对应位都为 1 时,结果的对应位才为 1。否则为 0。
按位异或 (XOR): #define XOR(a, b) ((a) ^ (b))

当 a 和 b 的对应位不同时,结果的对应位为 1;相同时,结果的对应位为 0。
按位或取反 (NOR): #define NOR(a, b) (~((a) | (b)))

对 OR 操作的结果取反。
按位与取反 (NAND): #define NAND(a, b) (~((a) & (b)))

对 AND 操作的结果取反。
按位异或取反 (NXOR): #define NXOR(a, b) (~((a) ^ (b)))

对 XOR 操作的结果取反。
按位取反 (NOT): #define NOT(a) (~a)

对 a 的每一位取反。
值取反 (TURN): #define TURN(a) (~a+1)

这通常用来获取一个数的补码。

示例代码

#include <stdio.h>
#include "LogicalOperator/Logical.h"

#define OR(a, b)   ((a) | (b))        // 按位逻辑或,两个位的值有一个为真结果为真
#define AND(a, b)  ((a) & (b))        // 按位逻辑与,两个位的值都为真结果为真
#define XOR(a, b)  ((a) ^ (b))        // 按位逻辑异或,两个位的值不一样为真
#define NOR(a, b)  (~((a) | (b)))     // 按位逻辑或,两个位的值有一个为真结果为真,按位取反
#define NAND(a, b) (~((a) & (b)))     // 按位逻辑与,两个位的值都为真结果为真,按位取反
#define NXOR(a, b) (~((a) ^ (b)))     // 按位逻辑异或,两个位的值不一样为真,按位取反
#define NOT(a)     (~a)               // 按位取反
#define TURN(a)    (~a+1)             // 值取反

int main(int argc, char const *argv[])
{
    int a = 127; 
    int b = 10;

    printf("OR(%d, %d) = %d\n", a, b, OR(a, b));    // 输出 OR 结果
    printf("AND(%d, %d) = %d\n", a, b, AND(a, b));  // 输出 AND 结果
    printf("XOR(%d, %d) = %d\n", a, b, XOR(a, b));  // 输出 XOR 结果
    printf("NOR(%d, %d) = %d\n", a, b, NOR(a, b));  // 输出 NOR 结果
    printf("NAND(%d, %d) = %d\n", a, b, NAND(a, b));// 输出 NAND 结果
    printf("XNOR(%d, %d) = %d\n", a, b, NXOR(a, b));// 输出 XNOR 结果
    printf("NOT(%d) = %d\n", a,  NOT(a));           // 输出 NOT 结果
    printf("TURN(%d) = %d\n", a,  TURN(a));         // 输出 TURN 结果

    return 0;
}
假设我们执行上述代码,给定 a = 127 和 b = 10,每个操作的结果如下:

OR(127, 10) = 127

二进制表示:127 = 0111111110 = 00001010,OR 结果:01111111 = 127
AND(127, 10) = 10

二进制表示:127 = 0111111110 = 00001010,AND 结果:00001010 = 10
XOR(127, 10) = 117

二进制表示:127 = 0111111110 = 00001010,XOR 结果:01110101 = 117
NOR(127, 10) = -128

NOR 结果:10000000 对应 -128(在二进制中最高位为符号位)
NAND(127, 10) = -11

NAND 结果:11110101 对应 -11
XNOR(127, 10) = -118

XNOR 结果:10001010 对应 -118
NOT(127) = -128

NOT 结果:01111111 取反为 10000000,即 -128
TURN(127) = -127

TURN 结果为 -127,即补码表示。

按位运算在处理底层数据时是非常高效和必要的。通过简单的按位操作,您可以实现复杂的逻辑计算,控制位级别的数据处理。掌握这些运算符,不仅能提升您在C语言中的编程技巧,还能为编写高性能、低级别的代码奠定坚实的基础。

【评估多目标跟踪方法】9个高度敏捷目标在编队中的轨迹和测量研究(Matlab代码实现)内容概要:本文围绕“评估多目标跟踪方法”,重点研究9个高度敏捷目标在编队飞行中的轨迹生成与测量过程,并提供完整的Matlab代码实现。文中详细模拟了目标的动态行为、运动约束及编队结构,通过仿真获取目标的状态信息与观测数据,用于验证和比较不同多目标跟踪算法的性能。研究内容涵盖轨迹建模、噪声处理、传感器测量模拟以及数据可视化等关键技术环节,旨在为雷达、无人机编队、自动驾驶等领域的多目标跟踪系统提供可复现的测试基准。; 适合人群:具备一定Matlab编程基础,从事控制工程、自动化、航空航天、智能交通或人工智能等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①用于多目标跟踪算法(如卡尔曼滤波、粒子滤波、GM-CPHD等)的性能评估与对比实验;②作为无人机编队、空中交通监控等应用场景下的轨迹仿真与传感器数据分析的教学与研究平台;③支持对高度机动目标在复杂编队下的可观测性与跟踪精度进行深入分析。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,重点关注轨迹生成逻辑与测量模型构建部分,可通过修改目标数量、运动参数或噪声水平来拓展实验场景,进一步提升对多目标跟踪系统设计与评估的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值