今天你学C++了吗?——C++中的类与对象(日期类的实现)——实践与知识的碰撞❤


♥♥♥~~~~~~欢迎光临知星小度博客空间~~~~~~♥♥♥

♥♥♥零星地变得优秀~也能拼凑出星河~♥♥♥

♥♥♥我们一起努力成为更好的自己~♥♥♥

♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥

♥♥♥如果有什么问题可以评论区留言或者私信我哦~♥♥♥

✨✨✨✨✨✨ 个人主页✨✨✨✨✨✨

❤C++专栏中比较重要的类与对象知识现在已经更新完毕❤欢迎大家随时访问哦❤

类与对象——第一集

类与对象——第二集

类与对象——第三集

类与对象——第四集
类与对象——最后一集(日期类的实现)

在前面的博客内容中,我们已经学习了C++中类与对象的大部分知识,这一篇博客我们将会利用前面学习到的知识,来实现一个日期类~用实践检验我们学习的成果~准备好了吗~我们发车啦~🚗🚗🚗🚗🚗🚗

目录

实现一个怎么样的日期类?

定义一个日期类

构造函数

拷贝构造函数

打印日期

使用成员函数

流插入运算符重载

流提取运算符重载

赋值运算符重载

判断日期大小关系

等于

不等于

大于

大于等于

小于

小于等于

日期+=天数

日期+天数

日期-=天数

日期-天数

前置++

后置++

前置--

后置--

日期-日期

总代码

Date.h

Date.cpp


实现一个怎么样的日期类?

我们生活中经常会使用到日期,比如日期加天数,日期-日期,倒计时等等,这里我们要实现的日期类就是来实现这样一些具有实际意义的日期处理~像日期加日期这种是没有实际意义的,我们这里也就不会进行实现~

这里我们创建三个文件~

Date.h  

定义日期类结构,对要提供的操作进行声明

Date.cpp

具体实现各种操作

test.cpp

进行各种操作的测试

定义一个日期类

我们这里实现的日期类是包含年、月、日的,所以我们给到的成员变量就有年、月、日,同时使用private访问限定符进行修饰,不希望只希望在这一个类里面访问成员变量~

