【C++初阶】之类和对象(中)

【C++初阶】之类和对象(中)

  • ✍ 类的六个默认成员函数
  • ✍ 构造函数
    • 🏄 为什么需要构造函数
    • 🏄 默认构造函数
    • 🏄 为什么编译器能自动调用默认构造函数
    • 🏄 自己写的构造函数
    • 🏄 构造函数的特性
  • ✍ 拷贝构造函数
    • 🏄 编译器默认生成的拷贝构造函数
    • 🏄 自己写的拷贝构造函数
    • 🏄 拷贝构造函数调用的场景
  • ✍ 赋值运算符重载(也叫拷贝赋值函数)
    • 🏄 运算符重载的引入
      • 💘 前置++和后置++重载
      • 💘 运算符重载函数的调用
    • 🏄 赋值运算符重载
      • 💘 编译器默认生成的赋值运算符重载函数
      • 💘 自己显示写的赋值运算符重载函数
  • ✍ 析构函数
    • 🏄 编译器默认生成的析构函数
    • 🏄 显式写的析构函数
    • 🏄 析构函数的特性
    • 🏄 没有深拷贝,导致二次释放同一空间问题
      • 💘 问题的引入---拷贝构造函数
      • 💘 问题的解决---深拷贝
      • 💘 赋值运算符重载函数的浅拷贝问题
  • ✍ const成员函数
    • 🏄 const对象访问的规则
    • 🏄 非const对象访问的规则
  • ✍ 对普通对象的取地址运算符重载和对const对象取地址运算符重载
  • ✍ C++默认构造函数提供的机制
    • 🏄 C++默认构造函数是否提供的情况

📃博客主页: 小镇敲码人
💞热门专栏:C++初阶
🚀 欢迎关注:👍点赞 👂🏽留言 😍收藏
🌏 任尔江湖满血骨,我自踏雪寻梅香。 万千浮云遮碧月,独傲天下百坚强。 男儿应有龙腾志,盖世一意转洪荒。 莫使此生无痕度,终归人间一捧黄。🍎🍎🍎
❤️ 什么?你问我答案,少年你看,下一个十年又来了 💞 💞 💞

✍ 类的六个默认成员函数

当类为空是编译器也不是什么都不生成,而是会生成六大默认成员函数。

在这里插入图片描述
我们也可以自己显式把这六个默认成员写出来,这样编译器就会调用我们自己的,而不会调用默认生成的。

✍ 构造函数

🏄 为什么需要构造函数

我们学习C语言的时候,初始化栈操作需要自己写一个Init函数,但是这样就很麻烦,因为初始化栈之后需要我们显示的去调用Init函数,否则就有可能出现野指针的情况,因为如果是链式的栈,要把next指针初始化为空。

🏄 默认构造函数

我们构造函数就是为了解决这样的问题,在初始化类的时候,
你不需要显示的调用Init函数,编译器会自动的去调用,如果你不去显示的写,

编译器会生成一个默认的构造函数。我们来验证一下。
class Date
{
private:int year;int day;int month;
};
int main()
{Date x;return 0;
}

此时我们写了一个Date类,编译器会给调用它的默认构造函数吗?运行结果:

在这里插入图片描述

怎么回事呢?x对象的值没有被初始化呀,那是不是代表编译器没有调用默认构造函数呢?其实不然,C++把类型分为自定义类型和内置类型,默认构造函数要做的是,自定义类型去调用它自己的构造函数(如果有的话),内置类型去给一个随机值,那到底是不是这样呢?我们也可以来验证一下。

class year
{
public:year(){std::cout << "year()" << std::endl;}
};
class Date
{
private:year y;int day;int month;
};
int main()
{Date x;return 0;
}

注意:那个自定义类型的构造函数必须是public的,否则在它自己的类外面就访问不了。

在这里插入图片描述
运行结果:

在这里插入图片描述

默认构造函数默认成员函数是两个不同的概念,两者不能混淆,不用我们传参数,全缺省构造函数和无参数构造函数、默认生成的构造函数都称作为默认构造函数。

class Date
{
public:Date(){day = 0;month = 0;}Date(int day = 0,int month = 0){}
private:year y;int day;int month;
};
int main()
{Date x;return 0;
}

注意:上面那两个默认构造函数不能同时存在,因为都不需要传参数,会造成歧义,编译器不知道调用哪一个默认构造函数。

在这里插入图片描述

