C++ Day04 this指针,友元函数,重载

news2025/1/19 11:39:15

this指针

概念

谁调用 this 所在的函数 ,this 就存储谁的地址

特点

1, 在当前类的非静态成员函数中调用本类非静态成员时 , 默认有 this 关键字
2, 静态成员函数 , 没有 this 指针。
示例
#include <iostream>
#include <cstring>
using namespace std;
class Stu{
private:
    char name[50];
    char sex[10];
    int age;
public:
    Stu(){}
    Stu(char *n,char *s,int a):age(a)
    {
        strcpy(name,n);
        strcpy(sex,s);
    }
    void test01()
    {
    //以下两句代码效果相同
    //证明本类函数中调用本类成员默认使用this关键字
        cout << this->name << endl;
        cout << name << endl;
    }
    static void test02()
    {
    //报错,因为静态函数中没有this
        //cout << name << endl;
    }
};
int main(int argc, char *argv[])
{
    Stu s("张三","男",18);
    s.test01();
    s.test02();
    return 0;
}

使用场景

1, 局部变量与成员变量重名时 , 使用 this 区分
2, 调用本类其他成员 , 此时 this 可以省略不写
示例
#include <iostream>
#include <cstring>
using namespace std;
class Stu{
private:
    char name[50];
    char sex[10];
    int age;
public:
    Stu(){}
    Stu(char *name,char *sex,int age)
    {
    //当局部变量与成员变量重名,使用this区分
        strcpy(this->name,name);
        strcpy(this->sex,sex);
        this->age = age;
    }
    void print_info()
    {
        //调用本类成员变量
        cout << this->name << endl;
        cout << this->sex << endl;
        cout << this->age << endl;
    }
    void test()
    {
    //调用本类成员函数
        this->print_info();
    }
};
int main(int argc, char *argv[])
{
    Stu s("张三","男",18);
    s.print_info();
    s.test();
    return 0;
}

实例

使用 :*this 完成链式编程
#include <iostream>
#include <cstring>
using namespace std;
class Stu{
private:
    char name[50];
    char sex[10];
    int age;
public:
    Stu(){}
    Stu(char *name,char *sex,int age)
    {
        strcpy(this->name,name);
        strcpy(this->sex,sex);
        this->age = age;
    }
    void print_info()
    {
        cout << this->name << endl;
        cout << this->sex << endl;
        cout << this->age << endl;
    }
    Stu& eat(char *foodName)
    {
        cout << name << "吃" << foodName << endl;
        return *this;
    }
};
int main(int argc, char *argv[])
{
    Stu s("张三","男",18);
    s.eat("凉皮").eat("肉夹馍").eat("甑糕");
    return 0;
}

const修饰成员函数(了解)

特点

        const修饰的成员函数内部不能对成员数据写操作, mutable 修饰的成员数据 除外。

实例

class Stu{
private:
    char name[50];
    char sex[10];
    int age;
    mutable int score;
public:
    Stu(){}
    Stu(char *name,char *sex,int age)
    {
        strcpy(this->name,name);
        strcpy(this->sex,sex);
        this->age = age;
    }
    void print_info()
    {
        cout << this->name << endl;
        cout << this->sex << endl;
        cout << this->age << endl;
    }
    Stu& eat(char *foodName)
    {
        cout << name << "吃" << foodName << endl;
        return *this;
    }
    void test() const
    {
    //age = 10;//错误
    score = 99;//正确
    }
};

友元函数(重要)

概述

关键字 :friend
可以声明 :
        1,全局函数
        2,成员函数
        3,类
注意 :
        友元打破c++ 的封装性。一般用于运算符重载

全局友元函数

特点

可以访问其友元类的任意成员 , 包括私有成员

步骤

1, 在定义并实例全局函数
2, 在类中声明步骤 1 中的函数为友元函数
3, 步骤 1 中定义的函数 , 可以访问步骤 2 中定义的类中的所有成员

示例

#include <iostream>
#include <cstring>
using namespace std;
class Stu{
friend void test(Stu &stu);
private:
    char name[50];
    char sex[10];
    int age;
public:
    Stu(){}
    Stu(char *name,char *sex,int age)
    {
        strcpy(this->name,name);
        strcpy(this->sex,sex);
        this->age = age;
    }
    void print_info()
    {
        cout << this->name << endl;
        cout << this->sex << endl;
        cout << this->age << endl;
    }
private:
    void eat(char *foodName)
    {
        cout << name << "吃" << foodName << endl;
    }
};
void test(Stu& stu)
{
//调用友元类的私有属性
    cout << stu.name << endl;
    cout << stu.sex << endl;
    cout << stu.age << endl;
//调用友元类的私有函数
    stu.eat("大嘴巴子");
}
int main(int argc, char *argv[])
{
    Stu s("张三","男",18);
    test(s);
    return 0;
}

