C++实战——日期类的实现

日期类的实现

  • 前言
  • 一、日期类
    • 概念
    • 实现
    • 运用场景
  • 二、日期类的具体实现代码
    • 构造函数
    • 拷贝构造函数
    • 获取日期(内联函数)
    • 赋值
    • 加等
    • 减等
    • 小于
    • 小于等于
    • 大于
    • 大于等于
    • 相等
    • 不相等
    • 前置++
    • 后置++
    • 前置- -
    • 后置- -
    • 关于类里重载的比较运算符为什么要加外部const
      • 示例
    • Date.h
    • Date.cpp


前言

日期类是指处理日期和时间相关操作的编程类库或对象。它提供了创建、解析、比较、格式化日期和时间等功能,方便开发者在程序中处理与时间相关的逻辑。日期类通常包括年、月、日、时、分、秒等属性,并允许进行各种日期时间的计算和操作,如加减天数、获取星期几、判断是否为闰年等。通过使用日期类,开发者可以更加高效、准确地处理时间相关的数据。


一、日期类

本文的实现基于往期文章学过的内容

  • C++从入门到精通——类的6个默认成员函数之赋值运算符重载
  • C++从入门到精通——类的6个默认成员函数之拷贝构造函数
  • C++从入门到精通——类的6个默认成员函数之析构函数
  • C++从入门到精通——类的6个默认成员函数之构造函数
  • C++从入门到精通——this指针
  • C++从入门到精通——类的作用域及类的实例化
  • C++从入门到精通——类的定义及类的访问限定符和封装
  • C++从入门到精通——内联函数
  • C++从入门到精通——引用(&)
  • C++从入门到精通——缺省参数
  • C++从入门到精通——C++输入和输出
  • C++从入门到精通——命名空间

概念

日期类是一种用于表示日期的数据类型。它通常包含年、月、日等成员变量,以及一些用于操作日期的方法。

日期类可以用于记录和处理具体的日期信息,例如生日、纪念日、活动日期等。

日期类可以提供一些常用的功能,例如计算两个日期之间的时间差、判断一个日期是星期几、格式化日期等。

日期类还可以用于日期的比较和排序,通过比较日期对象的大小,可以判断哪个日期在前、哪个日期在后。

日期类在编程中广泛应用,特别是在计算机程序中需要处理时间和日期相关的业务逻辑时。

实现

#include"Date.h"
class Date
{
public:
    // 获取某年某月的天数
    int GetMonthDay(int year, int month)
    {
        static int days[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30,
       31 };
        int day = days[month];
        if (month == 2
            && ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0)))
        {
            day += 1;
        }
        return day;
    }

    // 全缺省的构造函数
    Date(int year = 1900, int month = 1, int day = 1);
    // 拷贝构造函数
 // d2(d1)
    Date(const Date& d);

    // 赋值运算符重载
 // d2 = d3 -> d2.operator=(&d2, d3)
    Date& operator=(const Date& d);
    // 析构函数
    ~Date();
    // 日期+=天数
    Date& operator+=(int day);
    // 日期+天数
    Date operator+(int day);
    // 日期-天数
    Date operator-(int day);
    // 日期-=天数
    Date& operator-=(int day);
    // 前置++
    Date& operator++();
    // 后置++
    Date operator++(int);
    // 后置--
    Date operator--(int);
    // 前置--
    Date& operator--();

    // >运算符重载
    bool operator>(const Date& d);
    // ==运算符重载
    bool operator==(const Date& d);
    // >=运算符重载
    bool operator >= (const Date& d);

    // <运算符重载
    bool operator < (const Date& d);
    // <=运算符重载
    bool operator <= (const Date& d);
    // !=运算符重载
    bool operator != (const Date& d);
    // 日期-日期 返回天数
    int operator-(const Date& d);
private:
    int _year;
    int _month;
    int _day;
};

运用场景

