【带头学C++】----- 1.基础知识 ---- 1.21.23.9 位运算符的综合应用

        最近做任务,公司项目比较重,赶上1024的活动流量券任务,内容治疗略微有一些杂乱,后期会把专栏目录重新搞一下,内容我是融合了很多课程和书籍包含ai的一些理解,我整理和增加了自己的见解和代码贴图,后续有需要代码的可以私聊我。免费赠送(专栏整理完了再发哈)

1.23.9 位运算符的综合应用

本章主要对上一篇文章作为补充,补充一下关于位运算符的一些综合应用。同时补充一下关于三目运算符、运算符的优先级、以及重要的自增、自减操作。

上图引用千锋教育C++基础班课程笔记 

1.23.10 三目运算符 ?:

表达式1?值1:值2
如果表达式1为真整个表达式的值为值1

如果表达式1为假 整个表达式的值为值2

例如:

    int age = 20;string result = (age >= 18) ? "成年人" : "未成年人";cout << "年龄:" << age << endl;cout << "身份:" << result << endl;

 其实相当于if-else,经常用于比较简单的比较条件,省去if-else的大块语句

 

注意特殊的:

test08里面我们可以看到data1的值是10,data2是原始是20,最后data2的值发生了改变。

实际上是因为在给 (data1>data2?data1:data2) 赋值时,根据条件 (data1>data2) 的判断结果,如果为真,则将 data1 的值赋给整个表达式,如果为假,则将 data2 的值赋给整个表达式。

在这个例子中,(data1>data2?data1:data2) 的值为 data2,因为 data1 的值并没有大于 data2。所以 data2 的值被赋为了 200

因此,最后的输出结果中,data1 的值保持为原来的 10,而 data2 的值被赋为了 200

 

1.23.11 运算符优先级

 1.图标展示运算符号的优先级

 

图示在C++primer一书中。 

 

 

 

1.23.12 自增自减

1.基础认识++(自增加1)和--(自减少1)符号

在C++中,递增运算符(++)和递减运算符(--)提供了一种便捷的方式来对对象进行加1和减1操作。

递增运算符有两种形式:前置版本和后置版本。前置递增运算符将运算对象加1,并返回修改后的对象本身作为求值结果。例如,++x 将会将变量 x 的值加1,并返回加1后的值。

后置递增运算符也将运算对象加1,但是返回的是运算对象改变之前的值的副本。例如,x++ 将会将变量 x 的值加1,但返回的是加1之前的值。

递减运算符的工作原理与递增运算符类似,只是将对象减1。

#include <iostream>
using namespace std;int main() {int x = 5;int y = 10;// 前置递增运算符++x; // x 增加1,现在 x 的值为 6cout << "x = " << x << endl;// 后置递增运算符y++; // y 增加1,但返回的是加1之前的值,现在 y 的值为 11cout << "y = " << y << endl;// 前置递减运算符--x; // x 减少1,现在 x 的值为 5cout << "x = " << x << endl;// 后置递减运算符y--; // y 减少1,但返回的是减少之前的值,现在 y 的值为 10cout << "y = " << y << endl;return 0;
}

2.在一条语句中混用解引用和递增运算符 

     如果我们想在一条复合表达式中既将变量加1或减1又能使用它原来的值,这时就可以使用递增和递减运算符的后置版本。

这里引用了C++primer5版本里面对改问题解释 

 

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

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

相关文章

React hooks优势

React Hooks 是 React 16.8 版本引入的一种特性&#xff0c;它提供了在函数式组件中使用状态和其他 React 特性的能力。下面将介绍 React Hooks 的优势&#xff1a; 简洁和可读性&#xff1a;相比于类组件&#xff0c;使用 Hooks 可以大幅简化函数式组件的编写方式&#xff0c;…

2023-10-25 精神分析-领悟新技术的错误做法-持续数年的错误做法-记录与分析

摘要: 过去数年对于领悟技术, 采取的做法不能说是对达到目的毫无裨益&#xff0c;但是对突破技术和将技术融为自身这个目的来说, 没有达到。 而且随着时间的流逝, 过去已经熟悉的技术, 竟然会被忘掉&#xff01;就像是没有涉猎过一样&#xff01; 根本原因出在对技术的领悟的…

newstar week3 pwn

newstar week3 pwn 巩固知识&#xff0c;如有错误记得纠正&#xff0c;感谢师傅们的评阅 puts or system? Arch: amd64-64-little RELRO: Partial RELRO Stack: Canary found NX: NX enabled PIE: No PIE (0x400000)int __cdecl main(int argc, const…

uni-app:解决异步请求返回值问题

可以使用 Promise 或者回调函数来处理异步请求的返回值。 方法一&#xff1a; Promise处理异步请求的返回值 使用 Promise 可以将异步请求的结果通过 resolve 和 reject 返回&#xff0c;然后通过 .then() 方法获取成功的结果&#xff0c;通过 .catch() 方法获取错误信息。 …

鸿鹄工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离构建工程项目管理系统项目背景

鸿鹄工程项目管理系统 Spring CloudSpring BootMybatisVueElementUI前后端分离构建工程项目管理系统 1. 项目背景 一、随着公司的快速发展&#xff0c;企业人员和经营规模不断壮大。为了提高工程管理效率、减轻劳动强度、提高信息处理速度和准确性&#xff0c;公司对内部工程管…