🏄 为什么编译器能自动调用默认构造函数

那为什么编译器能在实例化类对象的的时候自动调用它的构造函数呢?

可以认为这是编译器做了特殊的处理,它帮助我们调用了这个函数。我们转到反汇编,可以发现编译器帮助我们调用了。

在这里插入图片描述

🏄 自己写的构造函数

我们也可以自己显示的写构造函数,那样编译器就不会去调用默认生成的构造函数了。


class year
{
public:year(){std::cout << "year()" << std::endl;}
};
class Date
{
public:Date(){day = 0;month = 0;}
private:year y;int day;int month;
};
int main()
{Date x;return 0;
}

运行结果:

在这里插入图片描述

可以看到,编译器在我们自己写的构造函数进去前,仍然会先去调用自定义类型的构造函数。

🏄 构造函数的特性

1、一次实例化对象只会调用一次,不支持显示调用。

在这里插入图片描述

2、构造函数会在实例化对象的时候自动调用,只用于初始化对象的一些成员变量,是初始化对象,而不是给对象开空间。

3、函数名和类名相同,无返回值。

4、支持重载。

✍ 拷贝构造函数

拷贝构造函数是构造函数的一种,主要作用是实现用一个已经存在的类对象,去初始化创建另外一个类对象。

🏄 编译器默认生成的拷贝构造函数

和前面普通的构造函数一样,如果我们不写编译器就会默认生成。

class year
{
public:year(){std::cout << "year()" << std::endl;}
};
class Date
{
public:Date(){day++;month++;}void f(){}
private:year y;int day = 0;int month = 0;
};
int main()
{Date x;Date y(x);return 0;
}

运行结果:

在这里插入图片描述

那我们为什么要写呢?这样岂不是浪费时间多次一举吗,编译器都帮助我们写好了,我们有时候的确是不需要写的,比如在没有向堆申请空间的时候,这时不涉及资源的清理,浅拷贝不会出问题,但是一旦我们向堆上申请空间后,不自己写深拷贝的拷贝构造函数,就会造成二次释放相同空间的问题。

🏄 自己写的拷贝构造函数

Date(const Date& x)
{day = x.day;month = x.month;y = x.y;
}

这里加上const是因为我们只是用x去初始化,但不希望改变它的值,至于这里为什么要使用引用,而且必须使用引用否则就会引发无穷递归:

在这里插入图片描述

这是因为我们在传参的时候,实参和形参的关系是,形参是实参的拷贝(当两者类型一样时),这不就相当于使用实参去初始化形参吗(也就是一个类去初始化另外一个类),也要调用拷贝构造函数,下一次又是一样的情况,所以会造成无穷递归,但是加了引用,你这个形参就是我实参的别名,不用再去调用拷贝构造,也就不会出现这种问题。

🏄 拷贝构造函数调用的场景

刚刚我们其实已经说了两个场景了。

1、用一个创建好的类初始化另外一个没有初始化的类
2、函数传参(参数为自定义类型)
3、函数返回值(参数为自定义类型),2和3都不能带引用,否则就不会调用拷贝构造函数。
4、赋值运算符重载时,被赋值的类还没有创建。

✍ 赋值运算符重载(也叫拷贝赋值函数)

我们的内置类型可以支持,一个变量赋值给另外一个对象,比如:a = b(都是int类型),那我们类(自定义类型)支持吗,答案是肯定的,使用运算符重载就可以解决这个问题。

🏄 运算符重载的引入

在C++中,增加了运算符的重载,这是因为有时候自定义类型也需要做一些类似操作符的操作,引入运算符重载,极大的提升了代码的可读性,它的规则如下:

  1. 函数名为operator后面接需要重载的运算符,注意:不能重载一些莫名奇妙的符号像@。
  2. 函数原型:返回值类型 operator操作符(参数列表)

注意:运算符重载时必须要有一个自定义类型的参数,因为运算符重载就是为类而生的,如果你没有类参数,那就没有意义了。

在这里插入图片描述
编译器为了防止你乱搞,会报错的。上面是全局的运算符重载函数。

有时候有的运算符需要两个参数,但是我们在类里面设计的时候只有一个参数,实际上是有两个参数的,第一个参数传的是this指针,编译器给隐藏了

💘 前置++和后置++重载

我们来介绍一下两个特殊的运算符重载,前置++和后置++重载,这两个操作符名字都一样,该如何区分呢?