日期类的运用场景非常广泛,以下是一些常见的场景:

  1. 日历和时间管理:日期类可以用于创建日历和管理时间,例如在行事历应用程序中,可以使用日期类来跟踪和管理用户的日程安排。

  2. 数据处理和分析:在数据分析和处理的过程中,日期类可以用于对时间序列数据进行操作和计算,例如计算日期之间的时间间隔、按日期进行排序和过滤数据等。

  3. 事件调度和提醒:日期类可以用于事件调度和提醒的功能,例如在任务管理应用程序中,可以使用日期类来设置任务的截止日期,并提醒用户即将到期的任务。

  4. 日志记录和统计:日期类可以用于记录和统计事件的发生时间,例如在日志系统中,可以使用日期类来记录日志的时间戳,并对日志进行统计和分析。

  5. 计算器和时钟功能:日期类可以用于实现计算器和时钟功能,例如在计算器应用程序中,可以使用日期类来进行日期和时间的计算和显示。

总而言之,日期类的运用场景非常广泛,几乎在任何需要处理时间和日期的应用程序中都可以看到其身影。

二、日期类的具体实现代码

构造函数

Date(int year = 1900, int month = 1,int day = 1);
Date::Date(int year, int month, int day)
{
	_year = year;
	_month = month;
	_day = day;
}

拷贝构造函数

Date(const Date& d);
Date::Date(const Date& d)
{
	_year = d._year;
	_month = d._month;
	_day = d._day;
}

获取日期(内联函数)

int GetMonthDay(int year, int month)
{
	assert(month > 0 && month < 13);

	static int monthDayArray[13] = { -1, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };

	// 365天 5h +
	if (month == 2 && (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))
	{
		return 29;
	}
	else
	{
		return monthDayArray[month];
	}
}

函数的输入是年份和月份,都是整数类型。函数的输出是一个整数,表示指定月份的天数。

首先,函数使用assert函数来确保传入的月份在有效范围内,即大于0且小于13。如果月份不在有效范围内,程序会终止。

然后,函数定义了一个静态的整型数组monthDayArray,用于存储每个月份的天数。数组的下标对应月份,数组的值对应该月份的天数。

接下来,函数通过判断月份是否为2月来处理闰年的情况。闰年的判断条件为:年份能被4整除并且不能被100整除,或者能被400整除。如果是闰年,2月的天数为29天,否则使用数组monthDayArray中对应月份的值作为天数。

最后,函数返回获取到的天数。

总结:这段代码是一个用于获取指定年份和月份的天数的函数,对闰年进行了处理,并使用数组存储了每个月份的天数。

赋值

Date& operator=(const Date& d);
Date& Date::operator=(const Date& d)
{
	if (this != &d)
	{
		_year = d._year;
		_month = d._month;
		_day = d._day;
	}
	return *this;
}

这是一个重载赋值运算符的函数,用于将一个Date对象赋值给另一个Date对象。

首先,通过this指针与待赋值对象(&d)进行比较,确保不是自我赋值。

然后,将待赋值对象的私有成员变量(_year, _month, _day)的值分别赋给当前对象的对应成员变量。

最后,返回当前对象的引用(*this)。

这样,通过重载赋值运算符,可以实现Date对象之间的赋值操作。

加等

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

	return *this;
}

这是一个重载"+="运算符的函数,用于给当前的Date对象增加指定的天数。

首先,检查增加的天数是否小于0,如果是,则将其转换为正数,并使用递减运算符(-=)来实现减少指定天数的操作,然后返回当前对象的引用。

接着,将给定的天数累加到当前对象的_day成员变量上。

然后,使用一个while循环来判断当前的_day是否超过了当前月份的天数。如果超过了,就通过减去当前月份的天数来计算剩余的天数,并将_month加1。如果_month等于13(即当前月份是12月),则说明年份需要进位,将_year加1,同时将_month重置为1。

最后,返回当前对象的引用。

这样,通过重载"+="运算符,可以实现给Date对象增加指定天数的操作。

减等

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

这是重载"-="运算符的函数,用于给当前的Date对象减少指定的天数。

首先,检查减少的天数是否小于0,如果是,则将其转换为正数,并使用递增运算符(+=)来实现增加指定天数的操作,然后返回当前对象的引用。

接着,将给定的天数从当前对象的_day成员变量中减去。

然后,使用一个while循环来判断当前的_day是否小于等于0。如果小于等于0,说明日期需要借位,所以将_month减1。如果_month等于0(即当前月份是1月),则说明年份需要借位,将_year减1,同时将_month重置为12。

接下来,根据减少的月份重新计算_day的值。首先获取减少后的月份的天数,然后将_day加上这个天数。