成员友元函数

特点

        可以访问其友元类的任意成员, 包括私有成员

注意       

1, 成员函数作为友元 那么成员函数所在的类 必须定义到最上方
2, 成员函数所在的类的所有成员函数 必须在两个类的下方实现

步骤

        1,定义 B , 但不现实
        2,定义成员函数 A1 所在的类 A, 但其中只定义该成员函数 A1
        3,实现 B , 并在其中声明成员函数 A1 为友元函数
        4,实现成员函数

示例

#include <iostream>
#include <cstring>
using namespace std;
//定义B类,但是没有实现
class B;
class A{
public:
    void test(B& b);
};
class B{
friend void A::test(B& b);
private:
    int a;
public:
    B(int a)
    {
    this->a = a;
    }
private:
    void print_B()
    {
        cout << "a = " << a << endl;
    }
};
void A::test(B& b)
    {
        cout << b.a << endl;
        b.print_B();
    }
int main(int argc, char *argv[])
{
    A a;
    B b(10);
    a.test(b);
    return 0;
}

整个类作为友元函数

特点

        在B 中声明 A B 的友元类 , 此时 A 中任意成员函数中皆可直接访问 B 中的成员

步骤        

1, 定义 B
2, 定义并实现 A , 其中函数只定义不实现
3, 实现 B , 在其中声明 A 类为友元类
4, 实现 A 类中的成员函数

示例

#include <iostream>
#include <cstring>
using namespace std;
//定义B类,但是没有实现
class B;
class A{
public:
    void test01(B& b);
    void test02(B& b);
};
class B{
friend class A;
private:
    int a;
public:
    B(int a)
    {
        this->a = a;
    }
private:
    void print_B()
    {
        cout << "a = " << a << endl;
    }
};
void A::test01(B& b)
{
    cout << "test01" << endl;
    cout << b.a << endl;
    b.print_B();
}
void A::test02(B& b)
{
    cout << "test02" << endl;
    cout << b.a << endl;
    b.print_B();
}
int main(int argc, char *argv[])
{
    A a;
    B b(10);
    a.test01(b);
    cout << "--------------------" << endl;
    a.test02(b);
    return 0;
}

注意

1, 友元关系不能被继承。
2, 友元关系是单向的,类 A 是类 B 的朋友,但类 B 不一定是类 A 的朋友。
3, 友元关系不具有传递性。类 B 是类 A 的朋友,类 C 是类 B 的朋友,但类 C 不一
定是类 A 的朋友

实例

说明

遥控器类的对象可以操作电视机类对象的成员
所以遥控器类是电视机类的友元类

代码

#include <iostream>
#include <cstring>
using namespace std;
class TV;
class YK{
public:
    void up(TV& tv);
    void down(TV& tv);
};
class TV{
friend class YK;
private:
    int yl;
public:
    TV(){}
    TV(int yl)
    {
    this->yl = yl;
    }
};
void YK::up(TV &tv)
{
    tv.yl++;
    cout << "当前音量:" << tv.yl << endl;
}
void YK::down(TV &tv)
{
    tv.yl--;
    cout << "当前音量:" << tv.yl << endl;
}
int main(int argc, char *argv[])
{
    TV tv(10);
    YK yk;
    yk.up(tv);
    yk.up(tv);
    yk.up(tv);
    yk.down(tv);
    yk.down(tv);
    yk.down(tv);
    return 0;
}

string

c++ 字符串类 , 使其字符串操作方便
示例
#include <iostream>
#include <string>
using namespace std;
int main(int argc, char *argv[])
{
string str01 = "hello";
string str02 = str01;//字符串赋值
cout << str01 << endl;//字符串输出
cout << str02 << endl;
str02 = "world";
cout << str01 << endl;
cout << str02 << endl;
string str03 = str01 + str02;//字符串拼接
cout << str03 << endl;
string str04;
cin >> str04;//字符串输入
cout << str04 << endl;
string str05 = "Hi C++";
string str06 = "Hi C++";
string str07 = "Hi C";
cout << (str05 == str06) << endl;//判断字符串内容是否相同
cout << (str05 == str07) << endl;
cout << &str05 << endl;//打印str05地址
cout << &str06 << endl;//打印str06地址
return 0;
}