这里没有办法了,C++对其做了特殊的处理,即给后置++多传一个参数来去区分,并且++操作符重载,最多额外传一个int参数作区分,也是为了防止用户乱搞。

我们来实现一下Date类的前置++和后置++:

// 前置++运算符  
// 该运算符将对象的年份、月份和日期都递增1,并返回递增后的对象的引用  
Date& operator++() // 前置++  
{  year++;       // 递增年份  day++;        // 递增日期  month++;      // 递增月份  return *this; // 返回当前对象的引用  
}  Date operator++(int) // 后置++  
{  Date tmp(*this); // 创建当前对象的副本  ++(*this);       // 递增当前对象(使用前置++)  return tmp;      // 返回递增前的对象的副本  
}

这里实际上我们在++日期的时候要考虑月份和年份的变化,这里我们主要是学习语法就不考虑了。
注意后置++的返回值不能带引用。因为我们返回的是副本,但是副本是临时对象(出了作用域销毁了),所以我们需要返回一个副本的拷贝,而不是副本本身。

  • 注意这里即使我们运算符重载函数写成全局的,也能像内置类型那样调用:
using namespace std;
class Date
{
public:Date(int year, int month = 2, int day = 1) ://普通的构造函数year_(year),month_(month),day_(day){cout << "Date(int year, int month = 2, int day = 1)" << endl;}Date(const Date& x) ://拷贝构造函数year_(x.year_),month_(x.month_),day_(x.day_){cout << "Date(const Date& x)" << endl;}Date& operator=(const Date& x)//拷贝赋值函数{year_ = x.year_;month_ = x.month_;day_ = x.day_;cout << "operator=(const Date& x)" << endl;return *this;}~Date()//析构函数{cout << "~Date" << endl;}
public:int year_;int month_;int day_;
};// 前置++运算符  
// 该运算符将对象的年份、月份和日期都递增1,并返回递增后的对象的引用  
Date& operator++(Date& x) // 前置++  
{x.year_++;       // 递增年份  x.day_++;        // 递增日期  x.month_++;      // 递增月份  return x; // 返回当前对象的引用  
}Date operator++(Date&x,int) // 后置++  
{Date tmp(x); // 创建当前对象的副本  ++x;       // 递增当前对象(使用前置++)  return tmp;      // 返回递增前的对象的副本  
}int main()
{Date x(2022);x++;++x;
}

运行结果:

在这里插入图片描述
代码正常运行。

如果我们给++运算符重载函数增加其它类型的参数,编译器就会报错:

在这里插入图片描述

💘 运算符重载函数的调用

内置类型可以直接a = b,或者a++,那我们的自定义类型是否可以这样了,为了可读性和方便,我们的C++支持这样来调用运算符重载函数,我们拿刚刚的前置++、和后置++函数来演示。

int main()
{Date x;x++;//-->operator++(&x,1);++x;//-->operator++(&x);return 0;
}

我们转到反汇编可以发现,确实是调用了对应的函数。

在这里插入图片描述
也可以显示调用,注意这里编译器已经帮助我们传了this指针过去,所以这里我们显示调用的是后置++:

在这里插入图片描述

🏄 赋值运算符重载

回归正题,我们继续来看我们的赋值运算符重载函数。

💘 编译器默认生成的赋值运算符重载函数

当我们不去显示的写赋值运算符重载函数,编译器会默认生成一个。

在这里插入图片描述

但是当我们这样去写,被赋值的y还没有被创建这个时候编译器就会去调用拷贝构造函数,无论你有没有自己显式的写

在这里插入图片描述

💘 自己显示写的赋值运算符重载函数

下面我们来自己显示的写一下,还是会有深拷贝的问题,当我们类的成员变量有在堆上申请空间时,直接赋值会引发二次析构的问题。

// 赋值运算符重载函数  
// 将参数x的值赋给当前对象,并返回当前对象的引用  
Date& operator=(const Date& x)  
{  if (this != &x) // 检查自赋值  {  day = x.day;  month = x.month;  year = x.year;  }  return *this;  
}

现代写法:

这种写法在拷贝构造函数处理好深拷贝问题后,可以很好的实现深拷贝,因为我们这种写法本质是对拷贝构造函数的一个复用。

