C语言复习概要(四)

在这里插入图片描述

本文

      • 1. 操作符的分类
        • 算术操作符
        • 关系操作符
        • 逻辑操作符
      • 2. 二进制制和进制转换
        • 二进制与十六进制的表示
        • 进制转换算法
      • 3. 原码、反码和补码
        • 原码
        • 反码
        • 补码


1. 操作符的分类

C语言中的操作符种类繁多,常用的主要操作符可以按照其功能进行如下分类:

  • 算术操作符:用于基本的数学运算,例如加法、减法、乘法和除法。
  • 关系操作符:用于比较两个操作数的关系,返回布尔值(真或假)。
  • 逻辑操作符:用于逻辑运算,如与、或、非等,用于条件判断。
  • 位操作符:按位操作符处理位级别的数据操作。
  • 赋值操作符:将右侧的值赋给左侧变量。
  • 条件操作符(三元运算符):对条件表达式进行判断,并根据条件返回不同的值。
  • 逗号操作符:顺序执行多个表达式,并返回最后一个表达式的值。
  • 其他操作符:包括取地址符号&、指针解引用符*等。
算术操作符

算术操作符用于处理整数和浮点数的基本运算,它们包括加法(+)、减法(-)、乘法(*)、除法(/)和取模(%)。

代码示例:更复杂的算术操作

#include <stdio.h>int main() {int a = 15, b = 4;float x = 7.5, y = 2.0;// 整数算术操作printf("a + b = %d\n", a + b); // 加法printf("a - b = %d\n", a - b); // 减法printf("a * b = %d\n", a * b); // 乘法printf("a / b = %d\n", a / b); // 整数除法printf("a %% b = %d\n", a % b); // 取模操作// 浮点数算术操作printf("x + y = %.2f\n", x + y); // 浮点加法printf("x - y = %.2f\n", x - y); // 浮点减法printf("x * y = %.2f\n", x * y); // 浮点乘法printf("x / y = %.2f\n", x / y); // 浮点除法// 混合算术操作printf("a + x = %.2f\n", a + x); // 整数与浮点混合运算printf("b * y = %.2f\n", b * y);return 0;
}

在这个例子中,我们展示了整数与浮点数的加法、减法、乘法、除法和取模运算。整数运算和浮点数运算的区别是,整数除法会丢弃小数部分,而浮点运算会保留小数部分。

关系操作符

关系操作符用于比较两个值,并返回一个布尔结果。它们包括:

  • ==:等于。
  • !=:不等于。
  • <:小于。
  • >:大于。
  • <=:小于等于。
  • >=:大于等于。

代码示例:使用关系操作符进行比较

#include <stdio.h>int main() {int a = 10, b = 20;// 比较 a 和 bif (a == b) {printf("a 等于 b\n");} else {printf("a 不等于 b\n");}if (a < b) {printf("a 小于 b\n");} else {printf("a 不小于 b\n");}if (a >= 5) {printf("a 大于等于 5\n");}return 0;
}

通过使用关系操作符,可以轻松判断两个操作数之间的大小关系,从而在程序中做出条件判断。关系操作符的返回结果通常用于if语句或其他控制结构中。

逻辑操作符

逻辑操作符用于布尔逻辑运算,包括:

  • &&:逻辑与。如果两个操作数都为真,则结果为真。
  • ||:逻辑或。如果至少一个操作数为真,则结果为真。
  • !:逻辑非。将真值转换为假,将假值转换为真。

代码示例:逻辑操作符在条件判断中的使用

#include <stdio.h>int main() {int a = 5, b = 10, c = 15;// 使用逻辑与操作符if (a < b && b < c) {printf("a 小于 b 且 b 小于 c\n");}// 使用逻辑或操作符if (a > b || b < c) {printf("a 大于 b 或者 b 小于 c\n");}// 使用逻辑非操作符if (!(a == b)) {printf("a 不等于 b\n");}return 0;
}

