逍遥自在学C语言 | 位运算符>>的高级用法

前言

在上一篇文章中,我们介绍了<<运算符的高级用法,本篇文章,我们将介绍>> 运算符的一些高级用法。

逍遥自在学C语言 | 位运算符>>的高级用法

一、人物简介

  • 第一位闪亮登场,有请今后会一直教我们C语言的老师 —— 自在。

逍遥自在学C语言 | 位运算符>>的高级用法

  • 第二位上场的是和我们一起学习的小白程序猿 —— 逍遥。

逍遥自在学C语言 | 位运算符>>的高级用法

二、优化除法运算

  • 除法运算需要比位移运算需要更多的计算资源,某些情况下采用位移运算可以提高性能

  • 代码示例

#include <stdio.h>
int main()
{
    int a = 1024;
    int b = a / 8; // 整除8
    int c = a >> 3; // 相当于除以8
    printf("b = %d, c = %d\n", b, c);
    return 0;
}
  • 每右移一位相当于除以2, a >> 3相当于a/(2*2*2) = a/8
  • 运行结果

逍遥自在学C语言 | 位运算符>>的高级用法

三、获取字节序

  • 大端模式:是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中。

  • 小端模式:是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中。

  • 右移运算符还可以用于获取当前系统的字节序(即大端序或小端序)

  • 比如数字 0x1234在内存中的表示形式为:

    大端模式:
    低地址 -----------------> 高地址
    0x12 | 0x34

    小端模式:
    低地址 ------------------> 高地址
    0x34 | 0x12

  • 代码示例

#include <stdio.h>
int main()
{
    short int i = 0x1234; // 假设i在内存中的地址为0x1000
    char *p = (char *)&i; // 将i的地址转换为字符型指针,即指向0x1000的字节型指针
    if (*p == 0x12) // 判断*p的值是否等于0x12,如果等于则为大端序,否则为小端序
    {
        printf("大端序\n");
    }
    else
    {
        printf("小端序\n");
    }
    return 0;
}
  • 运行结果

逍遥自在学C语言 | 位运算符>>的高级用法

四、提取二进制数的某一位

  • 将一个二进制数右移n位,再与1进行按位与运算,得到的结果就是这个二进制数的第n位(从第0位开始算)
  • 例如,将1011右移2位,得到的结果是10,再与1进行按位与运算,得到的结果是0,即1011的第二位是0
  • 代码示例
#include <stdio.h>
int main()
{
    int a = 0b1011;
    int b = (a >> 2) & 1; // 提取a的第二位,即0
    printf("第二位的值为 %d\n", b);
    return 0;
}
  • 运行结果

逍遥自在学C语言 | 位运算符>>的高级用法

五、提取二进制数的多个连续位

  • 将一个二进制数右移n位,再与一个掩码进行按位与运算,得到的结果就是这个二进制数从第n位开始的若干位
  • 例如,将1011011右移3位,得到的结果是1011,再与111进行按位与运算,得到的结果是011,即1011011从第3位开始的三位是011
  • 代码示例
#include <stdio.h>
int main()
{
    int a = 0b1011011;
    int b = (a >> 3) & 0b111; // 提取a从第3位开始的3位,即101
    printf("b = %d\n", b);
    return 0;
}
  • 运行结果,3 (二进制为0b011)

逍遥自在学C语言 | 位运算符>>的高级用法

六、浮点数向下舍入为整数

  • 这种用法通常用于嵌入式系统中,因为某些嵌入式处理器没有浮点数运算单元,只能使用整数运算单元来处理浮点数

  • 将一个浮点数乘以一个定点数的精度,并将结果向下取整,可以得到一个整数近似值

  • 例如,将一个浮点数乘以1000,再将结果右移10位,得到的结果就是这个浮点数乘以1000并向下取整的整数值

  • 代码示例

#include <stdio.h>
int main()
{
    float x = 3.1415926;
    int a = (int)(x * 1000.0f) >> 10; // 将x乘以1000并向下取整
    printf("向下取整后的数值为 %d\n", a);
    return 0;
}
  • 运行结果

逍遥自在学C语言 | 位运算符>>的高级用法

小结

通过这篇文章,我们学会了用位运算符>>的5种高级用法

1、优化除法运算

2、获取字节序

3、提取二进制数的某一位