最后,返回当前对象的引用。

通过重载"-="运算符,可以实现给Date对象减少指定天数的操作。

Date operator+(int day);
Date Date::operator+(int day)
{
	Date tmp = *this;
	tmp += day;

	return tmp;
}

这是重载"+"运算符的函数,用于创建一个新的Date对象,该对象的日期是当前Date对象加上指定天数后的结果。

首先,创建一个临时的Date对象tmp,并将其初始化为当前对象的副本。

然后,使用重载的"+="运算符将指定天数加到tmp对象上。

最后,返回tmp对象。

通过重载"+"运算符,可以实现给Date对象加上指定天数后返回一个新的Date对象的操作。

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

这是重载"-"运算符的函数,用于创建一个新的Date对象,该对象的日期是当前Date对象减去指定天数后的结果。

首先,创建一个临时的Date对象tmp,并将其初始化为当前对象的副本。

然后,使用重载的"-="运算符将指定天数从tmp对象上减去。

最后,返回tmp对象。

通过重载"-"运算符,可以实现给Date对象减去指定天数后返回一个新的Date对象的操作。

小于

bool operator<(const Date& d)const;
bool Date::operator<(const Date& d)const
{
	if (_year < d._year)
	{
		return true;
	}
	else if (_year == d._year)
	{
		if (_month < d._month)
		{
			return true;
		}
		else if (_month == d._month)
		{
			return _day < d._day;
		}
	}

	return false;
}

这段代码是重载了"<"运算符,用于比较两个日期对象的大小。

首先,比较当前对象的_year和另一个日期对象d_year。如果当前对象的_year小于d_year,则返回true,表示当前对象的日期较早。

如果当前对象的_year等于d_year,则继续比较_month。如果当前对象的_month小于d_month,则返回true,表示当前对象的日期较早。

如果当前对象的_month等于d_month,则继续比较_day。如果当前对象的_day小于d_day,则返回true,表示当前对象的日期较早。

如果以上条件都不满足,则返回false,表示当前对象的日期与d相等或较晚。

通过重载"<"运算符,可以方便地比较两个日期对象的大小。这在需要判断日期先后关系的场景中非常有用,比如排序、查找等操作。

小于等于

bool operator<=(const Date & d)const;
bool Date::operator<=(const Date& d)const
{
	return *this < d || *this == d;
}

这段代码是重载了"<="运算符,用于比较两个日期对象的大小或相等关系。

首先,使用重载的"<"运算符比较当前对象和另一个日期对象d的大小。如果当前对象小于d,则返回true

然后,使用重载的"=="运算符比较当前对象和d是否相等。如果相等,则返回true

如果以上两个条件都不满足,则返回false

通过重载"<="运算符,可以方便地比较两个日期对象的大小或相等关系。这在需要判断日期先后关系和相等关系的场景中非常有用,比如进行条件判断、排序、查找等操作。

大于

bool operator>(const Date& d)const;
bool Date::operator>(const Date& d)const
{
	return !(*this <= d);
}

这是一个重载的比较运算符(大于)的实现,用于比较两个Date对象的大小关系。

该函数采用了常量引用参数const Date& d,表示传递给该函数的参数d是一个常量引用,即不会对d进行修改。这是为了保证在比较函数中不会对传入的对象进行修改。

函数的逻辑是先判断this指针所指向的对象是否小于等于d对象(使用小于等于运算符<=),然后对这个结果取反,即得到大于运算符的结果。

函数实现中调用了<=运算符,该运算符可能在Date类中定义了,也可能是通过其他方式实现的。这段代码的逻辑是先判断两个Date对象的大小关系(小于等于),再对结果取反,即得到大于运算符的结果。

大于等于

bool operator>=(const Date& d)const;
bool Date::operator>=(const Date& d)const
{
	return !(*this < d);
}

这是一个重载的比较运算符(大于等于)的实现,用于比较两个Date对象的大小关系。

该函数采用了常量引用参数const Date& d,表示传递给该函数的参数d是一个常量引用,即不会对d进行修改。这是为了保证在比较函数中不会对传入的对象进行修改。

函数的逻辑是先判断this指针所指向的对象是否小于d对象(使用小于运算符<),然后对这个结果取反,即得到大于等于运算符的结果。

相等