在这个示例中,逻辑与(&&)和逻辑或(||)用于复杂条件判断。逻辑非(!)通常用于反转条件的布尔值,便于简化条件表达式。


2. 二进制制和进制转换

二进制(binary)、八进制(octal)和十六进制(hexadecimal)在低层次的系统编程中非常常见。C语言提供了便捷的方法来表示不同进制的数值。理解二进制数对于掌握位操作符至关重要,而进制转换则是在二进制、十进制和十六进制之间切换。

二进制与十六进制的表示

在C语言中,二进制数通常以0b开头表示,而十六进制数则以0x开头表示。例如,0b1010代表二进制的数字10,而0xA表示十六进制的数字10

代码示例:二进制、八进制和十六进制表示法

#include <stdio.h>int main() {int binaryNum = 0b1010;  // 二进制 1010, 等于十进制 10int octalNum = 012;      // 八进制 12, 等于十进制 10int hexNum = 0xA;        // 十六进制 A, 等于十进制 10printf("二进制数 0b1010 = %d\n", binaryNum);printf("八进制数 012 = %d\n", octalNum);printf("十六进制数 0xA = %d\n", hexNum);return 0;
}

在上述代码中,我们使用了不同的进制表示方法,展示了如何在C语言中处理各种进制表示。printf函数中的%d会将数值转换为十进制输出。

进制转换算法

在实际开发中,我们经常需要将一个进制数转换为另一个进制数。下面我们展示如何手动实现二进制到十进制的转换。

代码示例:手动实现进制转换

#include <stdio.h>
#include <math.h>// 二进制转换为十进制
int binaryToDecimal(int binary) {int decimal = 0, i = 0, remainder;while (binary != 0) {remainder = binary % 10;binary /= 10;decimal += remainder * pow(2, i);++i;}return decimal;
}// 十进制转换为二进制
int decimalToBinary(int decimal) {int binary = 0, i = 1, remainder;while (decimal != 0) {remainder = decimal % 2;decimal /= 2;binary += remainder * i;i *= 10;}return binary;
}int main() {int binary = 1010;int decimal = 10;printf("二进制 %d 转换为十进制: %d\n", binary, binaryToDecimal(binary));printf("十进制 %d 转换为二进制: %d\n", decimal, decimalToBinary(decimal));return 0;
}

这个例子展示了如何手动将二进制转换为十进制,反之亦然。通过简单的算法,可以帮助理解进制转换的过程


3. 原码、反码和补码

原码反码补码是用于表示负数的不同方法,它们在底层编程中极其重要,特别是在涉及位操作时。C语言使用补码来表示负数,这是因为它可以简化硬件加减法操作。

原码

原码是最简单的表示方法,使用符号位来区分正负号。最高位为0表示正数,为1表示负数。例如:

  • +5的原码是:00000101
  • -5的原码是:10000101
反码

反码是对原码的符号位保持不变,其余位按位取反。正数的反码与原码相同,而负数的反码则是在正数基础上按位取反。例如:

  • +5的反码是:00000101
  • -5的反码是:11111010
补码

补码是计算机中最常用的表示负数的方法。负数的补码是反码加1。这样可以简化硬件中的加减法操作。例如:

  • +5的补码是:00000101
  • -5的补码是:11111011

代码示例:理解补码的表示

#include <stdio.h>int main() {signed char a = 5;   // 原码: 00000101signed char b = -5;  // 补码: 11111011printf("5 的二进制补码: %d\n", a);printf("-5 的二进制补码: %d\n", b);return 0;
}

在上面的例子中,计算机内部存储负数的方式是通过补码完成的,理解补码对于进行位操作和低级编程非常重要。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/881180.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++关于链表基础知识

单链表 // 结点的定义 template <class T> struct Node { T data ; Node <T> *next; //指向下一个node 的类型与本node相同 } // 最后一个node指针指向Null 生成结点&#xff1a; Node <T> * p new Node < T>; 为结点赋值: p-> data …