重载

引入

经源码查看 string 发现其也是一个类
那么为什么 string 的类对象可以使用 >>,<<,+,== 等运算符 , 我们自定义的类不行呢 ?
因为 string 类对运算符进行了重载
那我们如何实现运算符的重载

概述

作用

        是对已有的运算符重新进行定义,赋予其另一种功能,以适应不同的数据类型。

关键字

        operator

语法

        返回值类型 operator+ 运算符 ( 形参列表 )
        {
                函数体
        }
        如:
        >>
        void operator>>(形参列表 )
        {
        }
思路
1 、分析运算符的运算对象的个数
2 、分析运算符左边的运算对象是 自定对象 还是其他
左边:是其他 只能全局函数实现 (必须使用友元)
左边:自定义对象
可以用使用全局函数重载运算符(参数个数 和 运算符对象的个数一致)
也可以使用成员函数重载运算符(参数可以少一个) (推荐)

示例1:重载<<,>>运算符

效果
        使其可以通过<< 输出自定义类型的变量或通过 >> 输入自定义类型变量
分析
         << >> 符号左边为 cout cin 不是自定义对象 , 只能使用全局函数对其进行重载
示例
#include <iostream>
#include <cstring>
using namespace std;
class Data{
public:
    int x,y,z;
    Data(){}
    Data(int a,int b,int c):x(a),y(b),z(c){}
};
//第一个参数为运算符左边的变量
//第二个参数为运算符右边的变量
istream& operator >>(istream& in,Data& d)
{
    in >> d.x >> d.y >> d.z;
    return in;
}
ostream& operator <<(ostream& out,Data& d)
{
    out << "x = " << d.x << "\ty = " << d.y << "\tz = " << d.z << endl;
    return out;
}
int main(int argc, char *argv[])
{
    Data d;
    cin >> d;
    cout << d << endl;
    return 0;
}

示例2:重载+运算符

效果

        使用+ 运算符将自定义类型对象的属性一一相加

分析

        +符号左边为自定义类型 , 可以使用全局函数重载也可以使用成员函数中

示例:全局函数重载

#include <iostream>
using namespace std;
class Data{
public:
    int x,y,z;
    Data(){}
    Data(int a,int b,int c):x(a),y(b),z(c){}
};
//第一个参数为运算符左边的变量
//第二个参数为运算符右边的变量
Data* operator +(Data& d1,Data& d2)
{
    Data *d = new Data();
    d->x = d1.x + d2.x;
    d->y = d1.y + d2.y;
    d->z = d1.z + d2.z;
    return d;
}
int main(int argc, char *argv[])
{
    Data d1(1,2,3);
    Data d2(1,2,3);
    Data* d3 = d1 + d2;
    cout << d3->x << d3->y << d3->z << endl;
    return 0;
}
示例 2: 成员函数重载 + 运算符
#include <iostream>
using namespace std;
class Data{
public:
    int x,y,z;
    Data(){}
    Data(int a,int b,int c):x(a),y(b),z(c){}
//调用该函数的对象为运算符左边的变量
//参数为运算符右边的变量
Data* operator +(Data& d2)
{
    Data *d = new Data();
    d->x = this->x + d2.x;
    d->y = this->y + d2.y;
    d->z = this->z + d2.z;
    return d;
}
};
int main(int argc, char *argv[])
{
    Data d1(1,2,3);
    Data d2(1,2,3);
    Data* d3 = d1 + d2;
    cout << d3->x << d3->y << d3->z << endl;
    return 0;
}

示例3:重载==运算符

效果
        比较类中成员变量值是否相同
分析
        符号左边为自定义类型, 可以使用全局函数重载也可以使用成员函数中