Date& operator=(const Date& x)  
{  // 检查自赋值,避免不必要的操作  if (this != &x)  {  // 创建一个临时Date对象tmp,并使用参数x来初始化它  Date tmp(x);  // 使用std::swap来交换tmp对象的day成员和当前对象的day成员  std::swap(tmp.day, this->day);  // 使用std::swap来交换tmp对象的year成员和当前对象的year成员  std::swap(tmp.year, this->year);  // 使用std::swap来交换tmp对象的month成员和当前对象的month成员  std::swap(tmp.month, this->month);  // 通过上述交换,实际上是将tmp对象(即x的副本)的内容赋给了当前对象  }  // 返回当前对象的引用,以支持链式赋值操作  return *this;  
}

在这里插入图片描述

运行结果:

在这里插入图片描述

✍ 析构函数

有初始化资源的函数,就会有清理资源的函数。析构函数和构造函数一样,它是在当前作用域结束后就会自动调用析构函数。它的函数名字不一样,类名前面多了一个~

🏄 编译器默认生成的析构函数

一般情况下编译器也会默认生成一个析构函数,当我们的成员变量都没有申请资源时就不需要显示的写析构函数。

🏄 显式写的析构函数

	~Date(){year = 0;day = 0;month = 0;}

在这里插入图片描述

🏄 析构函数的特性

1、当前函数作用域结束后自动调用
2、无参数,无返回值
3、函数名是~+类名。
4、功能是清理对象中的资源而不是释放对象的空间。
5、支持显示调用,构造函数不支持。

在这里插入图片描述

🏄 没有深拷贝,导致二次释放同一空间问题

💘 问题的引入—拷贝构造函数

前面在讲拷贝构造函数和赋值构造函数,我们就对这个问题做了铺垫,这个问题的本质就和标题一样,内存重复释放,为什么会这样,本质还是万恶的值拷贝!下面我们写一段代码来解释并解决这个问题。

class Stack
{
public:Stack(){_capacity = 4;//假设开始的时候给容量设置为4_top = 0;_a = (int*)malloc(sizeof(int) * _capacity);if (_a == nullptr){std::cout << "malloc Failed" << std::endl;exit(-1);}}~Stack(){std::cout << " ~Stack" << std::endl;_capacity = 0;_top = 0;free(_a);_a = nullptr;}
private:int* _a;int _top;		// 栈顶int _capacity;  // 容量 
};int main()
{Stack st1;Stack st2(st1);return 0;
}

运行结果:

在这里插入图片描述

是的,程序在这里崩溃了,我们来调试一下。

在这里插入图片描述

可以看到st1中的_a、和st2中的_a保存的地址值是一模一样,释放了两次相同空间的地址。

在这里插入图片描述

💘 问题的解决—深拷贝

那么我们如何规避这种情况呢,就要用到深拷贝,我们可以开和st1中_a指向空间一样大小的数组,并把_a指向空间的值赋值给我们的数组。

在这里插入图片描述
代码实现:

// Stack类的拷贝构造函数  
// 接收一个对Stack类型的常量引用st作为参数,用于复制对象  
Stack(const Stack& st)  
{  // 为栈的底层数组_a分配内存,大小与源栈st的容量相同  _a = (int*)malloc(sizeof(int) * (st._capacity));  // 检查内存是否分配成功  if (_a == nullptr)  {  // 如果分配失败,则输出错误信息并退出程序  std::cout << "内存分配失败" << std::endl;  exit(-1);  }  // 使用memcpy函数将源栈st的底层数组内容复制到当前栈的底层数组_a中  memcpy(_a, st._a, sizeof(int) * (st._capacity));  // 复制源栈st的栈顶指针_top到当前栈  _top = st._top;  // 复制源栈st的容量_capacity到当前栈  _capacity = st._capacity;  
}

运行结果:

在这里插入图片描述

此时不再报错。

调试结果:

在这里插入图片描述
保存的地址不同(指向的空间不同),但是数组中的值相同,完成了拷贝构造(深拷贝)。

💘 赋值运算符重载函数的浅拷贝问题

使用编译器默认的值拷贝,去赋值,在刚刚的场景也会报错。

int main()
{Stack st1;Stack st2;st2 = st1;return 0;
}

在这里插入图片描述

我们可以使用赋值运算符重载函数现代写法来复用刚刚拷贝构造函数写好的深拷贝。

// Stack类的赋值运算符重载  
// 接收一个对Stack类型的常量引用st作为参数,用于赋值操作  
Stack& operator=(const Stack& st)  
{  // 检查是否自赋值,即当前对象与参数对象是否为同一个对象  if (this != &st)  {  free(_a);//释放之前_a的内存// 创建一个临时Stack对象tmp,并用参数对象st初始化  Stack tmp(st);  // 使用std::swap交换临时对象tmp的底层数组与当前对象的底层数组  std::swap(tmp._a, _a);  // 使用std::swap交换临时对象tmp的栈顶指针与当前对象的栈顶指针  std::swap(tmp._top, _top);  // 使用std::swap交换临时对象tmp的容量与当前对象的容量  std::swap(tmp._capacity, _capacity);  }  // 返回当前对象的引用,支持链式赋值操作  return *this;  
}

运行结果:

在这里插入图片描述

调试结果:

在这里插入图片描述
与预期一致。

✍ const成员函数

使用const关键字修饰的函数(放在函数括号右边)叫做const成员函数,const实际是修饰的this指针指向的内容,所以其指向的内容不能修改。

请看下面的代码:

class Date
{
public:Date(){year = 2024;month = 1;day = 1;}void f() const{this->year = 1;}
private:int year;int month;int day;
};int main()
{Date x;
}

在这里插入图片描述

🏄 const对象访问的规则

1、const对象不能访问非const类型的函数,但是可以构造函数和析构函数例外。这很好理解,因为我们的const修饰对象,对象的内容不能被修改,如果你能调用非const函数,在这个函数里修改了我们的成员变量,那不就逻辑不自洽了嘛。

在这里插入图片描述
const对象访问构造函数。

也不能对析构或者构造函数使用const修饰。

在这里插入图片描述

const对象访问析构函数。

在这里插入图片描述

const对象访问非const函数是非法的。

在这里插入图片描述

2、const成员函数类也不能调用其它的非const的成员函数。

在这里插入图片描述

本质上是一样的问题const Date* const this类型不能转变为Date* const this,否则它的能力就扩大了。