bool operator==(const Date& d)const;
bool Date::operator==(const Date& d)const
{
	return _year == d._year
		&& _month == d._month
		&& _day == d._day;
}

这是一个重载的相等运算符(等于)的实现,用于比较两个Date对象是否相等。

该函数采用了常量引用参数const Date& d,表示传递给该函数的参数d是一个常量引用,即不会对d进行修改。这是为了保证在比较函数中不会对传入的对象进行修改。

函数的逻辑是比较调用该函数的对象(即*this)的_year_month_day成员变量与参数对象d的相应成员变量是否相等。如果这三个成员变量都相等,则返回true;否则返回false

需要注意的是,由于该函数没有修改类中的成员变量,因此可以被声明为const成员函数。使用const关键字来修饰成员函数,表示该成员函数不会修改类的成员变量,也不会调用其他非const成员函数,从而保证了常量对象也可以调用该函数。

不相等

bool operator!=(const Date& d)const;
bool Date::operator!=(const Date& d)const
{
	return !(*this == d);
}

这是一个重载的不等运算符(不等于)的实现,用于比较两个Date对象是否不相等。

该函数采用了常量引用参数const Date& d,表示传递给该函数的参数d是一个常量引用,即不会对d进行修改。这是为了保证在比较函数中不会对传入的对象进行修改。

函数的逻辑是调用相等运算符(==)来判断两个Date对象是否相等。如果两个对象相等,则返回false;否则返回true

需要注意的是,由于该函数没有修改类中的成员变量,因此可以被声明为const成员函数。使用const关键字来修饰成员函数,表示该成员函数不会修改类的成员变量,也不会调用其他非const成员函数,从而保证了常量对象也可以调用该函数。

前置++

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

这是一个重载的前置递增运算符(++)的实现,用于对Date对象进行自增操作。

该函数返回的是一个引用类型的Date对象,即返回自增后的对象。这是为了实现连续的递增操作,例如:++d1++d2++d3

函数的逻辑是先调用自定义的加法运算符(+=),将自身增加1天,然后返回自身引用。

需要注意的是,由于该函数会修改类的成员变量,因此不能被声明为const成员函数。同时,返回引用类型的对象,可以通过连续使用操作符实现连续的自增操作。

后置++

Date& operator++(int);
Date& Date::operator++(int)
{
	Date tmp(*this);

	*this += 1;
	return *this;
}

这是一个重载的后置递增运算符(++)的实现,用于对Date对象进行自增操作。

该函数返回的是一个引用类型的Date对象,即返回自增前的对象。这是为了模拟后置递增操作符的行为,先返回旧值,然后再对对象自增。

函数的逻辑是先创建一个临时的Date对象tmp,将自身的值赋给tmp。然后调用自定义的加法运算符(+=),将自身增加1天。最后返回tmp

需要注意的是,该函数的参数int,只是为了区分前置递增运算符和后置递增运算符的函数签名,在函数体内并没有实际使用。同时,返回引用类型的对象,可以通过连续使用操作符实现连续的自增操作。

前置- -

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

这是一个重载的前置递减运算符(--)的实现,用于对Date对象进行自减操作。

该函数返回的是一个引用类型的Date对象,即返回自减后的对象。这是为了模拟前置递减操作符的行为,先对对象自减,然后再返回新值。

函数的逻辑是调用自定义的减法运算符(-=),将自身减少1天。然后返回自身。

需要注意的是,该函数没有参数,因为前置递减运算符不需要额外的参数来区分前置和后置形式。同时,返回引用类型的对象,可以通过连续使用操作符实现连续的自减操作。

后置- -

Date& operator--(int);
Date& Date::operator--(int)
{
	Date tmp(*this);

	*this -= 1;
	return *this;
}

这是一个重载的后置递减运算符(--)的实现,用于对Date对象进行自减操作。

和前置递减运算符不同,后置递减运算符需要通过函数参数来区分前置和后置形式,参数的类型可以是int或者一个无关的类型,这里使用int作为参数。

函数的逻辑是先创建一个临时的Date对象tmp,将当前对象的值拷贝给tmp。然后通过调用自定义的减法运算符(-=),将自身减少1天。最后返回tmp对象,也就是自减之前的值。