示例
#include <iostream>
using namespace std;
class Data{
public:
    int x,y,z;
    Data(){}
    Data(int a,int b,int c):x(a),y(b),z(c){}
//调用该函数的对象为运算符左边的变量
//参数为运算符右边的变量
    bool operator ==(Data& d2)
    {
        if(this->x == d2.x && this->y == d2.y && this->z == d2.z)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
};
int main(int argc, char *argv[])
{
    Data d1(1,2,3);
    Data d2(1,2,3);
    Data d3(2,2,3);
    cout << (d1 == d2) << endl;
    cout << (d1 == d3) << endl;
    return 0;
}

示例4:重载++运算符

注意

++ 运算符分为 ++ 在前与 ++ 在后两种所以需要重载两种
当编译器看到 ++a( 前置 ++), 它就调用 operator++(Type& a)( 全局函数 ),operator++
()( 成员函数 )
当编译器看到 a++( 后置 ++), 它就会去调用 operator++(Type& a,int)( 全局函
),operator++(int)( 成员函数 )

示例

#include <iostream>
using namespace std;
class Data{
public:
    int x,y,z;
    Data(){}
    Data(int a,int b,int c):x(a),y(b),z(c){}
    Data& operator ++()//++前置
    {
        ++x;
        ++y;
        ++z;
    return *this;
    }
    Data operator ++(int)//++后置
    {
        Data old = *this;//记录旧值
        ++x;
        ++y;
        ++z;
    return old;//返回旧值
    }
};
ostream& operator <<(ostream& out,Data& d)
{
    out << d.x << d.y << d.z << endl;
    return out;
}
int main(int argc, char *argv[])
{
    Data d1(1,2,3);
    ++d1;
    cout << d1;
    Data d2(1,2,3);
    Data d3 = d2++;
    cout << d3;
    cout << d2;
    return 0;
}

示例5:重载*->

要求

