【C++学习手札】一文带你初识运算符重载

news2025/1/16 3:02:34

                                         食用指南:本文在有C基础的情况下食用更佳   

                                        🍀本文前置知识: C++类 

                                        ♈️今日夜电波:クリームソーダとシャンデリア—Edo_Ame江户糖

                                                                1:20 ━━━━━━️💟──────── 3:40
                                                                    🔄   ◀️   ⏸   ▶️    ☰ 

                                      💗关注👍点赞🙌收藏您的每一次鼓励都是对我莫大的支持😍 


目录

💓一、运算符重载基本概念

什么是运算符重载?

运算符重载简要干货

可重载的运算符有哪些? 

💗二、前置知识-友元函数 

 什么是友元函数?

 友元函数的语法

 💞三、运算符重载

运算符重载的语法

一步一步带你实现运算符重载(以<<为例)

运算符重载作为成员函数以及全局函数的实现(以+为例)

全局函数

成员函数

💕四、++和--运算符重载 (重要、常用)

💘具体实现用例 


一、运算符重载基本概念

什么是运算符重载?

        运算符重载, 就是对已有的运算符重新进行定义, 赋予其另一种功能, 以适应不同
的数据类型。
        运算符重载(operator overloading)只是一种”语法上的方便”,也就是它只是另一种函
数调用的方式。

        在 c++中, 可以定义一个处理类的新运算符。 这种定义很像一个普通的函数定义,只是函数的名字由关键字 operator 及其紧跟的运算符组成。 差别仅此而已。 它像任何其他函数一样也是一个函数, 当编译器遇到适当的模式时, 就会调用这个函数。

运算符重载简要干货

        运算符重载的目的:简化操作 让已有的运算符 适应适应不同的数据类型。
        语法:函数的名字由关键字operator及其紧跟的运算符组成
        比如:重载+运算符 ==>     operator+ 重载=号运算     ==>     operator=
        注意:重载运算符 不要更改 运算符的本质操作(+是数据的相加 不要重载成相减)

         栗子:(以下为重载了<<运算符的类)

class Data
{
	friend ostream& operator<<(ostream& out, Data& ob);//友元函数,经常与运算符重载搭配使用
private:
	int a;
	int b;
public:
	Data()
	{
		cout << "无参的构造函数" << endl;
		a = 0;
		b = 0;
	}
	Data(int a, int b) :a(a), b(b)
	{
		cout << "有参构造" << endl;
		//this‐>a = a;
			//this‐>b = b;
	}
	void showData(void)
	{
		cout << "a = " << a << ", b= " << b << endl;
	}
	~Data()
	{
		cout << "析构函数函数" << endl;
	}
};

ostream& operator<<(ostream& out, Data& ob)
 {
	 out << "a = " << ob.a << ", b = " << ob.b;
	 return out;
 }

        解释:

        为了简化类中访问私有数据较为困难的问题,运用友元函数(下小点会提到)同重载运算符的结合,得以运用我们较为常用的<<直接输出数据。

可重载的运算符有哪些? 

        几乎 C 中所有的运算符都可以重载, 但运算符重载的使用时相当受限制的。 特别是不能使用 C 中当前没有意义的运算符(例如用**求幂)不能改变运算符优先级, 不能改变运算符的参数个数。 这样的限制有意义, 否则, 所有这些行为产生的运算符只会混淆而不是澄清寓语意。

        一张图囊括~ 


二、前置知识-友元函数 

 什么是友元函数?

一句话概括:C++允许 友元 访问 私有数据。

 友元函数的语法

friend+定义的函数

      注意:  friend关键字只出现在声明处 其他类、类成员函数、全局函数都可声明为友元 友元函数不是类的成员,不带this指针 友元函数可访问对象任意成员属性,包括私有属性。

        栗子: (创建一个房间类,你只准许你的朋友进入你的卧室,但是客厅是谁都可以进的)