需要注意的是,返回的是一个临时对象的引用,而不是自身的引用。这是因为后置递减运算符需要返回自减之前的值,而不是自减之后的值。为了防止出现悬空引用的情况,使用临时对象来保存自减之前的值,并返回其引用。

关于类里重载的比较运算符为什么要加外部const

在C++中,比较运算符重载通常需要将其定义为成员函数。在重载比较运算符时,我们需要考虑到两个方面:

  1. 在比较运算符重载中,我们不希望修改类的成员变量。因此,我们需要将比较运算符定义为const成员函数。通过将成员函数标记为const,我们告诉编译器这个函数不会修改类的任何成员变量。

  2. 我们还需要考虑到使用比较运算符的情况。在某些情况下,我们可能会在const对象上使用比较运算符。比如,如果我们将一个const对象与另一个const对象进行比较,我们需要确保比较运算符能够在const对象上正确地进行比较。

因此,为了确保比较运算符能够在const对象上正确地进行比较,并且不修改类的成员变量,我们需要将比较运算符定义为const成员函数。这样可以保证比较运算符能够正确地在const对象上使用,并且不会修改类的状态。

示例

const Date d1(2024,4,11);

在这里插入图片描述
d1< d2 会报错,是因为this指针在类里是Date* const this修饰的

在C++中,类里的成员函数有一个隐含的指向当前对象的指针,称为this指针。在类的成员函数中使用this指针,可以访问当前对象的成员变量和成员函数。

this指针的类型是指向当前对象的非常量指针,因此this指针默认情况下是指向非常量对象的。如果将一个常量对象传递给this指针,即将一个常量对象赋值给非常量指针,就会导致类型不匹配的错误。

这是因为常量对象具有只读属性,不允许被修改,而非常量指针可以修改指向的对象。如果允许将常量对象传递给非常量指针,就会破坏常量对象的只读属性。为了确保对象的常量性,C++编译器会报错。

所以,类里的this指针接受一个常量会报错。如果想在类的成员函数中操作常量对象,需要将成员函数声明为const成员函数,在const成员函数中,this指针的类型会变为指向常量对象的指针。这样就可以在const成员函数中访问常量对象的成员变量,但不能修改它们。

Date.h

#pragma once
#include<iostream>
#include<assert.h>
using namespace std;

class Date
{
public:
	int GetMonthDay(int year, int month)
	{
		assert(month > 0 && month < 13);

		static int monthDayArray[13] = { -1, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };

		// 365天 5h +
		if (month == 2 && (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))
		{
			return 29;
		}
		else
		{
			return monthDayArray[month];
		}
	}
	Date(int year = 1900, int month = 1,int day = 1);
	Date(const Date& d);
	Date& operator=(const Date& d);
	Date& operator+=(int day);
	Date& operator-=(int day);
	Date operator+(int day);
	Date operator-(int day);
	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;
	bool operator!=(const Date& d)const;
	Date& operator++();
	Date& operator++(int);
	Date& operator--();
	Date& operator--(int);
private:
	int _year ;
	int _month;
	int _day;
};

Date.cpp

#include"Date.h"

Date::Date(int year, int month, int day)
{
	_year = year;
	_month = month;
	_day = day;
}
Date::Date(const Date& d)
{
	_year = d._year;
	_month = d._month;
	_day = d._day;
}
Date& Date::operator=(const Date& d)
{
	if (this != &d)
	{
		_year = d._year;
		_month = d._month;
		_day = d._day;
	}
	return *this;
}
Date& Date::operator+=(int day)
{
	if (day < 0)
	{
		return *this -= -day;
	}
	_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)
{
	if (day < 0)
	{
		return *this += -day;
	}
	_day -= day;
	while (_day <= 0)
	{
		--_month;
		if (_month == 0)
		{
			_month = 12;
			--_year;
		}
		int days = GetMonthDay(_year, _month);
		_day += days;
	}
	return *this;
}
Date Date::operator+(int day)
{
	Date tmp = *this;
	tmp += day;

	return tmp;
}
Date Date::operator-(int day)
{
	Date tmp = *this;
	tmp -= day;
	return tmp;
}
bool Date::operator<(const Date& d)const
{
	if (_year < d._year)
	{
		return true;
	}
	else if (_year == d._year)
	{
		if (_month < d._month)
		{
			return true;
		}
		else if (_month == d._month)
		{
			return _day < d._day;
		}
	}

	return false;
}