        重载指针运算符实现智能指针

推演

#include <iostream>
using namespace std;
class Data{
private:
    int x,y,z;
public:
    Data(){
    cout << "无参构造函数" << endl;
    }
    Data(int a,int b,int c):x(a),y(b),z(c){
        cout << "有参构造函数" << endl;
    }
    ~Data()
    {
        cout << "析构函数" << endl;
    }
};
int main(int argc, char *argv[])
{
    Data *p = new Data();
    return 0;
}
观察以上代码 , 我们发现创建的对象没有被销毁 , 但是我们在编写代码时经常会忘记销
, 那该怎么办呢 ?
解决方案如下
#include <iostream>
using namespace std;
class Data{
private:
int x,y,z;
public:
    Data(){
        cout << "无参构造函数" << endl;
    }
    Data(int a,int b,int c):x(a),y(b),z(c){
        cout << "有参构造函数" << endl;
    }
    ~Data()
    {
        cout << "析构函数" << endl;
    }
};
class FreeData{
private:
    Data* p;
public:
    FreeData(){
    p = NULL;
    }
    FreeData(Data* data){
        p = data;
    }
    ~FreeData(){
        if(p != NULL)
        {
            delete p;
            p = NULL;
        }
    }
};
int main(int argc, char *argv[])
{
    FreeData fd(new Data(1,2,3));
    return 0;
}
现在我们发现 Data 对象可以销毁 , 但是如何调用其对象中的属性呢 ?
方案如下
#include <iostream>
using namespace std;
class Data{
private:
    int x,y,z;
public:
    Data(){
    cout << "无参构造函数" << endl;
    }
    Data(int a,int b,int c):x(a),y(b),z(c){
        cout << "有参构造函数" << endl;
    }
    ~Data()
    {
        cout << "析构函数" << endl;
    }
    int getX()
    {
        return x;
    }
};
class FreeData{
private:
    Data* p;
public:
    FreeData(){
        p = NULL;
    }
    FreeData(Data* data){
        p = data;
    }
    ~FreeData(){
        if(p != NULL)
        {
            delete p;
            p = NULL;
        }
    }
    Data& operator *()
    {
        return *p;
    }
    Data* operator ->()
    {
        return p;
    }
};
int main(int argc, char *argv[])
{
    FreeData fd(new Data(1,2,3));
    cout << (*fd).getX() << endl;
    cout << fd->getX() << endl;
    return 0;
}

示例6:重载()

作用

当类对象作为函数调用时,会执行 operator()( 参数列表 ) 函数。
对象作为函数调用
对象名 ( 实参列表 );
一种仿函数

示例

#include <iostream>
using namespace std;
class Data{
friend ostream& operator <<(ostream& out,Data& d);
private:
    int x,y,z;
public:
    Data(){
    cout << "无参构造函数" << endl;
    }
    Data(int a,int b,int c):x(a),y(b),z(c){
        cout << "有参构造函数" << endl;
    }
    ~Data()
    {
        cout << "析构函数" << endl;
    }
    void operator ()(int a,int b,int c){
        this->x += a;
        this->y += b;
        this->z += c;
    }
};
ostream& operator <<(ostream& out,Data& d)
{
    out << d.x << "\t" << d.y << "\t" << d.z << endl;
    return out;
}
int main(int argc, char *argv[])
{
    Data d(1,2,3);
    d(2,5,8);
    cout << d;
    return 0;
}

示例7:重载=

注意
= 重载时,可能会调用类本身的拷贝构造函数。
如果左值是没有创建的对象时 , 会调用拷贝构造函数 .
如果左值是已创建的类对象 , 会执行 = 重载函数 , 实现数据的拷贝
示例
#include <iostream>
using namespace std;
class Data{
friend ostream& operator <<(ostream& out,Data& d);
private:
    int x,y,z;
public:
    Data(){
        cout << "无参构造函数" << endl;
    }
    Data(int a,int b,int c):x(a),y(b),z(c){
        cout << "有参构造函数" << endl;
    }
    Data(const Data& d)
    {
        cout << "执行拷贝构造" << endl;
        this->x = d.x;
        this->y = d.y;
        this->z = d.z;
    }
    ~Data()
    {
        cout << "析构函数" << endl;
    }
    void operator =(Data& d){
        cout << "执行重载=运算符的函数" << endl;
        this->x = d.x;
        this->y = d.y;
        this->z = d.z;
    }
};
ostream& operator <<(ostream& out,Data& d)
{
    out << d.x << "\t" << d.y << "\t" << d.z << endl;
    return out;
}
int main(int argc, char *argv[])
{
    Data d1(1,2,3);
    Data d2(3,6,9);
    d1 = d2;//d1已完成初始化,执行重载的=号运算符
    Data d3 = d2;//d3未完成初始化,执行拷贝构造
    return 0;
}

注意:

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

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

相关文章

羊大师教你如何有效解决工作中的挑战与压力?

在现代社会&#xff0c;工作问题一直是许多人头疼的难题。无论是从工作压力到职业发展&#xff0c;工作问题不仅会影响个人的心理健康&#xff0c;还可能对整个工作团队的效率和和谐产生负面影响。因此&#xff0c;如何有效解决工作问题成为了每个职场人士都需要面对的挑战。 …

什么是Zero-shot(零次学习)

1 Zero-shot介绍 Zero-shot学习&#xff08;ZSL&#xff09;是机器学习领域的一种先进方法&#xff0c;它旨在使模型能够识别、分类或理解在训练过程中未见过的类别或概念。这种学习方法对于解决现实世界中常见的长尾分布问题至关重要&#xff0c;即对于一些罕见或未知类别的样…

vue2指令的使用和自定义指令

前言 个人认为vue的指令,对比react来说,给开发者节省了很大的学习成本。比如在react中,你想渲染一个列表,需要用Array.map的方法return<div>,而在vue中,一个简单的v-for就解决了问题。 在学习成本和入手体验上,vue的作者确实后来者居上,能让人更快的使用vue开发。不过也…

vs调试输出,不显示线程已退出

如题&#xff1a;一堆线程退出的信息&#xff0c;招人烦。 其实在vs设置里可以关闭&#xff1a; 工具-->选项-->调试-->输出窗口&#xff1a;

【Linux】权限的理解和使用

&#x1f466;个人主页&#xff1a;Weraphael ✍&#x1f3fb;作者简介&#xff1a;目前正在学习c和算法 ✈️专栏&#xff1a;Linux &#x1f40b; 希望大家多多支持&#xff0c;咱一起进步&#xff01;&#x1f601; 如果文章有啥瑕疵&#xff0c;希望大佬指点一二 如果文章对…

Linux程序之可变参数选项那些事!

一、linux应用程序如何接收参数&#xff1f; 1. argc、argv Linux应用程序执行时&#xff0c;我们往往通过命令行带入参数给程序&#xff0c;比如 ls /dev/ -l 其中参数 /dev/ 、-l都是作为参数传递给命令 ls 应用程序又是如何接收这些参数的&#xff1f; 通常应用程序都…

程序的执行原理(上)

文章目录 hello world程序源文件的本质是0和1hello world文件的ASCII表示程序被其他程序翻译成不同的格式预处理阶段编译阶段汇编阶段链接阶段 为什么需要了解编译系统的工作原理&#xff1f;优化程序性能理解链接时出现的错误避免安全漏洞 运行程序参考 hello world 程序源文件…

基于ZLMediaKit的GB28181视频平台demo

GB28181 主要内容 国标的20位id是按照标准来定的&#xff0c;前8位是地域信息&#xff0c;9-10位是行业信息&#xff0c;11-13是设备类型、14是网络标识、后6位为序号 约定以SIP协议作为会话通道的使用标准&#xff0c;以RTP作为语言和视频的载体。联网系统在进行音视频传输及…

AQS和ReentrantLock还能这样理解?

1.公平锁和非公平锁 1.1含义 公平锁:在竞争环境下&#xff0c;先到临界区的线程比后到的线程一定更快地获取得到锁。非公平锁:先到临界区的线程未必比后到的线程更快地获取得到锁。 1.2如何自我实现 公平锁实现&#xff1a;可以把竞争的线程放在一个先进先出的队列上。只要…

webpack plugin

1、基本写法及使用 这里用到 emit 钩子 及make 钩子&#xff0c;前者是串行后者是并行 /*** 1.webpack加载webpack.config.js中所有配置&#xff0c;此时就会new TestPlugin()&#xff0c;执行插件的constructor2.webpack创建compiler对象3.遍历所有plugins中插件&#xff0…

404 - File or directory not found.

iis部署的时候容易出现以下错误&#xff0c;造成的主要原因可能是IIS没有安装好某个组件或插件: 04-找不到文件或目录。 您要查找的资源可能已被删除、名称已更改或暂时不可用。 如果遇到该问题&#xff0c;安装iis的时候记得安装以下

AIGC ChatGPT4总结SQL优化细节操作

数据库SQL优化是一个复杂的过程,它通常涉及到许多不同的技术和方法。以下是一些常用的SQL优化策略: 1. **索引使用**:索引可以极大地加速查询速度。但是,索引并不总是有好处的,因为它们需要额外的空间来存储,并且在插入和更新数据时可能会减慢速度。因此,选择正确的字段…

【C++】类和对象——构造函数和析构函数

今天要学习两个特殊的函数&#xff0c;分别是构造函数和析构函数&#xff0c;它们究竟有什么用呢&#xff1f; 比如说&#xff0c;我们先写一个简单的日期的类 class Date { public:void Init() {_year 1;_month 1;_day 1;}void Print() {cout << _year << &qu…

字符串和内存函数(2)

文章目录 2.13 memcpy2.14 memmove2.15 memcmp2.16 memset 2.13 memcpy void* memcpy(void* destination, const void* source, size_t num); 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。这个函数在遇到 ‘\0’ 的时候并不会停下来。如果so…

企业计算机服务器中了locked勒索病毒怎么办,勒索病毒解密恢复

计算机网络为企业的生产生活提供了极大帮助&#xff0c;让企业逐步走向数字化办公&#xff0c;但随之而来的网络安全威胁也不断增多&#xff0c;网络勒索病毒病毒攻击企业计算机的事件频发&#xff0c;并且攻击加密手段也在不断提升。近期&#xff0c;云天数据恢复中心再次接到…

接口测试 —— requests 的基本了解

● requests介绍及安装 ● requests原理及源码介绍 ● 使用requests发送请求 ● 使用requests处理响应 ● get请求参数 ● 发送post请求参数 ● 请求header设置 ● cookie的处理 ● https证书的处理 ● 文件上传、下载 requests介绍 ● requests是python第三方的HTTP…

python -opencv 中值滤波 ,均值滤波,高斯滤波实战

python -opencv 中值滤波 &#xff0c;均值滤波&#xff0c;高斯滤波实战 cv2.blur-均值滤波 cv2.medianBlur-中值滤波 cv2.GaussianBlur-高斯滤波 直接看代码吧&#xff0c;代码很简单&#xff1a; import copy import math import matplotlib.pyplot as plt import matp…

第二十章 多线程

20.2创建线程 20.2.1继承Thread类 Thread类是Java.lang包中的一个类&#xff0c;从这个类中实例化的对象代表线程&#xff0c;程序员启动一个新线程需要建议Thread实例。 public class ThreadTest extedns Thread{} run方法格式&#xff1a; public void run(){} 20.1让线…

论设备管理的发展趋势及对策

作者&#xff1a;韩平 设备是企业生产要素的一个重要组成部分&#xff0c;是企业进行生产活动的物质硬件基础&#xff0c;也是决定企业生产效能的重要因素之一。 设备管理又称设备工程&#xff0c;是根据企业生产经营目标&#xff0c;为了提高设备效能&#xff0c;在调查研究…

主播产品话术

以电子产品为例 一、产品特点 1.高效性能:这款产品采用了最先进的技术&#xff0c;确保高效运行&#xff0c;让你的工作更加流畅。 2.便捷操作:设计简洁&#xff0c;操作方便&#xff0c;即使是不熟悉电子产品的人也能轻松上手。 3.时尚外观:多种颜色可选&#xff0c;满足你…