  • 注意前面的const修饰的是*this,表示this指向的内容具有常性,后面的const修饰this指针,表示this指针的值不能被修改。

🏄 非const对象访问的规则

3、但是非const成员函数内可以调用const成员函数。

在这里插入图片描述
程序正常退出。

4、非const对象也可以调用const函数。

在这里插入图片描述

3和4总结起来也是一样的,Date* const this类型可以向const Date* const this类型转化。

✍ 对普通对象的取地址运算符重载和对const对象取地址运算符重载

这两个函数一般都不需要我们显示的去写,编译器会默认生成的。

在这里插入图片描述

我们也可以显示的写出来。

// 非const成员函数的取地址运算符重载  
// 返回当前对象的地址  
Date* operator&()  
{  return this;  
}// const成员函数的取地址运算符重载  
// 返回当前对象的const地址  
const Date* operator&() const  
{  return this;  
}

但是通常只有我们有一些特殊的需求比如取出某个特定成员变量的地址时,才需要自己显示的去写。

✍ C++默认构造函数提供的机制

部分内容参考博主这篇博客C++默认构造函数提供的机制。

我们都知道,在C++98中,有着这样的几种构造函数:普通构造函数、析构函数、拷贝构造函数、赋值运算符重载函数。

生成这些特殊的成员函数(或者不生成)的规则比较复杂,编译器默认生成的构造函数是有可能被删除的。

🏄 C++默认构造函数是否提供的情况

  1. 如果自定义了普通构造函数和拷贝构造函数,系统将不再提供默认的无参构造函数。

在这里插入图片描述
但是如果定义了一个赋值运算符重载函数,系统还是会提供普通的无参构造函数。

在这里插入图片描述

2、如果自定义了一个普通的构造函数,系统还会提供一个拷贝构造函数和赋值运算符重载函数(值拷贝)。

  1. 如果自定义了一个拷贝构造函数,系统将不再提供默认的拷贝构造函数。但是会生成默认的赋值运算符重载函数。

在这里插入图片描述
4、如果自定义了一个赋值运算符重载函数,系统就不会默认生成赋值运算符重载函数了,但是其它函数还是会生成。

在这里插入图片描述
在这里插入图片描述
这里少打字了,应该是无参的构造函数。

没有生成报错是这样的:

在这里插入图片描述

  1. 如果自定义了一个析构函数,系统也就不会再提供默认的析构函数。

