当前位置: 首页 > news >正文

c++入门学习④——对象的初始化和清理

目录

对象的初始化和清理:

why?

如何进行初始化和清理呢?

使用构造函数和析构函数​编辑

构造函数语法:

析构函数语法:

构造函数的分类:

两种分类方式:

三种调用方法:

括号法(默认构造函数调用)

显示法

隐式转换法

拷贝调用函数的调用时机

1.使用一个已经常见完毕的对象来初始化一个新对象

2.值传递的方式给函数参数传值。

3.以值方式返回局部对象

构造函数调用时机:

深拷贝浅拷贝:

有可能的错误:

错误原因:

解决方案:

 深拷贝和浅拷贝案例:

 初始化列表

基本初始化列表案例:

灵活定义初始化的数字时的初始化列表案例:

类对象作为类成员

静态成员

静态成员变量:

 静态成员变量访问案例:

访问方式:

静态成员函数

静态成员函数创建调用基本示例

why?

结语:


本篇博客讲解c++入门学习④有关对象的初始化以及清理的知识点💪

传送门:

c++入门学习①-CSDN博客

c++入门学习②-CSDN博客

c++入门学习③——封装-CSDN博客

对象的初始化和清理:

why?

为了保证数据安全👉一个对象或者是变量没有初始化,则后面的后果是未知的,同样,没有清理也是可能会造成一系列的安全问题。

如何进行初始化和清理呢?

使用构造函数和析构函数
构造函数语法:

类名(){}
1.构造函数,没有返回值也不写void
2.函数名称与类名相同
3.构造函数可以有参数,因此可以发生重载
4.程序在调用对象时候会自动调用构造,无须手动调用,而且只会调用一次

自己不写,程序会自动帮你实现,不过函数里面的代码是空的,要是自己写,程序运行你自己写的构造函数

析构函数语法:

~类名(){}
1.析构函数,没有返回值也不写void
2.函数名称与类名相同,在名称前加上符号
3.析构函数不可以有参数,因此不可以发生重载
4.程序在对象销毁前会自动调用析构,无须手动调用,而且只会调用一次

自己不写,程序会自动帮你实现,不过函数里面的代码是空的,要是自己写,程序运行你自己写的析构函数

代码:

#include<iostream>
#include<string>
using namespace std;
class person{public://创造构造函数person() {cout << "构造函数" << endl;}~person() {cout << "析构函数调用" << endl;}
};
void test1() {person a;
}//局部变量,在栈区上创建,test执行完毕后,释放对象,会自动实现析构函数,不过是空的
//当自己创建了一个,那么就执行自己创建的析构函数int main()
{test1();system("pause");return 0;
}

构造函数的分类:

两种分类方式:

按照参数分类:有参数和无参数(默认情况下为无参)

按照类型分类:普通和拷贝

拷贝:copy、复制,

例如:person(const person &a){name=a.name;};把其他的属性拷贝到这个上面

拷贝方式创建,注意括号里写要copy的对象,并加上const,以引用的方式写入。

三种构造函数的具体表示:

#include<iostream>
#include<string>
using namespace std;
class person{public://创造构造函数person() {cout << "默认构造函数" << endl;}person(int age) {cout << "有参构造函数" << endl;Age = age;}person(const person& p) {cout << "拷贝构造函数" << endl;Age = p.Age;}~person() {cout << "析构函数调用" << endl;}int Age;
};

引用:c++引用-CSDN博客

三种调用方法:

括号法(默认构造函数调用)

person p1;调用无参构造函数,也是默认构造函数调用;

person p2(12);调用有参构造函数

person p3(p2);调用拷贝构造函数

注意事项:调用默认构造函数的时候不要加(),因为编译器会认为这个是一个函数声明,不会认为在创建对象

显示法

person p1;默认构造

person p2=person(12);有参构造

person p3=person(p2);拷贝构造

单独拿出来person(12),称为匿名对象,当前执行结束后,系统会立即回收掉匿名对象,马上析构掉

不单独看这个,匿名对象就有名字了,左边的就是它的名字