class Room
	 {
	 //将goodGayVisit作为类的友元函数
		 //goodGayVisit 访问 类中所有数据 但是 它不是类的成员
		 friend void goodGayVisit(Room & room);
 private:
	 string bedRoom;//卧室
 public:
	 string sittingRoom;//客厅
 public: 
	 Room()
	 {
	 this-> bedRoom = "卧室";
	 this-> sittingRoom = "客厅";
	 }
	};

 // 普通全局函数 作为 类的友元
 //好基友 访问 我的房间
 void goodGayVisit(Room & room)
 {
	 cout << "好基友访问了你的" << room.sittingRoom << endl;
	 cout << "好基友访问了你的" << room.bedRoom << endl;//ok
	 }
 void test01()
 {
	 Room myRoom;
	 goodGayVisit(myRoom);
}

        friend在这里可以访问对象任意成员属性,包括私有属性。因此,本来不能访问的私有数据,在friend的情况下就可以访问了!结果如下:

        此为普通全局函数 作为 类的友元 。当然,也有类的某个成员函数 作为 另一个类的友元;一个类整体 作为 另一个类的友元等等。

        而我们的友元函数大多应用在重载运算符上!

         本文仅仅对友元函数做简单介绍,如果大家需要详解,请在评论区或者私信踢我一脚o(╯□╰)o,作者肯定会出一篇的!


 三、运算符重载

运算符重载的语法

(根据自身改变的返回类型)operator + 重载的运算符(根据实际情况改变的传参)
  1. 函数声明:运算符重载是通过在类中定义特殊的成员函数来实现的。这些成员函数被称为运算符重载函数。例如,如果要重载"+"运算符,则需要在类中声明一个名为"operator+"的函数。

  2. 函数名:运算符重载函数的命名规则是以"operator"关键字开始,后面跟着要重载的运算符符号。例如,要重载"+“运算符,函数名应为"operator+”。

  3. 参数列表:运算符重载函数的参数列表取决于所重载的运算符。例如,对于二元运算符如"+", “-”, “*”, “/“等,参数列表应包含一个额外的参数,表示右操作数。对于一元运算符如”++”, "– – "等,参数列表不需要额外的参数。

  4. 返回类型:运算符重载函数的返回类型取决于所重载的运算符。例如,对于"+"运算符,返回类型通常是所操作对象的类型。

  5. 成员函数或友元函数:运算符重载函数可以作为类的成员函数或友元函数来定义。成员函数形式的运算符重载函数将使用对象本身作为左操作数,而友元函数形式的运算符重载函数将不使用任何对象。


一步一步带你实现运算符重载(以<<为例)

        注意:此代码未能实现重载 下文为对用cout来输出类的一个引入

#define _CRT_SECURE_NO_WARNINGS 01
#include <iostream>
#include<string.h>
 using namespace std;
 class Person
 {
 private:
	 char* name;
	 int num;
 public:
	 Person(char* name, int num)
		 {
		 this-> name = new char[strlen(name) + 1];
		 strcpy(this-> name, name);
		 this-> num = num;
		 cout << "有参构造" << endl;
		 }
	 //普通的成员函数
		 void printPerson(void)
		 {
		 cout << "name = " << name << ", num = " << num << endl;
		 }
	 ~Person()
		 {
		 if (this-> name != NULL)
			 {
			 delete[] this-> name;
			 this-> name = NULL;
			 }
		 cout << "析构函数" << endl;
		 }
	 };
 int main(int argc, char* argv[])
 {
	 char arr[] = "lucy";
	 Person ob1(arr, 18);
	 //普通的成员函数 遍历信息
	 //ob1.printPerson();
		
	 //cout默认输出方式 无法识别 自定义对象 输出格式
	cout<<ob1<<endl;//err
	return 0;
 }

        运行改代码,我们发现编译器报错!如下图:

         这个时候我们就需要对运算符进行重载了!

        那么问题又来了?如何重载运算符呢?根据上文所提到的语法,我们做出以下的操作:

        运用operator来重载<<运算符

 ostream& operator<<(ostream& out, Person& ob)//out=cout, ob =ob1
	  {
	  //重新实现 输出格式
		  out << ob.name << ", " << ob.num;
		  //每次执行为 返回值得到cout
		  return out;
	  }

        注意:ostream为cout的类型,定义ostream&为返回类型是为了作为起到链接的效果,如:

cout<<ob1<<ob2<<endl;ostream&返回out,然后再次被后面所调用,一直反复调用下去。

        然而,进行了运算符重载,就能实现我们想要的效果了吗?答案是不能,见下图:

         造成这样的原因是什么呢?还是类的封装问题,私有的数据不能被外界所访问!这时,我们就需要用到友元函数来帮助我们实现了!

         于是,我们将operator<<设置成友元:

#define _CRT_SECURE_NO_WARNINGS 01
#include <iostream>
#include<string.h>
 using namespace std;
 class Person
 {
	 //设置成友元函数 在函数内 访问Person类中的所有数据
	  friend ostream & operator<<(ostream & out, Person & ob);
 private:
	 char* name;
	 int num;
 public:
	 Person(char* name, int num)
		 {
		 this-> name = new char[strlen(name) + 1];
		 strcpy(this-> name, name);
		 this-> num = num;
		 cout << "有参构造" << endl;
		 }
	 //普通的成员函数
		 void printPerson(void)
		 {
		 cout << "name = " << name << ", num = " << num << endl;
		 }
	 ~Person()
		 {
		 if (this-> name != NULL)
			 {
			 delete[] this-> name;
			 this-> name = NULL;
			 }
		 cout << "析构函数" << endl;
		 }
	 };
 ostream& operator<<(ostream& out, Person& ob)//out=cout, ob =ob1
	  {
	  //重新实现 输出格式
		  out << ob.name << ", " << ob.num;
		  //每次执行为 返回值得到cout
		  return out;
	  }
 int main(int argc, char* argv[])
 {
	 char arr[] = "lucy";
	 Person ob1(arr, 18);
	 //普通的成员函数 遍历信息
	 //ob1.printPerson();
		
	 //cout默认输出方式 无法识别 自定义对象 输出格式
	cout<<ob1<<endl;//err
	return 0;
 }

        实现效果如下:


运算符重载作为成员函数以及全局函数的实现(以+为例)

全局函数

        这里同上面的栗子大致一样,不过多叙述

#include <iostream>
 #include<string.h>
 using namespace std;
 class Person
 {
	 //设置成友元函数 在函数内 访问Person类中的所有数据
	 friend ostream & operator<<(ostream & out, Person & ob);
	 friend Person operator+(Person & ob1, Person & ob2);
 private:
	 char* name;
	 int num;
 public:
	 Person(){
		 this-> name = NULL;
		 this-> num = 0;
		 cout << "无参构造" << endl;
		 }
	 Person(char* name, int num)
		 {
		 this-> name = new char[strlen(name) + 1];
		 strcpy(this-> name, name);
		 this-> num = num;
		 cout << "有参构造" << endl;
		 }
	 //普通的成员函数
		 void printPerson(void)
		 {
		 cout << "name = " << name << ", num = " << num << endl;
		 }
	 ~Person()
		 {
		 if (this-> name != NULL)
			 {
			 delete[] this-> name;
			 this-> name = NULL;
			 }
		 cout << "析构函数" << endl;
		 }
	 };

 //全局函数作为友元 完成运算符重载<<
 ostream & operator<<(ostream & out, Person & ob)//out=cout, ob =ob1
 {
	 //重新实现 输出格式
		 out << ob.name << ", " << ob.num;
	
		 //每次执行为 返回值得到cout
		 return out;
	 }
 //全局函数作为友元 完成运算符重载+
 Person operator+(Person & ob1, Person & ob2)//ob1 ob2
 { //name+name(字符串追加)
 char* tmp_name = new char[strlen(ob1.name) + strlen(ob2.name) + 1];
 strcpy(tmp_name, ob1.name);
 strcat(tmp_name, ob2.name);

 //num+num(数值相加)
 int tmp_num = ob1.num + ob2.num;
 Person tmp(tmp_name, tmp_num);

 //释放tmp_name的空间
 if (tmp_name != NULL)
 {
	 delete[] tmp_name;
	 tmp_name = NULL;
	 }

 return tmp;
 }


 void test02()
 {
	 char arr[] = "lucy";
	 Person ob1(arr, 18);  
	 char arr2[] = "bob";
	 Person ob2(arr2, 19);
	
		 cout << ob1 << endl;
		cout << ob2 << endl;
	 //Person ob3 = operator+(ob1,ob2);
		 Person ob3 = ob1 + ob2;
	 cout << ob3 << endl;
	 }
 int main(int argc, char* argv[])
 {
	 test02();
	 return 0;
 }