  2. 如果类里面有没有初始化的非静态const数据成员或者引用类型的数据成员,会导致默认提供的默认构造函数被删除。

在这里插入图片描述
当我们使用初始化列表初始化好这两个变量好,发现去调用拷贝构造函数是可以的(编译器默认生成了),但是拷贝赋值函数却被删除了。

在这里插入图片描述
在这里插入图片描述

6.用户如果自己没有提供一个拷贝构造函数或者拷贝赋值函数,编译器会隐式声明一个。

在这里插入图片描述

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

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

相关文章

淘宝商品评论抓取技术大揭秘:轻松获取用户评价,助力电商决策!

获取淘宝商品评论接口的技术实现涉及多个步骤&#xff0c;包括获取商品ID、构建请求URL、发送HTTP请求以及解析响应数据。以下是一个基本的指南和示例代码&#xff0c;帮助你了解如何实现这一功能。 步骤一&#xff1a;获取商品ID 首先&#xff0c;你需要知道你想要获取评论的…

fuzzywuzzy,一个好用的 Python 库!

目录 前言 安装 基本功能 1. 字符串相似度比较 2. 模糊匹配与排序 实际应用场景 1. 数据清洗 2. 文本匹配与搜索 3. 搜索引擎优化 总结 前言 大家好&#xff0c;今天为大家分享一个好用的 Python 库 - fuzzywuzzy Github地址&#xff1a;https://github.com/seatgeek/fu…

Stable Diffusion WebUI 图生图(img2img):图生图/涂鸦绘制/局部重绘/有色蒙版/上传蒙版/批量处理/反推提示词

本文收录于《AI绘画从入门到精通》专栏&#xff0c;专栏总目录&#xff1a;点这里&#xff0c;订阅后可阅读专栏内所有文章。 大家好&#xff0c;我是水滴~~ 本篇文章我们介绍 Stable Diffusion WebUI 的图生图功能&#xff0c;主要包括&#xff1a;图生图、图生图&#xff08…

Spring-IoC-属性注入的注解实现

1、创建对象的注解 Component 用于声明Bean对象的注解&#xff0c;在类上添加该注解后&#xff0c;表示将该类创建对象的权限交给Spring容器。可以直接将这些类直接创建&#xff0c;使用的时候可以直接用。 注解的value属性用于指定bean的id值&#xff0c;value可以省略&…

BioXcell InVivoPlus anti-mouse Ly6G及部分参考文献

BioXcell InVivoPlus anti-mouse Ly6G 1A8单克隆抗体与小鼠Ly6G反应。Ly6G分子量为21-25kDa&#xff0c;是GPI锚定的细胞表面蛋白Ly-6超家族的成员&#xff0c;在细胞信号传导和细胞粘附中发挥作用。Ly6G在发育过程中由骨髓谱系中的细胞&#xff08;包括单核细胞、巨噬细胞、粒…

在点集的新知识面前百年集论不堪一击

黄小宁 与x∈R相异&#xff08;等&#xff09;的实数均可表为yxδ&#xff08;增量δ可0也可≠0&#xff09;&#xff0c;因各实数的绝对值都可是表示长度的数故各实数都可是数轴上点的坐标&#xff0c;于是x∈R变换为实数yxδ的几何意义可是&#xff1a;一维空间“管道”g内R…

产品推荐 | 基于 Xilinx ZYNQ UltraScale+的FACE-ZUSSD-C 多核SOC设计开发平台

01、产品概述 FACE-ZUSSD-C多核SOC设计开发平台是FACE系列的新产品。FACE-ZUSSD-C搭载有16nm工艺的ZYNQ UltraScale系列主器件ZU19EG。该主器件具有丰富的FPGA可编程逻辑资源&#xff0c;同时其内嵌有四核ARM CortexA53&#xff0c;双核ARM CortexR5以及Mali400 GPU。 平台板…

常用的苹果应用商店上架工具推荐

摘要 移动应用app上架是开发者关注的重要环节&#xff0c;但常常会面临审核不通过等问题。为帮助开发者顺利完成上架工作&#xff0c;各种辅助工具应运而生。本文探讨移动应用app上架原理、常见辅助工具功能及其作用&#xff0c;最终指出合理使用工具的重要性。 引言 移动应…

构建一个基础的大型语言模型(LLM)应用程序

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

通用指南-营销和设计中的增强现实(AR)

原文作者&#xff1a;Superside 翻译&#xff1a;数字化营销工兵 --- 经典万字长文&#xff0c;权威解读&#xff0c;分享经典&#xff0c;预计阅读完需要30分钟&#xff0c;建议收藏&#xff01; 目录 一、引言 为什么要尝试AR AR到底是什么&#xff1f;营销人员和创意人…

镭速如何适配国产数据库(达梦)进行高效数据管理与共享

在当今企业运营的背景下&#xff0c;数据的管理和共享显得尤为关键。在这个过程中&#xff0c;挑选一个合适的数据库系统是至关重要的。国产的达梦数据库因其在多个关键领域&#xff0c;如金融、能源、航空和通信等的成功运用&#xff0c;已经成为众多企业的首选解决方案。 作为…

【Git篇】复习git

文章目录 &#x1f354;什么是git⭐git和svn的区别 &#x1f354;搭建本地仓库&#x1f354;克隆远程仓库&#x1f6f8;git常用命令 &#x1f354;什么是git Git是一种分布式版本控制系统&#xff0c;它可以追踪文件的变化、协调多人在同一个项目上的工作、恢复文件的旧版本等…

后端程序员入门react笔记(九)- react 插件使用

setState setState引起的react的状态是异步的。操作完毕setState之后如果直接取值&#xff0c;可能取不到最新的值&#xff0c;我们举个例子console.log(this.state.num)打印的值&#xff0c;总是上一次的值而不是最新的。 import React, {Component} from react; class Ap…

SQLiteC/C++接口详细介绍sqlite3_stmt类(十三)

返回&#xff1a;SQLite—系列文章目录 上一篇&#xff1a;SQLiteC/C接口详细介绍sqlite3_stmt类&#xff08;十二&#xff09; 下一篇&#xff1a; SQLite数据库文件损坏的可能几种情况 51、sqlite3_stmt_scanstatus_reset sqlite3_stmt_scanstatus_reset 函数用于重置指…

机器学习:探索数据中的模式与智能

文章目录 导言介绍&#xff1a;机器学习的定义和重要性发展历程&#xff1a;从概念到现实应用 基础概念机器学习的基本原理监督学习、无监督学习和强化学习的区别与应用1.监督学习2.无监督学习3.强化学习 常见的机器学习任务和应用领域 结语 导言 当代科技领域中最为引人注目的…

成都欣丰洪泰文化传媒有限公司怎么样正规吗?

随着互联网的飞速发展和电子商务的蓬勃兴起&#xff0c;越来越多的企业开始将目光投向这片广阔的市场。在这个风起云涌的时代&#xff0c;成都欣丰洪泰文化传媒有限公司凭借其深厚的行业积累和前瞻性的市场洞察力&#xff0c;迅速崛起为电商服务领域的领航者&#xff0c;引领着…

百度谷歌301强引蜘蛛池效果怎么样

301强引蜘蛛池效果怎么样 本文 虚良SEO 原创&#xff0c;转载保留链接&#xff01;网址&#xff1a;百度谷歌301强引蜘蛛池效果怎么样 - 虚良SEO 随着搜索引擎优化&#xff08;SEO&#xff09;技术的发展&#xff0c;越来越多的网站开始采用蜘蛛池技术来提高网站的排名和流量。…

谭浩强第五版C语言课后习题(编程题)+答案

谭浩强第五版作为初学C语言必读的一本教材&#xff0c;课后习题具有非常大的参考价值&#xff0c;也是很多高校期末考试或者考研的重要参考。在这里我整理了一部分个人认为比较重要的编程题&#xff0c;供大家作参考 1.输入两个数&#xff0c;求他们的最大公约数和最小公倍数&…

js改变图片曝光度(高亮度)

方法一&#xff1a; 原理&#xff1a; 使用canvas进行滤镜操作&#xff0c;通过改变图片数据每个像素点的RGB值来提高图片亮度。 缺点 当前项目使用的是svg&#xff0c;而不是canvas 调整出来的效果不是很好&#xff0c;图片不是高亮&#xff0c;而是有些发白 效果 代码 …

1320亿参数,性能超LLaMA2、Grok-1!开源大模型DBRX

3月28日&#xff0c;著名数据和AI平台Databricks在官网正式开源大模型——DBRX。 DBRX是一个专家混合模型&#xff08;MoE&#xff09;有1320亿参数&#xff0c;能生成文本/代码、数学推理等&#xff0c;有基础和微调两种模型。 根据DBRX在MMLU、HumanEval和 GSM8K公布的测试…