【微服务】服务注册与发现 - Eureka(day3)

CAP理论 P是分区容错性。简单来说&#xff0c;分区容错性表示分布式服务中一个节点挂掉了&#xff0c;并不影响其他节点对外提供服务。也就是一台服务器出错了&#xff0c;仍然可以对外进行响应&#xff0c;不会因为某一台服务器出错而导致所有的请求都无法响应。综上所述&…

LabVIEW机床加工监控系统

随着制造业的快速发展&#xff0c;机床加工的效率与稳定性成为企业核心竞争力的关键。传统的机床监控方式存在效率低、无法远程监控的问题。为了解决这些问题&#xff0c;开发了一种基于LabVIEW的机床加工监控系统&#xff0c;通过实时监控机床状态&#xff0c;改进生产流程&am…

PhotoMaker部署文档

一、介绍 PhotoMaker&#xff1a;一种高效的、个性化的文本转图像生成方法&#xff0c;能通过堆叠 ID 嵌入自定义逼真的人类照片。相当于把一张人的照片特征提取出来&#xff0c;然后可以生成你想要的不同风格照片&#xff0c;如写真等等。 主要特点&#xff1a; 在几秒钟内…

[C语言]指针和数组

目录 1.数组的地址 2.通过指针访问数组 3.数组和指针的不同点 4.指针数组 1.数组的地址 数组的地址是什么&#xff1f; 看下面一组代码 #include <stdio.h> int main() { int arr[5] {5,4,3,2,1}; printf("&arr[0] %p\n", &arr[0]); printf(&qu…

【c++】string类 (一)

简介 由于c的历史包袱&#xff0c;c要兼容c语言&#xff0c;c的字符串要兼容c语言&#xff0c;在 C 中&#xff0c;字符串通常使用两种主要的方式来表示&#xff1a; C风格字符串&#xff08;C-style strings&#xff09;&#xff1a; 依然是以 \0 结尾的字符数组。这种表示方…

设置服务器走本地代理

勾选&#xff1a; 然后&#xff1a; git clone https://github.com/rofl0r/proxychains-ng.git./configure --prefix/home/wangguisen/usr --sysconfdir/home/wangguisen/etcmakemake install# 在最后配置成本地代理地址 vim /home/wangguisen/etc/proxychains.confsocks4 17…

Web安全 - 文件上传漏洞(File Upload Vulnerability)

文章目录 OWASP 2023 TOP 10导图定义攻击场景1. 上传恶意脚本2. 目录遍历3. 覆盖现有文件4. 文件上传结合社会工程攻击 防御措施1. 文件类型验证2. 文件名限制3. 文件存储位置4. 文件权限设置5. 文件内容检测6. 访问控制7. 服务器配置 文件类型验证实现Hutool的FileTypeUtil使用…

计算机网络:计算机网络体系结构 —— OSI 模型 与 TCP/IP 模型

文章目录 计算机网络体系结构OSI 参考模型TCP/IP 参考模型分层的必要性物理层的主要问题数据链路层的主要问题网络层的主要问题运输层的主要问题应用层的主要问题 分层思想的处理方法发送请求路由器转发接受请求发送响应接收响应 计算机网络体系结构 计算机网络体系结构是指将…

简单部署vue+springboot项目