// d1 <= d2
bool Date::operator<=(const Date& d)const
{
	return *this < d || *this == d;
}

bool Date::operator>(const Date& d)const
{
	return !(*this <= d);
}

bool Date::operator>=(const Date& d)const
{
	return !(*this < d);
}

bool Date::operator==(const Date& d)const
{
	return _year == d._year
		&& _month == d._month
		&& _day == d._day;
}

bool Date::operator!=(const Date& d)const
{
	return !(*this == d);
}
//++
Date& Date::operator++()
{
	*this += 1;
	return *this;
}
Date& Date::operator++(int)
{
	Date tmp(*this);

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

	*this -= 1;
	return *this;
}


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

常见UI组件(二)

一、文本输入 1.1 概述 TextInput为文本输入组件&#xff0c;用于接收用户输入的文本内容 1.2 参数 Entry Component struct Index {build() {Column({space : 50}) {TextInput({placeholder:请输入用户名}).width(70%)TextInput({text:当前内容}).width(70%)}.width(100%).…

90天精通Psim仿真--经典实战教程--第10天 Simcode DSP28335 LED控制

PSIM (Power Simulation) 是一款电力电子和电机控制仿真软件,而DSP28335是德州仪器(TI)的一款数字信号处理器(DSP)。如果你想要在PSIM的SimCoder环境中为DSP28335生成LED闪烁的代码,遵循以下步骤: 打开PSIM并创建模型: 首先,在PSIM中创建一个电路模型,该模型应包括DS…

Bootstrap 5 保姆级教程(十一):模态框 提示框

一、模态框 1.1 创建模态框 以下实例创建了一个简单的模态框效果 &#xff1a; <div class"container mt-3"><h3>模态框实例</h3><p>点击按钮打开模态框</p><button type"button" class"btn btn-primary" d…

Scikit-Learn 支持向量机分类

Scikit-Learn 支持向量机分类 1、支持向量机&#xff08;SVM&#xff09;1.1、SVM概述1.2、SVM原理1.3、SVM的损失函数 1、支持向量机&#xff08;SVM&#xff09; 1.1、SVM概述 在机器学习中&#xff0c;支持向量机&#xff08;Support Vector Machine&#xff0c;SVM&#x…

C++入门5.内联函数,auto关键字,基于范围的for循环(C++11),指针空值nullptr(C++11)

本篇是C过度C初始的最后一篇&#xff0c;快快对入门须知的知识有个印象后&#xff0c;就可以顺顺利利的学习C的类了。 目录 内联函数&#xff1a; 内联函数的特性&#xff1a; auto关键字(C11)&#xff1a; auto简介&#xff1a; 使用细则&#xff1a; auto不能推导的场…

【Linux】帮助类命令

在Linux中&#xff0c;man用于查看系统手册页&#xff08;manual pages&#xff09;。它用于查阅关于特定命令、函数、工具或文件格式的详细信息。要使用man命令&#xff0c;只需在终端中输入man&#xff0c;后跟您要查看的命令或主题的名称。 例如&#xff0c;如果查看ls命令…

【Linux C | 多线程编程】线程同步 | 信号量(无名信号量) 及其使用例子

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

018Node.js安装淘宝镜像(cnpm命令)

http://www.npmjs.org npm包官网 https://npm.taobao.org 淘宝npm镜像官网 淘宝NPM镜像是一个完整npmjs.org镜像&#xff0c;你可以用此替代官方版本&#xff08;只读&#xff09;&#xff0c;同步频率目前为10分钟一次&#xff0c;保证尽量与官方服务同步。 可以定制的cnpm(…

若依前后端部署到一起

引用&#xff1a;https://blog.csdn.net/qq_42341853/article/details/129127553 前端改造&#xff1a; 配置打包前缀 修改router.js 编程hash模式&#xff1a; 前端打包&#xff1a;npm run build:prod 后端修改&#xff1a; 添加thymeleaf包&#xff0c;和配置文件 spri…

Three.js加载glb / gltf模型,Vue加载glb / gltf模型(如何在vue中使用three.js,vue使用threejs加载glb模型)