#include<iostream>
using namespace std;
//定义日期类
class Date
{
private://成员变量 年、月、日int _year;int _month;int _day;//前面加一个下划线便于区分
public://成员函数};//不要忘记末尾的分号

其他文件就可以包含我们自己写的头文件

注意这里是我们自己写的头文件,所以包含头文件的时候应该是双引号" ",而不是尖括号<>

构造函数

我们不希望使用编译器生成的构造函数让日期是随机值,所以我们这里需要自己写构造函数~

同时在构造的同时,我们也可以检查日期是否合法~

//检查日期是否合法~
bool Date::CheckDate()const
{if (_month > 12 || _month < 1 || _day <= 0 || _day > GetMonthDay(_year,_month)){return false;}return true;
}
//Date::Date(int year = 0,int month = 0,int day = 0)//err
Date::Date(int year,int month,int day)//声明和定义不可以同时给缺省参数
//在声明里面给缺省参数
{_year = year;_month = month;_day = day;//检查日期是否合法if (!CheckDate()){cout << "日期非法!" << *this << endl;}
}

拷贝构造函数

拷贝构造函数可以用一个已经初始化的对象来初始化新创建的对象,事实上,这里没有涉及到资源管理,我们可以不显示写拷贝构造函数,直接使用编译器自动生成的拷贝构造函数也是没有问题的~

显示写拷贝构造函数

//拷贝构造函数——可以用来初始化新创建的对象
Date::Date(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;
}

补充:自定义类型传值传参传值返回会产生临时对象,所以它们都会调用拷贝构造函数~

(C++规定自定义类型对象进行拷贝的行为必须调用拷贝构造

打印日期

接下来我们先来一个简单的,也是我们以前练习过的打印日期~

我们给出两种方法,一个是成员函数,一个是流插入运算符重载~

使用成员函数

使用成员函数的好处是,每一个成员函数参数都隐含一个this指针,这样我们就可以直接获得当前对象年月日进行打印~

void Date::Print()const
//const 修饰this指针指向的内容,我们不希望内容被修改
{cout << _year << "年" << _month << "月" << _day << "日" << endl;
}

流插入运算符重载

<< 流插入运算符有两个操作数,在这里一个是ostream类型,一个是Date类型,如果把它设计成成员函数,那么隐含的this指针在第一个参数,就不符合我们平常使用的习惯~所以我们可以把它设计为全局函数~

但是全局函数又不可以访问类的私有成员了,前面我们提到过三种解决方案~~

1.使用友元函数

2.提供get成员函数,获取年月日

3.将年月日成员变量改为公有

这里我们使用友元函数来达到目的~


在类里面加上friend关键字说明这个函数是这个类的友元函数,可以访问私有成员~


类外面对这个友元函数进行声明,这个时候就不需要再加friend关键字了


在Date.cpp文件里面进行函数的定义~

ostream& operator <<(ostream& ou, const Date& d)
{ou << d._year << "年" << d._month << "月" << d._day << "日" << endl;return ou;//有返回值实现连续输出
}

注意:这个重载函数返回值实现我们进行连续输出的操作~同时这里返回值只能使用引用返回~输出流我们是不可以改变的~

流提取运算符重载

知道了流插入运算符重载,流提取运算符重载就十分容易了~


在类里面加上friend关键字说明这个函数是这个类的友元函数,可以访问私有成员~这里与流插入运算符重载不相同的是d不能加const修饰,因为我们本身输入是修改了内容的~


类外面对这个友元函数进行声明,这个时候就不需要再加friend关键字了

在Date.cpp文件里面进行函数的定义~这里还可以增加一个小细节就是检查日期是否合法~


istream& operator>>(istream& in, Date& d)
{while (1){in >> d._year >> d._month >> d._day;//检查日期是否合法if (d.CheckDate()){break;}else{cout << "日期非法,请重新输入!" << endl;}}return in;
}

赋值运算符重载

对于自定义类型,使用赋值运算符重载可以让我们完成两个已经初始化对象的拷贝~

注意与拷贝构造函数进行区分,拷贝构造函数用一个已经初始化的对象来初始化一个新创建的对象~

赋值运算符重载同样有返回值,这样就可以实现连续赋值~

//  d1  =  d2
//* this   d
//这里需要修改*this
Date& Date::operator=(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;return *this;//有返回值,实现连续赋值
}

判断日期大小关系

等于

等于这个很好判断,只需要年月日都是相等的,那么这两个日期就是相等的~

bool Date::operator==(const Date& d)const
{//年月日相等就相等return (_year == d._year)&& (_month == d._month)&& (_day == d._day);
}

不等于

这里有两个方法

一个是直接写,只要年月日有一个不相同,那么这两个日期就不相等~

一个是进行代码复用(更加推荐这个方式,减少代码量)这里日期不相等就是相等的否

bool Date::operator!=(const Date& d)const
{//1.直接写/*return (_year != d._year)|| (_month != _month)|| (_day != d._day);*///2.代码复用return !(*this == d);
}

大于

判断思路:先判断年,年大就大;年相等判断月,月大就大;月相等就判断日,日大就大

bool Date::operator>(const Date& d)const
{if (_year > d._year){return true;}//年相等判断月if (_year == d._year){if (_month > d._month){return true;}//月相等判断天else if(_month == d._month){if (_day > d._day){return true;}}}return false;
}

大于等于

这里使用代码复用就大大减少我们的代码量了~事实上,前面实现了判断大于和等于,接下来的代码判断都可以使用代码复用~

bool Date::operator>=(const Date& d)const
{//代码复用return (*this == d) || (*this > d);
}

小于

bool Date::operator<(const Date& d)const
{代码复用return !((*this == d) || (*this > d));
}

小于等于

bool Date::operator<=(const Date& d)const
{//代码复用return (*this < d) || (*this == d);
}

日期+=天数

思路:加的天数先加在日上面得到总天数,判断总天数是否大于当前月份天数,比当前月份天数大就用总天数减去当前月份天数,月加加,再判断是否大于当前月份天数,如此循环~

这里我们就需要提供一个获取日期天数的方法,这里我们直接把这个函数定义在类里面,这个函数就成为了内联函数可以直接在调用的地方进行展开~

获取月份天数:

//获取月份天数
// 直接定义在类里面成为inline函数
int GetMonthDay(int y, int m)const
{static int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31, 30,31 };//                 0  1  2  3  4  5  6  7  8  9 10   11 12if (m == 2 && ((y % 400 == 0) || (y % 4 == 0 && y % 100 != 0)))//闰年的二月29天{return 29;}return arr[m];
}

日期+=天数:

//使用引用返回,减少拷贝次数
Date& Date::operator+=(int day)
{//特殊处理,day<0,调用日期-=天数if (day < 0)//调用日期减天数{*this -= (-day);}else{_day += day;while (_day > GetMonthDay(_year, _month)){_day -= GetMonthDay(_year, _month);_month++;//特殊处理:到下一年if (_month == 13){_year++;_month = 1;}}}return *this;
}

日期+天数

思路:这里日期加天数,本身是没有变化的,我们可以创建一个临时对象进行+=天数,返回临时对象~

这里临时对象不可以使用引用返回,因为出了这个作用域临时对象就会销毁,我们需要传值返回,调用拷贝构造~

这里返回不可以使用引用,局部对象出了作用域就销毁了,原来的对象存储的数据随机了
//返回对象会产生一个临时对象,调用拷贝构造
Date Date::operator+(int day)
{//创建一个临时对象Date tmp(*this);//特殊处理,day < 0if (day < 0){tmp -= (-day);}else{//代码复用tmp += day;}return tmp;
}

日期-=天数

思路:先让日减去当前月天数,如果_day<0,就让_month-- (注意特殊处理_month==0的时候,_year--,_month=1),_day加上_month的天数,再次判断_day是不是小于0

Date& Date::operator-=(int day)
{if (day < 0){*this += (-day);}else{_day -= day;while (_day <= 0){--_month;if (_month == 0){_year--;_month = 12;}_day += GetMonthDay(_year, _month);}}return *this;
}

日期-天数

与日期+天数类似,进行代码复用就可以了~

Date Date::operator-(int day)
{Date tmp(*this);//特殊处理,day < 0,调用+=天数if (day < 0){tmp += (-day);}else{//代码复用tmp -= day;}return tmp;
}

前置++

前置++是先++再使用,事实上也就是当前日期本身+=1,我们一样可以使用代码复用~

Date& Date::operator++()
{*this += 1;return *this;
}

后置++

这里像前面那样为了与前置++区分,这里参数会有一个int进行区分,没有什么特别的意义,只是为了好区分~

后置++是先使用再++,所有我们需要使用一个临时对象来保存++之前的值进行返回~

Date Date::operator++(int)//后面加int与前置++区分
{Date tmp = *this;*this += 1;return tmp;
}

接下来的前置--和后置--有了这些基础,相信就是小菜一碟了~

前置--

Date& Date::operator--()
{*this -= 1;//本身-=1return *this;
}

后置--

Date Date::operator--(int)
{Date tmp = *this;*this -= 1;return tmp;
}

日期-日期

日期-日期是一个比较有意义的计算,而日期+日期没有实际意义,这里就不进行实现了~

日期-日期,我们可以直接让小日期走到大日期进行计数

同时注意是前面的日期大,还是后面的日期大~使用一个flag进行标记~

//*this   ——  d
int Date::operator-(const Date& d)const
{int flag = 1;//标记,默认前面的日期大Date max = *this;Date min = d;if (*this < d){//后面的日期大,重新赋值max = d;min = *this;flag = -1;}int n = 0;//计数//让小日期走到大日期进行计数while (min != max){min++;//或者min += 1;n++;}return n * flag;
}

到这里,我们就实现了一个比较完整的日期类~如果小伙伴们有更好的想法~欢迎评论区留言或者私信小编哦❤

总代码

Date.h

#pragma once#include<iostream>
using namespace std;
//定义日期类
class Date
{
private://成员变量 年、月、日int _year;int _month;int _day;//前面加一个下划线便于区分
public://成员函数//构造函数Date(int year = 0, int month = 0, int day = 0);//全缺省参数//拷贝构造函数Date(const Date& d);//检查日期是否合法bool CheckDate()const;//获取月份天数// 直接定义在类里面成为inline函数int GetMonthDay(int y, int m)const{static int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31, 30,31 };//                 0  1  2  3  4  5  6  7  8  9 10   11 12if (m == 2 && ((y % 400 == 0) || (y % 4 == 0 && y % 100 != 0)))//闰年的二月29天{return 29;}return arr[m];}//显示日期//1.成员函数//后面加const不希望this指针指向的内容被修改void Print()const;//2.使用友元,流插入运算符重载,进行输出//日期d加const不希望内容被修改friend ostream& operator <<(ostream& ou, const Date& d);//流提取运算符重载//日期d不加const,输入本身修改了内容//输入后需要判断日期是否合法friend istream& operator>>(istream& in, Date& d);//日期操作运算符重载//赋值运算符重载Date& operator=(const Date& d);//日期相等==bool operator==(const Date& d)const;//只是判断,不希望日期被修改 *this 和 d//不相等!=bool operator!=(const Date& d)const;//大于>bool operator>(const Date& d)const;//>=bool operator>=(const Date& d)const;//<bool operator<(const Date& d)const;//<=bool operator<=(const Date& d)const;//日期+=天数——改变日期本身Date& operator+=(int day);//日期加天数,不改变本身Date operator+(int day);//日期-=天数——改变日期本身Date& operator-=(int day);//日期-天数,不改变本身Date operator-(int day);//前置++——先++再使用,本身发生变化Date& operator++();//后置++——先使用再++Date operator++(int);//后面加int与前置++区分//前置--Date& operator--();//后置--Date operator--(int);//日期减日期int operator-(const Date& d)const;};//不要忘记末尾的分号//>>和<<定义为全局函数,符合我们的使用习惯
//Date的友元函数,可以访问Date类里面的私有成员
ostream& operator <<(ostream& ou, const Date& d);//类外不需要再使用friend关键字istream& operator>>(istream& in, Date& d);

Date.cpp

#include"Date.h"//自己写的头文件使用""//Date::Date(int year = 0,int month = 0,int day = 0)//err
Date::Date(int year,int month,int day)//声明和定义不可以同时给缺省参数
//在声明里面给缺省参数
{_year = year;_month = month;_day = day;//检查日期是否合法if (!CheckDate()){cout << "日期非法!" << *this << endl;}
}//拷贝构造函数——可以用来初始化新创建的对象
Date::Date(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;
}//检查日期是否合法~
bool Date::CheckDate()const
{if (_month > 12 || _month < 1 || _day <= 0 || _day > GetMonthDay(_year,_month)){return false;}return true;
}void Date::Print()const
//const 修饰this指针指向的内容,我们不希望内容被修改
{cout << _year << "年" << _month << "月" << _day << "日" << endl;
}ostream& operator <<(ostream& ou, const Date& d)
{ou << d._year << "年" << d._month << "月" << d._day << "日" << endl;return ou;//有返回值实现连续输出
}istream& operator>>(istream& in, Date& d)
{while (1){in >> d._year >> d._month >> d._day;//检查日期是否合法if (d.CheckDate()){break;}else{cout << "日期非法,请重新输入!" << endl;}}return in;
}//  d1  =  d2
//* this   d
//这里需要修改*this
Date& Date::operator=(const Date& d)
{_year = d._year;_month = d._month;_day = d._day;return *this;//有返回值,实现连续赋值
}
bool Date::operator==(const Date& d)const
{//年月日相等就相等return (_year == d._year)&& (_month == d._month)&& (_day == d._day);
}bool Date::operator!=(const Date& d)const
{//1.直接写/*return (_year != d._year)|| (_month != _month)|| (_day != d._day);*///2.代码复用return !(*this == d);
}bool Date::operator>(const Date& d)const
{if (_year > d._year){return true;}//年相等判断月if (_year == d._year){if (_month > d._month){return true;}//月相等判断天else if(_month == d._month){if (_day > d._day){return true;}}}return false;
}bool Date::operator>=(const Date& d)const
{//代码复用return (*this == d) || (*this > d);
}bool Date::operator<(const Date& d)const
{代码复用return !((*this == d) || (*this > d));
}bool Date::operator<=(const Date& d)const
{//代码复用return (*this < d) || (*this == d);
}//使用引用返回,减少拷贝次数
Date& Date::operator+=(int day)
{//特殊处理,day<0,调用日期-=天数if (day < 0)//调用日期减天数{*this -= (-day);}else{_day += day;while (_day > GetMonthDay(_year, _month)){_day -= GetMonthDay(_year, _month);_month++;//特殊处理:到下一年if (_month == 13){_year++;_month = 1;}}}return *this;
}这里返回不可以使用引用,局部对象出了作用域就销毁了,原来的对象存储的数据随机了
//返回对象会产生一个临时对象,调用拷贝构造
Date Date::operator+(int day)
{//创建一个临时对象Date tmp(*this);//特殊处理,day < 0if (day < 0){tmp -= (-day);}else{//代码复用tmp += day;}return tmp;
}Date& Date::operator-=(int day)
{if (day < 0){*this += (-day);}else{_day -= day;while (_day <= 0){--_month;if (_month == 0){_year--;_month = 12;}_day += GetMonthDay(_year, _month);}}return *this;
}Date Date::operator-(int day)
{Date tmp(*this);//特殊处理,day < 0,调用+=天数if (day < 0){tmp += (-day);}else{//代码复用tmp -= day;}return tmp;
}Date& Date::operator++()
{*this += 1;return *this;
}Date Date::operator++(int)//后面加int与前置++区分
{Date tmp = *this;*this += 1;return tmp;
}Date& Date::operator--()
{*this -= 1;return *this;
}Date Date::operator--(int)
{Date tmp = *this;*this -= 1;return tmp;
}//*this   ——  d
int Date::operator-(const Date& d)const
{int flag = 1;//标记,默认前面的日期大Date max = *this;Date min = d;if (*this < d){//后面的日期大,重新赋值max = d;min = *this;flag = -1;}int n = 0;//计数//让小日期走到大日期进行计数while (min != max){min++;//或者min += 1;n++;}return n * flag;
}


♥♥♥本篇博客内容结束,期待与各位优秀程序员交流,有什么问题请私信♥♥♥

♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥

✨✨✨✨✨✨个人主页✨✨✨✨✨✨


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

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

相关文章

kafka进阶_4.kafka扩展

文章目录 一、Controller选举二、Kafka集成2.1、大数据应用场景2.1.1、Flume集成2.1.2、Spark集成2.1.3、Flink集成 2.2、Java应用场景(SpringBoot集成) 三、Kafka常见问题3.1、Kafka都有哪些组件&#xff1f;3.2、分区副本AR, ISR, OSR的含义&#xff1f;3.3、Producer 消息重…

Flink Python作业快速入门

Flink Python快速入门_实时计算 Flink版(Flink)-阿里云帮助中心 import argparse # 用于处理命令行参数和选项&#xff0c;使程序能够接收用户通过命令行传递的参数 import logging import sysfrom pyflink.common import WatermarkStrategy, Encoder, Types from pyflink.data…

前端(五)css属性

css属性 文章目录 css属性一、字体属性二、文本属性三、背景属性四、盒子模型 一、字体属性 font-weight&#xff1a;文字粗细&#xff0c;在100到900之间&#xff0c;normal(400),bord(700),inherit(继承父类) font-style&#xff1a;文字风格&#xff0c;normal表示正常(默认…

nginx反向代理(负载均衡)和tomcat介绍

nginx的代理 负载均衡 负载均衡的算法 负载均衡的架构 基于ip的七层代理 upstream模块要写在http模块中 七层代理的调用要写在location模块中 轮询 加权轮询 最小连接数 ip_Hash URL_HASH 基于域名的七层代理 配置主机 给其余客户机配置域名 给所有机器做域名映射 四层代理…

ansible自动化运维(二)playbook模式详解

相关文章ansible自动化运维&#xff08;一&#xff09;简介及清单,模块-CSDN博客ansible自动化运维&#xff08;三&#xff09;jinja2模板&&roles角色管理-CSDN博客ansible自动化运维&#xff08;四&#xff09;运维实战-CSDN博客 一.Ansible中的playbook模式 Playbo…

验证码功能实现

预览: 前端代码 让图片src 产生验证码图片的servlet <img src""></img> servlet代码 public void checkCode(HttpServletRequest request, HttpServletResponse response) throws IOException {ServletOutputStream os response.getOutputStream()…

Redis的哨兵机制

目录 1. 文章前言2. 基本概念2.1 主从复制的问题2.2 人工恢复主节点故障2.3 哨兵机制自动恢复主节点故障 3. 安装部署哨兵&#xff08;基于docker&#xff09;3.1 安装docker3.2 编排redis主从节点3.3 编排redis-sentinel节点 4. 重新选举5. 选举原理6. 总结 1. 文章前言 &…

Java:集合(List、Map、Set)

文章目录 1. Collection集合1-1. 迭代器遍历方式1-2. 通过for循环进行遍历1-3. forEach遍历 2. List集合2-1. ArrayList底层实现原理2-2. LinkedList底层实现原理 3. Set集合3-1. HashSet 底层实现3-2. LinkedHashSet 底层实现3-3. TreeSet 4. Collection集合->总结5. Map集…

什么是Apache日志?为什么Apache日志分析很重要?

Apache是全球最受欢迎的Web服务器软件&#xff0c;支持约30.2%的所有活跃网站。凭借其可靠性、灵活性和强大的功能&#xff0c;Apache数十年来一直是互联网的中坚力量。 一、Apache Web服务器的工作原理 Apache Web服务器的工作原理如下&#xff1a; 接收HTTP请求&#xff1…

【再谈设计模式】组合模式~层次构建的多面手

一、引言 在软件开发的世界里&#xff0c;我们经常面临着处理对象之间复杂关系的挑战。如何有效地表示对象的部分 - 整体层次结构&#xff0c;并且能够以一种统一的方式操作这些对象&#xff0c;是一个值得探讨的问题。组合模式&#xff08;Composite Pattern&#xff09;为我们…

论文翻译 | ChunkRAG: Novel LLM-Chunk Filtering Method for RAG Systems

摘要 使用大型语言模型&#xff08;LLM&#xff09;的检索-增强生成&#xff08;RAG&#xff09;系统经常由于检索不相关或松散相关的信息而生成不准确的响应。现有的在文档级别操作的方法无法有效地过滤掉此类内容。我们提出了LLM驱动的块过滤&#xff0c;ChunkRAG&#xff0…

Redis配置文件中 supervised指令

什么是Supervised&#xff1f; supervised模式允许Redis被外部进程管理器监控。通过这个选项&#xff0c;Redis能够在崩溃后自动重启&#xff0c;确保服务的高可用性。常见的进程管理器包括systemd和upstart。 开启方法 vim修改&#xff1a; sudo vi /etc/redis/redis.conf…

Android四大组件——Activity(二)

一、Activity之间传递消息 在&#xff08;一&#xff09;中&#xff0c;我们把数据作为独立的键值对进行传递&#xff0c;那么现在把多条数据打包成一个对象进行传递&#xff1a; 1.假设有一个User类的对象&#xff0c;我们先使用putExtra进行传递 activity_demo06.xml <…

SpringBoot基于Redis+WebSocket 实现账号单设备登录.

引言 在现代应用中&#xff0c;一个账号在多个设备上的同时登录可能带来安全隐患。为了解决这个问题&#xff0c;许多应用实现了单设备登录&#xff0c;确保同一个用户只能在一个设备上登录。当用户在新的设备上登录时&#xff0c;旧设备会被强制下线。 本文将介绍如何使用 Spr…

【架构】从 Socket 的角度认识非阻塞模型

文章目录 前言1. 阻塞模型2. 非阻塞模型2.1 Reactor 模型优势2.2 Reactor 模型劣势 后记 前言 近期看了很多中间件的文章&#xff0c;RocketMQ&#xff0c;Dubbo 这些中间件内部的rpc通信都用的是非阻塞的模型。(Netty)&#xff0c;这里从 Socket 的角度总结一下。 1. 阻塞模…

location和重定向、代理

location匹配的规则和优先级 在nginx当中&#xff0c;匹配的对象一般是URI来匹配 http://192.168.233.62/usr/local/nginx/html/index.html 182.168.233.61/ location匹配的分类&#xff1a; 多个location一旦匹配其中之一&#xff0c;不在匹配其他location 1、精确匹配 …

ragflow连ollama时出现的Bug

ragflow和ollama连接后&#xff0c;已经添加了两个模型但是ragflow仍然一直warn&#xff1a;Please add both embedding model and LLM in Settings &#xff1e; Model providers firstly.这里可能是我一开始拉取的镜像容器太小&#xff0c;容不下当前添加的模型&#xff0c;导…

软件测试面试问答

文章目录 什么是软件&#xff1f;软件测试工程师的工作内容什么是软件测试&#xff1f;软件开发生命周期软件开发的几个阶段软件bug的五个要素Bug的十大要素:软件测试的分类软件测试方法分类单元测试设计测试用例的主要方法什么是测试用例测试用例几大要素你的测试职业发展是什…

python学习笔记—7—变量拼接

1. 字符串的拼接 print(var_1 var_2) print("supercarry" "doinb") name "doinb" sex "man" score "100" print("sex:" sex " name:" name " score:" score) 注意&#xff1a; …

Win10环境vscode+latex+中文快速配置

安装vscodelatex workshop 配置&#xff1a; {"liveServer.settings.donotVerifyTags": true,"liveServer.settings.donotShowInfoMsg": true,"explorer.confirmDelete": false,"files.autoSave": "afterDelay","exp…