vue 参考博客 先将vue项目打包 npm run build 再创建项目文件夹front,在front中新建nginx.conf server {listen 80;server_name localhost;# 请求体的大小限制client_max_body_size 50m;# 日志文件存放地址access_log /var/log/nginx/host.access.log main;error…

openpnp - 图像传送方向要在高级校正之前设置好

文章目录 openpnp - 图像传送方向要在高级校正之前设置好笔记图像传送方向的确定END openpnp - 图像传送方向要在高级校正之前设置好 笔记 图像传送方向和JOG面板的移动控制和实际设备的顶部摄像头/底部摄像头要一致&#xff0c;这样才能和贴板子时的实际操作方向对应起来。 …

C++ | Leetcode C++题解之第456题132模式

题目&#xff1a; 题解&#xff1a; class Solution { public:bool find132pattern(vector<int>& nums) {int n nums.size();vector<int> candidate_i {nums[0]};vector<int> candidate_j {nums[0]};for (int k 1; k < n; k) {auto it_i upper_…

测试-BUG篇

文章目录 软件测试的生命周期BUGbug的概念描述bug的要素bug级别bug的生命周期 与开发产生争执怎么办&#xff08;高频考题&#xff09; 软件测试的生命周期 软件测试贯穿于软件的整个生命周期 BUG bug的概念 是指计算机程序中存在的一个错误(error)、缺陷(flaw)、疏忽(mista…

docker环境下配置cerbot获取免费ssl证书并自动续期

文章目录 实践场景了解certbot查看nginx的映射情况操作目标配置nginx配置的ssl证书设置自动续签 实践场景 本人使用docker部署了一个nginx容器&#xff0c;通过容器卷&#xff0c;实现本地html&#xff0c;ssl&#xff0c;conf和ngiinx容器映射的&#xff0c; 经常需要手动部署…

适合跑步的开放式耳机哪个品牌好?怎么选?可入的蓝牙耳机推荐

想必很多爱晨跑的朋友&#xff0c;一定都有过这般令人困扰的经历。耳机戴久了总觉得不舒适&#xff0c;或是尺寸不合&#xff0c;或是材质欠佳&#xff0c;反正无论怎样调整&#xff0c;都很难找到最舒适的佩戴方式。而且&#xff0c;有时候戴的时间久了&#xff0c;还很容易掉…

FLUX的ID保持项目也来了! 字节开源PuLID-FLUX-v0.9.0,开启一致性风格写真新纪元!

之前的文章已经和大家介绍过字节开源的ID保持项目PuLID。随着FLUX模型的发布&#xff0c;PuLID也开源了 FLUX 版本的模型&#xff0c;不得不说FLUX的强大&#xff0c;两个月生态就赶上了SDXL。这次新发布PuLID-FLUX-v0.9.0模型&#xff0c;它为FLUX.1-dev提供了无需调整的ID定制…

4S店4S店客户管理系统小程序(lw+演示+源码+运行)

社会的发展和科学技术的进步&#xff0c;互联网技术越来越受欢迎。手机也逐渐受到广大人民群众的喜爱&#xff0c;也逐渐进入了每个用户的使用。手机具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本低等优点。 因此&#xff0c;构建符合自己要求的操作系统是非…

VirtulBOX Ubuntu22安装dpdk23.11

目录 依赖包安装 Python安装 numa安装 ​编辑Python pip3安装 ​编辑pyelftools安装 meson和ninja安装 ​编辑构建与编译 Meson构建DPDK ​编辑Ninja安装DPDK ​编辑VFIO-PCI驱动安装 大页内存和IOMMU配置 ​编辑VFIO-PCI加载 ​编辑VFIO-PCI驱动绑定 ​编辑dpdk…

Linux网络操作命令与函数全面总结

1. 引言 Linux作为服务器和开发平台&#xff0c;网络操作是其核心功能之一。本文旨在全面总结Linux系统中的网络操作方法&#xff0c;包括命令行工具和编程接口&#xff0c;帮助读者深入理解Linux网络管理的机制。 2. 命令行工具 2.1 ping 命令 ping 命令用于测试网络连接和…

【Linux】信号知识三把斧——信号的产生、保存和处理

目录​​​​​​​ 1、关于信号的前置知识 1.1.什么是信号&#xff1f; 1.2.为什么要学习信号&#xff1f; 1.3.如何学习信号&#xff1f; 1.4.一些常见的信号 1.5.信号的处理方式 1.6.为什么每一个进程都可以系统调用&#xff1f; 2.信号的产生 2.1.kill命令产生信号…