简介&#xff1a;Three.js 是一个用于在 Web 上创建和显示 3D 图形的 JavaScript 库。它提供了丰富的功能和灵活的 API&#xff0c;使开发者可以轻松地在网页中创建各种 3D 场景、模型和动画效果。可以用来展示产品模型、建立交互式场景、游戏开发、数据可视化、教育和培训等等…

Jenkins用maven风格build报错解决过程记录

1、Jenkins2.453新建项目&#xff0c;构建风格选的maven 2、自由风格构建部署没有任何问题&#xff0c;但是maven风格build一直失败&#xff0c;报错如下图 3、解决方案&#xff1a;在系统管理–系统配置–Maven项目配置&#xff0c;删除全局MAVEN_OPT的路径信息&#xff0c;…

OpenCV基本图像处理操作(四)——傅立叶变换

傅里叶变换的作用 高频&#xff1a;变化剧烈的灰度分量&#xff0c;例如边界 低频&#xff1a;变化缓慢的灰度分量&#xff0c;例如一片大海 滤波 低通滤波器&#xff1a;只保留低频&#xff0c;会使得图像模糊 高通滤波器&#xff1a;只保留高频&#xff0c;会使得图像细节…

事务的传播行为介绍和事务失效

常用的就下图介绍的这两种&#xff0c;REQUIRED 支持当前事务&#xff0c;如果不存在&#xff0c;就新建一个&#xff0c;EQUIRES_NEW 如果有事务存在&#xff0c;挂起当前事务&#xff0c;创建一个新的事务 同一个service中必须用代理对象调用&#xff0c;否则失效

ubuntu22.04下编译ffmpeg和ffplay

Ubuntu22.04 下编译安装 ffmpeg 和 ffplay 一、下载源码包 1.1 官方下载链接&#xff1a;Download FFmpeg 可以手动下载&#xff0c;也可以命令行下载&#xff1a; wget http://www.ffmpeg.org/releases/ffmpeg-7.0.tar.xz 1.2 下载完解压 tar -xvf ffmpeg-7.0.tar.xz…

3.SpringCloud版本

1.SpringCloud与SpringBoot之间版本对应 2.服务拆分的注意事项 1.不同微服务&#xff0c;不要重复开发相同业务。 2.微服务的数据独立&#xff0c;每个微服务都有自己独立的数据库&#xff0c;不要访问其他微服务的数据库。 3.微服务可以将自己的的业务暴露为接口&#xff…

如何选择适用于Mac的iPhone数据恢复软件?

以下是全球无数 Mac 用户每天遇到的场景&#xff1a; 用户丢失了重要文件。用户在搜索中输入术语“iPhone数据恢复软件”。出现了数百个可能合适的软件应用程序&#xff0c;使用户很难决定其中哪一个是最好的。 这并不好&#xff0c;因为iOS数据恢复是一个时间敏感的过程&…

Spring、SpringMVC、SpringBoot核心知识点(持续更新中)

Spring、SpringMVC、SpringBoot核心知识点&#xff08;持续更新中&#xff09; Spring Bean 的生命周期Spring 的 IOC 与 AOPSpring Bean 循环依赖Spring MVC 处理请求的过程Spring Boot 自动装配原理Spring Boot 启动流程 Spring Bean 的生命周期 参考文章&#xff1a;一文读…

提取点云-------PCL

提取点云 /// <summary> /// VoxelGrid滤波下采样 /// </summary> /// <param name"cloud">需要滤波的点云</param> /// <param name"lx">三维体素栅格的x</param> /// <param name"ly">三维体素栅格…

vue 下载文件 处理后台返回的文件流

1. 下载文件很常见&#xff0c;下载成各种格式的也很常见&#xff0c;本质就是后台返回一个文件流&#xff0c;我们前端去处理一下就行&#xff0c;但是如果因为某些条件&#xff0c;没有返回文件流&#xff0c;返回告诉你&#xff0c;文件出现错误了&#xff0c;那我们就需要把…

【机器学习】分类与预测算法的评价与优化

以实际案例解析F1值与P-R曲线的应用 一、分类算法与性能评价的重要性二、F1值与P-R曲线的概念与意义三、实例解析&#xff1a;以垃圾邮件检测为例四、代码实现与结果分析五、结论与展望 在数据驱动的时代&#xff0c;机器学习算法以其强大的数据处理和分析能力&#xff0c;成为…