4、提取二进制数的多个连续位

5、浮点数向下舍入为整数

?欢迎各位 ?点赞 ⭐收藏 ?评论,如有错误请留言指正,非常感谢!

原文链接:https://www.cnblogs.com/Wayne123/p/17324428.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:逍遥自在学C语言 | 位运算符>>的高级用法 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • 浅析Lua编程中的异常处理

    浅析Lua编程中的异常处理 异常处理是一种非常重要的编程实践,它可以让我们更好地处理代码中可能出现的错误,提高程序的健壮性。在Lua编程中,异常处理同样非常重要而且也非常容易实现,本文将会对Lua编程中的异常处理进行浅析。 try-catch 在Lua中,我们可以使用try-catch结构来捕获异常。try语句块中包含可能会出现异常的语句,当其中的某个语句发…

    C 2023年5月23日
    00
  • 菜鸟记录:c语言实现PAT甲级1003–Emergency

      久违的PAT,由于考研408数据结构中有一定需要,同时也是对先前所遗留的竞赛遗憾进行一定弥补 ,再次继续PAT甲级1003.。 As an emergency rescue team leader of a city, you are given a special map of your country. The map shows several s…

    C语言 2023年4月17日
    00
  • C语言中如何进行跨库链接?

    在C语言中,可以使用跨库链接来实现在不同的库文件中使用相同的函数和全局变量。下面将介绍如何进行跨库链接的具体步骤。 1. 编译源代码 首先,我们需要编译源代码并生成目标文件。在编译源代码时,需要使用编译器的-c选项,指定生成目标文件而不生成可执行文件。例如,在Linux系统下可以使用以下命令编译myfunc.c文件: gcc -c myfunc.c -o m…

    C 2023年4月27日
    00
  • C语言实现顺序表的基本操作的示例详解

    介绍 C语言是一门基础的编程语言,学习和了解C语言是一种基本的能力,实现顺序表是C语言中的一个常见问题。 什么是顺序表? 顺序表是一种线性结构,其中的元素在物理位置上是连续的。数组是一种简单的顺序表。 在顺序表中,每个元素的位置都能通过它在表中的下标计算出来。例如: int a[5] = {1, 2, 3, 4, 5}; printf("%d&qu…

    C 2023年5月30日
    00
  • 求斐波那契(Fibonacci)数列通项的七种实现方法

    求斐波那契数列通项的七种实现方法 方法一:递归 斐波那契数列的递推公式为:F(n) = F(n-1) + F(n-2),为了求得第 n 个斐波那契数,可以通过递归求解,但是递归实现时间复杂度为 O(2^n),随着 n 的增大,运行效率会非常低下。 def fib_recursion(n): if n <= 1: return n return fib_…

    C 2023年5月22日
    00
  • set_new_handler(0)有什么用

    set_new_handler是C++语言提供的一个函数,用于设置一个新的内存分配失败处理程序。当内存分配操作失败时,该处理程序将被调用。当我们在C++程序中使用new操作符申请内存时,如果系统找不到合适的内存块,就会触发内存分配失败,进而导致程序抛出std::bad_alloc异常。 set_new_handler(0)的作用是设置一个新的内存分配失败处理…

    C 2023年5月23日
    00
  • C语言链表实现学生管理系统

    C语言链表实现学生管理系统 链表是一种数据结构,它具有很好的插入和删除操作,并且可以对元素进行动态调整。学生管理系统是常用的一个应用场景。此处将用C语言来实现一个简单的学生管理系统,采用链表实现。 数据结构 在本例中,每个学生表示为一个结构体包含姓名和性别两个成员变量。由于要使用链表实现,每个学生还需要有一个指针成员变量,表示下一个学生节点。 代码如下: t…

    C 2023年5月24日
    00
  • C语言实现的学生选课系统代码分享

    C语言实现的学生选课系统代码分享 简介 本文将分享一份用C语言实现的学生选课系统代码,该系统实现了学生的选课、退课、成绩查看等功能。通过学习本系统的代码,可以加深对C语法及数据结构的理解。 功能模块 学生选课系统包含了以下几个功能模块: 学生信息管理 课程信息管理 学生选课 学生退课 成绩查询 数据结构 该系统使用了以下数据结构: 结构体:用于存储学生信息、…

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部