注意:不要利用拷贝构造函数初始化匿名对象。编译器会认为person(p3)==person p3;认为这是一个对象声明

隐式转换法

person p4=10;相当于写了person p4=person(10)有参构造

person p5=p4;拷贝构造

括号法最简单,这里推荐使用这个


拷贝调用函数的调用时机

1.使用一个已经常见完毕的对象来初始化一个新对象

#include<iostream>
using namespace std;
class person{public://创造构造函数person() {cout << "默认构造函数" << endl;}person(int age) {Age = age;cout << "有参构造函数" << endl;}person(const person & a) {Age = a.Age;cout << "拷贝构造函数" << endl;}~person() {cout << "析构函数调用" << endl;}int Age;
};
void test1() {person a;//局部变量,在栈区上创建,test执行完毕后,释放对象
}
//使用一个已经创建完毕的对象来初始化一个新的对象
void test2() {person p(20);//调用有参构造函数person p1(p);//调用拷贝构造函数
}int main()
{//test1();test2();system("pause");return 0;
}

输出结果: 

2.值传递的方式给函数参数传值。

#define  _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
using namespace std;
class person{public://创造构造函数person() {cout << "默认构造函数" << endl;}person(int age) {Age = age;cout << "有参构造函数" << endl;}person(const person & a) {Age = a.Age;cout << "拷贝构造函数" << endl;}~person() {cout << "析构函数调用" << endl;}int Age;
};
//值传递的方式给函数参数传值
void test(person p) 
{
}
void test3() {person p;//调用默认构造函数test(p);//调用拷贝构造函数,因为这里是以值传入,相当于拷贝一个副本传进去}int main()
{//test1();//test2();test3();return 0;
}

3.以值方式返回局部对象

示例:

#define  _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
using namespace std;
class person{public://创造构造函数person() {cout << "默认构造函数" << endl;}person(int age) {Age = age;cout << "有参构造函数" << endl;}person(const person & a) {Age = a.Age;cout << "拷贝构造函数" << endl;}~person() {cout << "析构函数调用" << endl;}int Age;
};//以值返回局部对象
person test0() {person p;//局部对象在完成函数之后会被自动释放掉,但是现在以值方式返回,则在返回的时候会自动给创建一个新的对象cout << "p地址" << (int*) & p << endl;return p;//返回的是p拷贝的一个新的对象
}
void test4() {person a=test0();//这里的函数a没有调用析构函数和构造函数cout << "a地址" << (int*)&a << endl;
}
int main()
{//test1();//test2();//test3();test4();system("pause");return 0;
}

构造函数调用时机:

默认情况添加的函数:

⭐注意:拷贝构造函数默认情况下只写值传递语句,不会出现输出语句

构造函数调用规则如下:
若用户定义有参构造函数,c++不再提供默认无参构造,但是会提供默认拷贝构造函数

当仅定义有参构造函数时不要进行默认无参构造,会发生错误显示没有默认无参构造函数。

若用户定义拷贝构造函数,c++不会再次提供其他构造函数

只定义拷贝构造函数时如果使用其他的构造函数,则会发生错误

深拷贝浅拷贝:

一般浅拷贝是逐个字节依次复制过去,而默认情况下系统创建拷贝构造函数是浅拷贝

有可能的错误:

一般使用不会出错,但是如果数据是程序员开发在堆区,就会发生释放重复的错误

错误原因:

因为浅拷贝使两个对象里的属性指向同一块空间,当释放一个对象中的属性之后,再去释放另一个也在堆区的数据,由于她们指向相同,所指向的空间已经被释放,但是系统不知道因此会发生错误

解决方案:

改进方法就是进行深拷贝,程序员自己创建一个函数来达到深拷贝的效果,深拷贝是在拷贝构造函数内进行自己再开辟一片空间,只复制要拷贝对象属性的内容而非空间地址。

 深拷贝和浅拷贝案例:

#include<iostream>using namespace std;
class person{public://创造构造函数person() {cout << "默认构造函数" << endl;}person(int age,int height) {Age = age;high = new int(height);cout << "有参构造函数" << endl;}person(const person & a) {Age = a.Age;cout << "person的拷贝构造函数" << endl;high=new int(*a.high);}~person() {//析构代码,将堆区开辟数据做释放操作if (high != NULL) {delete high;high = NULL;}//加上这个代码后运行,发现程序崩溃了?cout << "析构函数调用" << endl;}int Age;int* high;//身高,使用指针,把这个参数存放在堆区//堆区的数据,由程序员手动开辟,也由程序员手动释放,销毁前释放,在析构之前释放
};
void test1() {person p1(18,160);cout << "p1年龄:" << p1.Age<<"p1身高为:"<<*p1.high << endl;person p2(p1);//编译器创建了一个拷贝函数,进行了一个浅拷贝的操作,简单的赋值操作,逐字节拷贝cout << "p2年龄:" << p2.Age<< "p2身高为:" <<*p2.high << endl;//栈区先进后出,所以p2先被释放,p2先执行析构函数,p2释放过了指针所指的内存,则再次用p1释放时发生错误//解决:浅拷贝用深拷贝改进,不是逐个字节拷贝了,是重新开辟一个空间,两个空间就不会存在重复释放了//自己写拷贝构造函数
}
int main()
{test1();system("pause");return 0;
}

 初始化列表

简介:
初始化类中属性:1创建构造函数2.初始化列表
构造函数():属性1(值1),属性2(值2)

基本初始化列表案例:

#include<iostream>
using namespace std; //初始化列表//初始化类中属性:1创建构造函数2.初始化列表// 构造函数():属性1(值1),属性2(值2)
class person{public://初始化列表给类属性赋初值;person() :Age(10),b(20){}int Age;int b;
};
void test1() {person p1;cout << p1.Age <<"\t" << p1.b << endl;
}
int main()
{test1();system("pause");return 0;
}

灵活定义初始化的数字时的初始化列表案例:

#include<iostream>using namespace std; //初始化列表//初始化类中属性:1创建构造函数2.初始化列表// 构造函数():属性1(值1),属性2(值2)
class person{public://初始化列表给类属性赋初值;person(int a,int n) :Age(a),b(n)//注意这个冒号的位置,别写错了{}int Age;int b;
};
void test1() {person p1(12,22);//12先传给了p1中的int a,然后传入到Age里的a,这样Age就被这个数字赋值了,被初始化了。cout << p1.Age <<"\t" << p1.b << endl;
}
int main()
{test1();system("pause");return 0;
}

类对象作为类成员

类定义的对象称为另一个类里的成员,则称为类成员

构造顺序和析构顺序相反

构造时,先构造类成员的类,再构造类成员所在的类

而析构顺序则正相反。

#include<iostream>
#include<string>
using namespace std; 
//类对象成为另一个对象的成员,称为类成员
//先有的什么?👉先构造其他的类的对象,再构造这个类
//那么析构的顺序呢?和构造的顺序是相反的。
class A {
public:// 可以用Phone a_phone=pname👉隐式转换法来初始化变量A(string Name, string pname):name(Name),a_phone(pname){cout << "A的构造函数" << endl;}//姓名string name;//手机Phone a_phone;//类成员
};
//手机类
class Phone{
public:Phone(string pname) {//Phone  的构造函数Pname = pname;cout << "Phone的构造函数" << endl;}//手机品牌名string Pname;
};
void test1() {A p("黑菜钟","华为");cout << "名字:"<<p.name<< endl;cout <<"手机型号:"<< p.a_phone  << endl;}
int main()
{test1();system("pause");return 0;
}

静态成员

定义:静态成员就是在成员变量和成员函数前加上关键字static,称为静态成员

分为:静态成员变量和静态成员函数

静态成员变量要求:所有对象共享同一份数据,编译阶段分配内存,类内声明,类外初始化

静态成员函数要求:

静态成员变量:

静态成员变量示例:

当静态成员变量像平常一样定义类对象并且输出所对应的值的时候,程序会怎么样?

结果:发生错误,无法解析的外部命令👉这是因为静态成员变量要类外进行初始化操作,这个程序显然没做

如何在类外初始化呢?👉int person::m = 100;(这里的person是类名,m是类内静态变量)

 静态成员变量访问案例:

⭐静态成员变量不属于某个对象,所有对象共享同一份

访问方式:

1.通过对象访问
person p;
cout<<p.m_A<<endl;
2.通过类名访问
cout << person::m_A << endl;

#include<iostream>
#include<string>
using namespace std; 
//静态成员变量
//所有对象共享同一份数据
// 编译阶段分配内存
// 类内声明,类外初始化
class person {
public:static int m_A;};
int person::m_A = 10;
void test1() {person p;cout << p.m_A << endl;//10person p2;p2.m_A = 20;cout << p.m_A << endl;//结果为20,因为所有对象共享数据,一改全改//静态成员变量不属于某个对象,所有对象共享同一份
}
void test2() {//访问方式1.通过对象访问person p;cout<<p.m_A<<endl;//20//访问方式2.通过类名访问cout << person::m_A << endl;//用::来借助访问类对象
}int main()
{test1();test2();system("pause");return 0;
}

注意:静态成员变量只能在公共权限内定义,在私有权限内定义不出错,但是不能共享数据。类外访问不到私有静态变量。

静态成员函数

特点:所有对象共享同一个函数,静态成员函数只能访问静态成员变量

静态成员函数创建调用基本示例

#include<iostream>
#include<string>
using namespace std; 
//静态成员函数
//所有对象共享同一个函数
// 静态成员函数只能访问静态成员变量class person {
public:static void func() {cout << "static void func调用" << endl;}
};void test1() 
{//访问方式和静态成员变量的访问方式相同//1.通过对象person p;p.func();//2.通过类名person::func();
}int main()
{test1();system("pause");return 0;
}

如果静态成员函数访问非静态成员变量会出现👉这样的结果

why?

数据属于特定的,而函数体无法区分是哪个对象的,会出错

而静态成员变量是共享的,所有类的对象都用一份,函数体不需要知道这是哪个类对象对应的

⭐注意: 类外还是不可以访问私有的静态成员函数

结语:

希望这篇有关c++对象初始化和清理的博客对大家有所帮助,欢迎大佬们留言o(* ̄▽ ̄*)ブ

一起学习进步!!!

相关文章:

c++入门学习④——对象的初始化和清理

目录 对象的初始化和清理&#xff1a; why? 如何进行初始化和清理呢&#xff1f; 使用构造函数和析构函数​编辑 构造函数语法: 析构函数语法: 构造函数的分类&#xff1a; 两种分类方式&#xff1a; 三种调用方法&#xff1a; 括号法&#xff08;默认构造函数调用&…...

Java-spring注解的作用

1.Qualifier&#xff1a;通常与Autowired搭配使用&#xff0c;通过指定具体的beanName来注入相应的bean 当容器中有多个类型相同的Bean时&#xff0c;可以使用Qualifier注解来指定需要注入的Bean。Qualifier注解可以用于字段、方法参数、构造函数参数等位置 Service public cl…...

Allegro如何把Symbols,shapes,vias,Clines,Cline segs等多种元素一起移动

Allegro如何把Symbols,shapes,vias,Clines,Cline segs等多种元素一起移动 在用Allegro进行PCB设计时,有时候需要同时移动某个区域的所有元素,如:Symbols,shapes,vias,Clines,Cline segs等元素。那么如何操作呢? 首先就是把Symbols,shapes,vias,Clines,Cline …...

【力扣】罗马数字转整数,哈希集合+模拟

罗马数字转整数原题地址 方法一&#xff1a;模拟 罗马数字是字符串&#xff0c;其中每个字符都对应一个整数值&#xff0c;为了方便查找&#xff0c;可以预先把这种对应关系存储到哈希表中。 遍历字符串&#xff0c;对于每个字符&#xff0c; 如果该字符不是最右边的字符&a…...

从长网址到短链接:探索网址缩短的神奇世界

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 从长网址到短链接&#xff1a;探索网址缩短的神奇世界 前言网址缩短的原理和历史网址缩短的应用场景网址缩短的安全风险网址缩短的未来趋势 前言 你是否曾经在浏览网页或社交媒体时遇到过一串看起来像…...

Micro micro controller一览

https://www.microchip.com.cn/&#xff0c; Microchip中文网站 https://www.microchip.com.cn/newcommunity/index.php?mSearch&adosearch&moduleDownload&keyworddsPIC33&p3 Microcontrollers and microProcessors dsPIC33 Digital Signal Controllers (D…...

一文简介Maven初级使用

一.概述 Maven是专门用于管理和构建Java项目的工具&#xff0c;它的主要功能有&#xff1a; 提供了一套标准化的项目结构提供了一套标准化的项目构建流程&#xff08;编译&#xff0c;测试&#xff0c;打包&#xff0c;发布&#xff09;提供了一套依赖管理机制 一方面&…...

Django的配置文件setting.py

BASE_DIR 项目路径&#xff1a;默认是已经打开的主项目路径 ​​​​​​​BASE_DIR os.path.dirname(os.path.dirname(os.path.abspath(__file__))) SECRET_KEY 密钥 SECRET_KEY (dh&_fm2hfn9y)35!_6#$a7q%%^onoy#-a8x18r4(6*8f(aniDEBUG 帮助调试&#xff0c;默认…...

2024-02-06(Sqoop)

1.Sqoop Apache Sqoop是Hadoop生态体系和RDBMS&#xff08;关系型数据库&#xff09;体系之间传递数据的一种工具。 Sqoop工作机制是将导入或者导出命令翻译成MapReduce程序来实现。在翻译出的MapReduce中主要是对inputformat和outputformat进行定制。 Hadoop生态包括&#…...

C++ 11新特性之tuple

概述 在C编程语言的发展历程中&#xff0c;C 11标准引入了许多开创性的新特性&#xff0c;极大地提升了开发效率与代码质量。其中&#xff0c;tuple&#xff08;元组&#xff09;作为一种强大的容器类型&#xff0c;为处理多个不同类型的值提供了便捷的手段。tuple是一种固定大…...

Spring Boot项目整合Seata AT模式

目录 1、添加依赖2.、配置Seata3、创建AT模式表4、使用Seata分布式事务 1、添加依赖 <dependency><groupId>io.seata</groupId><artifactId>seata-spring-boot-starter</artifactId></dependency>上述依赖适用于springboot项目 如果你的项…...

作业2.5

第四章 堆与拷贝构造函数 一 、程序阅读题 1、给出下面程序输出结果。 #include <iostream.h> class example {int a; public: example(int b5){ab;} void print(){aa1;cout <<a<<"";} void print()const {cout<<a<<endl;} …...

LeetCode、790. 多米诺和托米诺平铺【中等,二维DP,可转一维】

文章目录 前言LeetCode、790. 多米诺和托米诺平铺【中等&#xff0c;二维DP&#xff0c;可转一维】题目与分类思路二维解法二维转一维 资料获取 前言 博主介绍&#xff1a;✌目前全网粉丝2W&#xff0c;csdn博客专家、Java领域优质创作者&#xff0c;博客之星、阿里云平台优质…...

Python 的 sys 模块常用方法

sys.argv&#xff1a; 命令行参数 List&#xff0c;第一个元素是程序本身路径 sys.modules.keys()&#xff1a; 返回所有已经导入的模块列表 sys.exc_info() &#xff1a;获取当前正在处理的异常类 exc_type、exc_value、exc_traceback 当前处理的异常详细信息 sys.exit(n)&…...

Kafka 使用手册

kafka3.0 文章目录 kafka3.01. 什么是kafka&#xff1f;2. kafka基础架构3. kafka集群搭建4. kafka命令行操作主题命令行【topic】生产者命令行【producer】消费者命令行【consumer】 5. kafka生产者生产者消息发送流程Producer 发送原理普通的异步发送带回调函数的异步发送同步…...

STM32F407移植OpenHarmony笔记7

继上一篇笔记&#xff0c;成功启动了liteos_m内核&#xff0c;可以创建线程了&#xff0c;也能看到shell控制台了。 今天研究文件系统&#xff0c;让控制台相关文件命令如mkdir和ls能工作。 liteos_m内核支持fatfs和littlefs两个文件系统&#xff0c; fatfs适用于SD卡&#xff…...

cortexM c语言和汇编嵌套编程

编程环境是&#xff1a;stm32cubeIde 原因&#xff1a;很多操作需要使用底层来做&#xff0c;比如中断时的上下文数据保存。也就是说用到汇编来实现。 疑问&#xff1a;c语言怎么才能跟汇编很好的兼容在一起呢&#xff1f;必将是我下一步的必经探索之路了。 一、C语言和汇编…...

国外传输大文件必选工具

企业在全球范围内的业务拓展带来了前所未有的机遇&#xff0c;同时也带来了跨国文件传输的挑战。大文件的高效、安全传输成为了企业亟需解决的问题。本文将深入探讨传统传输方式的局限性&#xff0c;云存储服务的便捷与挑战&#xff0c;以及专用文件传输软件的创新&#xff0c;…...

Redis渗透SSRF的利用

Redis是什么&#xff1f; Redis是NoSQL数据库之一&#xff0c;它使用ANSI C编写的开源、包含多种数据结构、支持网络、基于内存、可选持久性的键值对存储数据库。默认端口是&#xff1a;6379 工具安装 下载地址&#xff1a; http://download.redis.io/redis-stable.tar.gz然…...

【深度学习】基于PyTorch架构神经网络学习总结(基础概念基本网络搭建)

神经网络整体架构 类似于人体的神经元 神经网络工作原来为层次结构&#xff0c;一层一层的变换数据。如上述示例有4层&#xff0c;1层输入层、2层隐藏层、1层输出层神经元&#xff1a;数据的量或矩阵的大小&#xff0c;如上述示例中输入层中有三个神经元代表输入数据有3个特征…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

React19源码系列之 事件插件系统

事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...

python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...

Spring数据访问模块设计

前面我们已经完成了IoC和web模块的设计&#xff0c;聪明的码友立马就知道了&#xff0c;该到数据访问模块了&#xff0c;要不就这俩玩个6啊&#xff0c;查库势在必行&#xff0c;至此&#xff0c;它来了。 一、核心设计理念 1、痛点在哪 应用离不开数据&#xff08;数据库、No…...

Element Plus 表单(el-form)中关于正整数输入的校验规则

目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入&#xff08;联动&#xff09;2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...

在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?

uni-app 中 Web-view 与 Vue 页面的通讯机制详解 一、Web-view 简介 Web-view 是 uni-app 提供的一个重要组件&#xff0c;用于在原生应用中加载 HTML 页面&#xff1a; 支持加载本地 HTML 文件支持加载远程 HTML 页面实现 Web 与原生的双向通讯可用于嵌入第三方网页或 H5 应…...

C++ 设计模式 《小明的奶茶加料风波》

&#x1f468;‍&#x1f393; 模式名称&#xff1a;装饰器模式&#xff08;Decorator Pattern&#xff09; &#x1f466; 小明最近上线了校园奶茶配送功能&#xff0c;业务火爆&#xff0c;大家都在加料&#xff1a; 有的同学要加波霸 &#x1f7e4;&#xff0c;有的要加椰果…...

基于PHP的连锁酒店管理系统

有需要请加文章底部Q哦 可远程调试 基于PHP的连锁酒店管理系统 一 介绍 连锁酒店管理系统基于原生PHP开发&#xff0c;数据库mysql&#xff0c;前端bootstrap。系统角色分为用户和管理员。 技术栈 phpmysqlbootstrapphpstudyvscode 二 功能 用户 1 注册/登录/注销 2 个人中…...

给网站添加live2d看板娘

给网站添加live2d看板娘 参考文献&#xff1a; stevenjoezhang/live2d-widget: 把萌萌哒的看板娘抱回家 (ノ≧∇≦)ノ | Live2D widget for web platformEikanya/Live2d-model: Live2d model collectionzenghongtu/live2d-model-assets 前言 网站环境如下&#xff0c;文章也主…...