成员函数

#include <iostream>
 #include<string.h>
 using namespace std;
 class Person
 { //设置成友元函数 在函数内 访问Person类中的所有数据
 friend ostream & operator<<(ostream & out, Person & ob);
 private:
	 char* name;
	 int num;
 public:
	 Person()
		 {
		 this-> name = NULL;
		 this-> num = 0;
		 cout << "无参构造" << endl;
		 }
	 Person(char* name, int num)
		 {
		 this-> name = new char[strlen(name) + 1];
		 strcpy(this-> name, name);
		 this-> num = num;
		 cout << "有参构造" << endl;
		 }
	 //成员函数 完成运算符重载 ob1用this代替 ob2用参数ob代替
		 Person operator+(Person & ob)
		 {
		 //this ==> &ob1
			
			 //name+name(字符串追加)
		 char* tmp_name = new char[strlen(this-> name) + strlen(ob.name) + 1];
		 strcpy(tmp_name, this-> name);
		 strcat(tmp_name, ob.name);
		
			 //num+num(数值相加)
		 int tmp_num = this-> num + ob.num;
		 Person tmp(tmp_name, tmp_num);
		
			 //释放tmp_name的空间
			 if (tmp_name != NULL)
			 {
			 delete[] tmp_name;
			 tmp_name = NULL;
			 }
		 return tmp;
		 }
	
		 //普通的成员函数
		 void printPerson(void)
		 {
		 cout << "name = " << name << ", num = " << num << endl;
		 }
	 ~Person()
		 {
		 if (this-> name != NULL)
			 {
			 delete[] this-> name;
			 this-> name = NULL;
			 }
		 cout << "析构函数" << endl;
		 }
	 };

 //全局函数作为友元 完成运算符重载<<
 ostream & operator<<(ostream & out, Person & ob)//out=cout, ob =ob1
 {
	 //重新实现 输出格式
		 out << ob.name << ", " << ob.num;
	
		 //每次执行为 返回值得到cout
		 return out;
	 }

 void test03()
 {
	 char arr[] = "lucy";
	 char arr2[] = "bob";
	 Person ob1(arr, 18);
	 Person ob2(arr2, 19);
	
		 //Person ob3 = ob1.operator+(ob2);
		 Person ob3 = ob1 + ob2;
	 cout << ob3 << endl;
	 }

 int main(int argc, char* argv[])
 { test03();

 return 0;
 }

        在运算符重载运算符时,如果我们以成员函数的方式定义,则可以直接访问类中的数据,无需再使用友元函数来定义。因此我们在重载运算符时最好是以成员函数的方式重载!


四、++和--运算符重载 (重要、常用)

        不知道大家有没有一个疑惑如果我们实现前置+ +、后置+ +以及前置- -、后置--,运用operator时如何区分他们呢?

        此时,我们又要提到一个概念,当编译器看到++a(前置++),它就调用operator++(a),当编译器看到a++(后置++),它就会去调用operator++(a,int)。 - -也是同样的道理,具体实现如下:

具体实现用例 

#include <iostream>

using namespace std;
 class Data
 {
	 friend ostream & operator<<(ostream & out, Data & ob);
 private:
	 int a;
	 int b;
 public:
	Data()
		 {
		 cout << "无参的构造函数" << endl;
		 a = 0;
		 b = 0;
		 }
	 Data(int a, int b) :a(a), b(b)
		 {
		 cout << "有参构造" << endl;
		 //this‐>a = a;
			 //this‐>b = b;
			 }
	 void showData(void)
		 {
		 cout << "a = " << a << ", b= " << b << endl;
		 }
	 ~Data()
		 {
		 cout << "析构函数函数" << endl;
		 }
	
		 //成员函数 重载前置++ ++ob1 (先加 后使用)
		 //编译器 默认识别 operator++(a) //但是a可以用this代替 从而化简 operator++()
		 Data & operator++()//++ob1
		 { //先加
		 a++;//this‐>a = this‐>a +1
	 b++;//this‐>b = this‐>b +1
	 //后使用
		 return *this;
	 }
	 //成员函数 重载后置++ ob1++ (先使用 后加)
		 //编译器 默认识别 operator++(a,int) //但是a可以用this代替 从而化简 operator ++(int)
		 Data & operator++(int)//ob1++
		 {
		 //先使用(备份加之前的值)
			 static Data old = *this;
		
			 //后加
			a++;
			b++;
		
			 //返回备份值
			 return old;
		 }
	
		 //重载前置‐‐ ‐‐ob3
		 //编译器 默认识别 operator++(a) //但是a可以用this代替 从而化简 operator‐‐()
		 Data & operator--()
		 {
		 //先减
			a--;
			b--;
		
			 //后使用(返回)
			 return *this;
		 }
	
		 //重载后‐‐ ob4‐‐
		 //编译器 默认识别 operator++(a,int) //但是a可以用this代替 从而化简 operator++(int)
		 Data & operator--(int)
		 {
		 //先使用
			 static Data old = *this;
			 //再减
			a--;
			b--;
		
			 return old;
		 }
	
		
		 };
 //普通全局函数 作为类的友元 重载<<运算符
 ostream & operator<<(ostream & out, Data & ob)
 {
	 out << "a = " << ob.a << ", b = " << ob.b;
	 return out;
	 }
 void test01()
 {
	 Data ob1(10, 20);
	 ob1.showData();
	
		 //重载<<直接输出自定义对象的值
		 //operator<<(cout,ob1);
		 cout << ob1 << endl;
	
		 //成员函数 重载 ++运算符
		 cout << ++ob1 << endl;
	
		 Data ob2(10, 20);
	 cout << ob2++ << endl;
	 cout << ob2 << endl;
	
		 //成员函数 重载 ‐‐运算符
		 Data ob3(10, 20);
	 cout << "ob3 " << ob3 << endl;
	 cout << --ob3 << endl;
	
		 Data ob4(10, 20);
	 cout << "ob4 " << ob4 << endl;
	 cout << ob4-- << endl;
	 cout << "ob4 " << ob4 << endl; 
		
		 }
 int main(int argc, char* argv[])
 {
	 test01();
	 return 0;
 }

        效果如下: 


                感谢你耐心的看到这里ღ( ´・ᴗ・` )比心,如有哪里有错误请踢一脚作者o(╥﹏╥)o!  

                                 

                                                                 给个三连再走嘛~      

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

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

相关文章

基于Python的HTTP代理爬虫开发初探

前言 随着互联网的发展&#xff0c;爬虫技术已经成为了信息采集、数据分析的重要手段。然而在进行爬虫开发的过程中&#xff0c;由于个人或机构的目的不同&#xff0c;也会面临一些访问限制或者防护措施。这时候&#xff0c;使用HTTP代理爬虫可以有效地解决这些问题&#xff0…

C4D那些超酷的插件,你知道几个?

Cinema 4D 是最著名的 3D 软件之一&#xff0c;由于其便利性和多功能性&#xff0c;艺术家和工作室经常在许多领域使用。尽管它被认为是一款一体化软件&#xff0c;但您仍然可以找到许多很酷的工具或插件&#xff0c;帮助您获得更好的结果并节省时间和金钱。 赞奇云工作站带领…

解放双手!写了个小工具给喜欢的博主一键三连

1. 写在前面 大家写博客的可能都知道&#xff0c;有时候我们或多或少会认识一些志同道合的博主。大家在写博客的时候偶尔也都会彼此之间相互支持一下 再如果看到自己感兴趣的文章&#xff0c;想收藏一下。这些需求我们目前大部分人都自己用手去操作&#xff0c;这是非常费力的…

恒运资本:布林线什么意思?

布林线是一种经过股票价格的标准差核算出涨跌起伏的技能剖析方法。这种剖析方法由约翰布林在1980年左右开发而来&#xff0c;是一种常用的股市剖析东西。本文将从前史、原理、应用等多个视点叙述布林线的含义&#xff0c;以及它对出资者所带来的意义。 一、前史 布林线在1983年…

解决方案:如何在 Amazon EMR Serverless 上执行纯 SQL 文件?

长久已来&#xff0c;SQL以其简单易用、开发效率高等优势一直是ETL的首选编程语言&#xff0c;在构建数据仓库和数据湖的过程中发挥着不可替代的作用。Hive和Spark SQL也正是立足于这一点&#xff0c;才在今天的大数据生态中牢牢占据着主力位置。在常规的Spark环境中&#xff0…

目前互联网企业知识库使用情况?企业知识库搭建缺陷有什么?

目前互联网企业普遍使用知识库作为内部和外部知识管理的工具。知识库通过集中存储和组织企业内部的知识和信息&#xff0c;使其易于访问和共享 目前互联网企业知识库使用情况&#xff1a; 内部知识管理&#xff1a; 知识库用于内部员工的知识共享和知识管理。企业可以将各个…

5款专业思维导图软件推荐:提升效率,促进协作!

思维导图作为一种有效的信息组织和可视化工具&#xff0c;已经广泛地应用于学习、工作和生活中。通过思维导图&#xff0c;我们能够以高效的方式把握和处理大量信息。 但到了挑选软件的环节&#xff0c;市面上层出不穷的思维导图软件&#xff0c;容易让人看花眼&#xff0c;不知…

matlab使用教程(17)—广度优先和深度优先搜索

1.可视化广度优先搜索和深度优先搜索 此示例说明如何定义这样的函数&#xff1a;该函数通过突出显示图的节点和边来显示 bfsearch 和 dfsearch 的可视化结果。 创建并绘制一个有向图。 s [1 2 3 3 3 3 4 5 6 7 8 9 9 9 10]; t [7 6 1 5 6 8 2 4 4 3 7 1 6 8 2]; G dig…

【Bug解决】1、Nacos启动成功,但却无法访问(提示:无法访问此网站,192.168.10.133的响应时间过长)

项目场景&#xff1a; 在虚拟机上通过Docker创建Nacos容器&#xff0c;已经创建成功&#xff0c;查看Nacos启动日志也是成功。但通过端口号加8848/nacos&#xff08;如&#xff1a;http://192.168.88.10:8848/nacos&#xff09;无法访问到Nacos管理页面。 问题描述 原因分析&a…

DC电源模块生产用料扎实的表现

BOSHIDA DC电源模块生产用料扎实的表现 随着现代科技的不断发展&#xff0c;DC电源模块已经被广泛应用于各种电子设备中。不同于其它电子元器件&#xff0c;DC电源模块生产所需用料的扎实程度对其性能的影响非常大。下面&#xff0c;本文将就DC电源模块生产用料扎实的表现进行…

互联网 vs IC 谁更有前景?

1、行业发展趋势 互联网行业 去年&#xff0c;阿里、腾讯裁员的消息双双冲上热搜&#xff0c;引发网友讨论。有消息称腾阿里、腾讯预计裁员 10%&#xff5e;30%&#xff0c;阿里多个业务线已确认裁员名单。 中国互联网的黄金时期已经过了&#xff0c;这个信号越来越明显。最…

卷积神经网络全解:(AlexNet/VGG/ GoogleNet/LeNet/卷积/激活/池化/全连接)

CNN&#xff0c;卷积神经网络&#xff0c;Convolution Neural Network 卷积计算公式&#xff1a; N &#xff08;W-F2p&#xff09;/s1 1 经典网络 按照时间顺序 1.1 LeNet LeNet是 Yann LeCun在1998年提出&#xff0c;用于解决手写数字识别的视觉任务。自那时起&#x…

八大排序超详解(动图+源码)

&#x1f493;博主个人主页:不是笨小孩&#x1f440; ⏩专栏分类:数据结构与算法&#x1f440; 刷题专栏&#x1f440; C语言&#x1f440; &#x1f69a;代码仓库:笨小孩的代码库&#x1f440; ⏩社区&#xff1a;不是笨小孩&#x1f440; &#x1f339;欢迎大家三连关注&…

高效提升工作效率,亚马逊云科技热门课程带你入门生成式AI

当前人工智能仍处于飞速发展阶段&#xff0c;作为当下最先进的科学技术之一&#xff0c;相信大家对AIGC关注已久。今天&#xff0c;引用亚马逊云科技最新发布的七项生成式AI新功能来跟大家聊聊近期的热门生成式AI&#xff01; 有人说&#xff0c;生成式AI将带来充满创造性的新世…

AMEYA360:村田共模扼流线圈,针对车载应用的高频噪声

近年来&#xff0c;随着ADAS(高级驾驶辅助系统)精度的提高&#xff0c;汽车行业开始安装大量毫米波雷达、LiDAR等高速传感设备。如果噪声从外部进入这些设备&#xff0c;系统可能无法正常工作。相反&#xff0c;如果这些设备产生噪声&#xff0c;则可能会对其他设备产生不利影响…

mysql 02 数据库的约束

为防止错误的数据被插入到数据表&#xff0c;MySQL中定义了一些维护数据库完整性的规则&#xff1b;这些规则常称为表的约束。常见约束如下&#xff1a; 主键约束 主键约束即primary key用于唯一的标识表中的每一行。被标识为主键的数据在表中是唯一的且其值不能为空。这点类似…

ICT产教融合创新实训基地软件测试实训室建设方案

一 、系统概述 ICT产教融合创新&#xff0c;简单来说&#xff0c;就是信息与通信技术&#xff08;ICT&#xff09;与产业界、教育界的融合创新。这个概念强调了在现代社会中&#xff0c;信息技术与产业发展以及教育培训之间相互关联的重要性。 ICT产教融合创新的核心思想包括以…

【正点原子STM32连载】第十章 跑马灯实验 摘自【正点原子】APM32F407最小系统板使用指南

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html# 第十…

数字孪生技术对环境保护有哪些作用?

数字孪生技术在环境保护中的作用不容忽视&#xff0c;为我们创造了全新的可能性和解决方案。在追求可持续发展的今天&#xff0c;数字孪生以其独特的能力&#xff0c;正逐渐改变着环境保护的方式。 数字孪生技术首先在环境监测方面发挥了巨大作用。通过传感器和数据采集设备&a…

JVM整体回忆笔记

模块三 内存的分配 指针碰撞 空闲列表 分配内存的时候出现并发问题&#xff0c;几个线程同时抢同一块内存区域 CAS方法解决 本地线程分配缓冲&#xff08;-XX&#xff1a;UseTLAB&#xff09;,jvm默认开启 对象的组成 对象头、实例数据、对齐填充&#xff08;保证对象8个字节…