统计文本词频的几种方法(Python)

目录 1. 单句的词频统计 2. 文章的词频统计 方法一&#xff1a;运用集合去重方法 方法二&#xff1a;运用字典统计 方法三&#xff1a;使用计数器 词频统计是自然语言处理的基本任务&#xff0c;针对一段句子、一篇文章或一组文章&#xff0c;统计文章中每个单词出现的次数…

[Hive] 常见函数

文章目录 字符串函数数值函数随机函数日期和时间函数字符串转时间 聚合函数数组函数结构体函数数组函数映射函数 map正则处理JSON 字符串函数 CONCAT(string1, string2, …)&#xff1a;将多个字符串连接成一个字符串。 LENGTH(string)&#xff1a;返回字符串的长度。 LOWER…

40.查找练习题(王道2023数据结构第7章)

试题1&#xff08;王道7.2.4节综合练习5&#xff09;&#xff1a; 写出折半查找的递归算法。 #include<stdio.h> #include<stdlib.h> #include<string.h>#define MAXSIZE 10 #define ElemType int #define Status inttypedef struct{int data[MAXSIZE]; /…

10.25一些旧代码

仿真文件 实现每5个单位翻转一次进行样例测试 timescale 1ns / 1psmodule clock_tb();reg clk; wire clk_o;hz1 u(clk,clk_o);initial clk 1;always #(5) clk ~clk;endmoduletimescale 1ns / 1psmodule final_tb( ); reg clk;//开关&#xff0c;开时复位 reg reset; wire…

GD32_定时器输入捕获波形频率

GD32_定时器输入捕获波形频率&#xff08;多通道轮询&#xff09; 之前项目上用到一个使用定时器捕获输入采集风扇波形频率得到风扇转速的模块&#xff0c;作为笔记简单记录以下当时的逻辑结构和遇到的问题&#xff0c;有需要参考源码、有疑问或需要提供帮助的可以留言告知 。…

react使用 Ant ui框架

react使用 Ant ui框架 说明&#xff1a;Ant Design 是一个 ui框架&#xff0c;和 bootstrap 一样是ui框架。里面的组件很完善&#xff0c;开发中后台系统非常方便。分别基于react、vue、angular框架&#xff0c;各自开发了一套 Ant Design 的UI框架。&#xff08;这里主要讲re…

电大搜题:江苏开放大学学子的优秀助手

在如今信息爆炸的时代&#xff0c;获取准确、高质量的学习资源成为学生们的迫切需求。尤其对于江苏开放大学的学生来说&#xff0c;他们需要更具针对性、便捷的学习辅助工具&#xff0c;以帮助他们更好地应对学业压力。而幸运的是&#xff0c;有一款名为“电大搜题”的微信公众…

Spring Event

前言 ApplicationEvent 与 ApplicationListener 应用 实现 基于注解 事件过滤 异步事件监听 好处及应用场景 源码阅读 总结 1前言 ApplicationContext 中的事件处理是通过 ApplicationEvent 类和 ApplicationListener 接口提供的。如果将实现了 ApplicationListener …

【AI视野·今日Robot 机器人论文速览 第五十八期】Thu, 19 Oct 2023

AI视野今日CS.Robotics 机器人学论文速览 Thu, 19 Oct 2023 Totally 25 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Robotics Papers InViG: Benchmarking Interactive Visual Grounding with 500K Human-Robot Interactions Authors Hanbo Zhang, Jie Xu, Yuch…

Qt生成PDF报告

文章目录 一、示意图二、实现部分代码总结 一、示意图 二、实现部分代码 //! 生成测试报告 void MainWindow::createPdf(QString filename, _pdf_msg_& msg, const QMap<QString, int>& ok, const QMap<QString, int>& err) {//QDir dir;if(!dir.exis…

关于Nginx缓存

Nginx缓存 一般情况下系统用到的缓存有三种 服务端缓存&#xff1a; 缓存存在后端服务器&#xff0c;如redis代理缓存&#xff1a; 缓存存储在代理服务器或中间件&#xff0c;内容从后端服务器获取&#xff0c;保存在本地客户端缓存&#xff1a; 缓存在浏览器什么时候会出现3…

使用Python脚本来生成用于测试的文件

使用Python脚本生成指定数量的文件&#xff0c;每个文件约10MB&#xff0c;内容为重复的英文句子&#xff0c;单词间只有空格作为分隔符。 import os import sys import randomWORDS ["apple", "apricot", "avocado", "banana", &qu…

vue2、vue3中路由守卫变化

什么是路由守卫&#xff1f; 路由守卫就是路由跳转的一些验证&#xff0c;比如登录鉴权&#xff08;没有登录不能进入个人中心页&#xff09;等等等 路由守卫分为三大类&#xff1a; 全局守卫&#xff1a;前置守卫&#xff1a;beforeEach 后置钩子&#xff1a;afterEach 单个…

Vue快速入门

一、概述 1.是一套前端框架&#xff0c;可免除原生JavaScript中的DOM操作&#xff0c;基于MVVM思想&#xff0c;实现数据双向绑定。 实现由MVC——>MVVM的转换 二、入门 1.新建HTML页面&#xff0c;引入Vue.js文件 2.在JS代码区&#xff0c;创建Vue核心对象&#xff0c;进行…