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

构造函数深入理解

目录

  • 构造函数
    • 构造函数体赋值
    • 初始化列表
      • 初始化列表格式
      • 初始化列表的意义以及注意点
        • const修饰的成员变量初始化
        • 对象成员具体初始化的地方
        • 缺省值存在的意义
          • 例子1
          • 例子2
        • 初始化与赋值
        • 引用成员变量的初始化
          • 注意点1
          • 注意点2
          • 我的疑惑
        • 自定义类型成员初始化
          • 例子1
          • 例子2
          • 例子3
          • 例子4
        • 初始化列表可以调用函数
          • 例子1
          • 例子2
          • 例子3
        • 我的疑惑
        • 拓展
          • 例子1
          • 例子2
          • 不同类型的赋值
          • 编译器优化拷贝构造函数的情景
            • 例子1
            • 例子2
        • 总结
    • explicit关键字
      • 例子1
      • 例子2
    • 补充

感谢各位大佬对我的支持,如果我的文章对你有用,欢迎点击以下链接
🐒🐒🐒 个人主页
🥸🥸🥸 C语言
🐿️🐿️🐿️ C语言例题
🐣🐣🐣 python
🐓🐓🐓 数据结构C语言
🐔🐔🐔 C++
🐿️🐿️🐿️ 文章链接目录

构造函数

构造函数体赋值

在创建对象时,编译器通过调用构造函数,给对象中各个成员变量一个合适的初始值

class Date
{
public:Date(int year, int month, int day){_year = year;_month = month;_day = day;}
private:int _year;int _month;int _day;
};

虽然上述构造函数调用之后,对象中已经有了一个初始值,但是不能将其称为对对象中成员变量
的初始化,构造函数体中的语句只能将其称为赋初值,而不能称作初始化。因为初始化只能初始
化一次,而构造函数体内可以多次赋值。

初始化列表

初始化列表格式

初始化列表:以一个冒号开始,接着是一个以逗号分隔的数据成员列表,每个"成员变量"后面跟
一个放在括号中的初始值或表达式

class Date
{
public:Date(int year, int month, int day): _year(year), _month(month), _day(day){}/*  Date(int year, int month, int day)之前的构造函数格式{_year = year;_day = day;_month = month;}*/private:int _year;int _month;int _day;
};

下面的写法都是错误的
在这里插入图片描述
在这里插入图片描述

初始化列表的意义以及注意点

const修饰的成员变量初始化
class Date
{
public:Date(int year, int month, int day){_n = 1;_year = year;_day = day;_month=month;}private:int _year;int _month;int _day;const int _n;
};
int main()
{Date d1(2024, 5, 14);return 0;
}

const int _n不能够初始化
在这里插入图片描述
在这里插入图片描述
对于下面的代码我们都知道,这是声明,当对象实例化的时候他们才会整体定义,比如Date d1(2024,5,14)

private:int _year;int _month;int _day;const int _n;

但是有些成员在定义的时候是必须初始化的,就如 const int _n,因为const修饰了int_n,const只有一次修改的机会就是在初始化的时候,初始化的时候没有被修改,就会导致后面要想再修改就不可能了,因为const不允许修改被修饰的变量

对象成员具体初始化的地方

那对象成员具体初始化的地方都在哪呢?

在这里插入图片描述
上图我们可以认为是具体的初始化吗?来看看下面的图片
在这里插入图片描述
定义和初始化应该只有一个位置,但是上图中我们对_year进行了两次初始化,那这是开辟了两次空间吗?
当然不是,这样的情况我们并不想让他发生
所以构造函数才有了初始化列表,初始化列表是每个成员变量定义初始化的位置,也就是说想_year=1这样重复初始化的就别出现在初始化列表当中了
在这里插入图片描述
在这里插入图片描述
上图中_month和_day默认初始化为0
在之前的构造函数当中,有提到过缺省值

缺省值存在的意义
private:int _year=2;int _month=1;int _day=3;const int _n=1;

这里的_year _month _day _n的缺省值分别为2 1 3 1,而这个缺省值其实就是为初始化列表准备的,当初始化列表当中什么都没有的时候,缺省值就发挥作用了

例子1
class Date
{
public:Date(int year, int month, int day){}void Print(){cout << _year << "/" << _month << "/" << _day << "/" << _n << endl;}
private:int _year=2;int _month=1;int _day=3;const int _n=1;
};
int main()
{Date d1(2024, 5, 14);d1.Print();return 0;
}

在这里插入图片描述

例子2

在这里插入图片描述

_year输出的结果是2因为在初始化列表当中我们对_year初始化成了2,所以并没有用到缺省值
_month输出结果是一个随机值因为_month即没给缺省值,又没对其进行初始化
_day输出结果是0,虽然_day给了缺省值,但是在初始化列表当中没有具体给初始化值,所以_day最后初始化的值为0(具体为什么我也不清楚,可能就觉得既然你都有缺省值了,要想让_day=缺省值,就不要在初始化列表里面写_day(),这样让人感觉你就像让_day默认初始化成0)
_n输出结果是4因为给的缺省值是4,虽然在初始化列表当中没有写n,但是初始化列表会用这个缺省值给n进行初始化

初始化与赋值

知道了初始化列表的用处后我们看看下面这个代码

class Date
{
public:Date(int year, int month, int day):_year(1),_month(2), _day(3),_n(4){_year = year;_month = month;_day = day;_year = 1;}void Print(){cout << _year << "/" << _month << "/" << _day << "/" << _n << endl;}
private:int _year=1;int _month;int _day=2;const int _n=4;
};
int main()
{Date d1(2024, 5, 14);d1.Print();return 0;
}

在这里插入图片描述
结果是1/5/14/4,为什么不是1/2/3/4呢?不是说初始化列表值允许初始化1次吗?
初始化的确只能初始化1次,但是赋值可以赋值很多次
所以大括号里面的_year=year…其实是对_year…赋值

并且从这个例子我们也可以看出谁才是初始化,因为按照程序运行的顺序,初始化必然是排在最前面的,赋值是在初始化成功的基础上才能进行

尽量使用初始化列表初始化,因为不管你是否使用初始化列表,对于自定义类型成员变量,一定会先使用初始化列表初始化,所以最终的写法如下

class Date
{
public:Date(int year, int month, int day):_year(year),_month(month), _day(day),_n(4){}void Print(){cout << _year << "/" << _month << "/" << _day << "/" << _n << endl;}
private:int _year=1;int _month;int _day=2;const int _n=4;
};
int main()
{Date d1(2024, 5, 14);d1.Print();return 0;
}

在这里插入图片描述

注意:
1. 每个成员变量在初始化列表中只能出现一次(初始化只能初始化一次)
2. 类中包含以下成员,必须放在初始化列表位置进行初始化:
引用成员变量
const成员变量
自定义类型成员(且该类没有默认构造函数时)

引用成员变量的初始化

为什么引用也要房子初始化列表当中呢?
在写引用的文章当中说过引用必须要在定义的时候初始化

注意点1

在这里插入图片描述
因为是引用,所以在初始化的时候我们可以填入成员变量,如下图_ref是_year的别名
在这里插入图片描述

注意点2

但同时也需要注意因为_ref是引用,所以在初始化的时候需要注意不可以成为const修饰成员的别名
在这里插入图片描述

我的疑惑

在写到这里的时候我还在想像这种引用放在初始化列表开始的位置,在_year还没初始化的时候,就让_ref作为_year的别名会不会报错呢?
在这里插入图片描述
这里我说一下我自己的想法,因为_year已经声明了,而_ref作为_year的别名,由于_year没有初始化,所以_ref只是套了一个空壳子,单号_year初始化后,_ref才真正的初始化成功
为了验证想法我见year的缺省值删掉,并且不在初始化列表当中加入_year,最后输出的是随机值
在这里插入图片描述
这时我有一点疑惑,如果没有初始化_year那_year应该只有一个声明才对,只有一个声明就说明_year没有空间,输出的时候应该会报错才对
于是我打印了一下_year和_ref的地址,发现他们是有地址的,说明_year和_ref是存在的
为了解释这种情况我觉得可能是在定义这个对象的时候想_year这些成员变量就已经有空间了,但是又和前面所的知识冲突,也可能是我自己没学懂😕😕😕
在这里插入图片描述

自定义类型成员初始化
例子1
class A
{
public:A(int a = 0):_a(a){cout << "A(int a=0)" << endl;}
private:int _a;
};
class Date
{
public:Date(int year, int month, int day):_ref(_year), _month(month), _day(day), _n(4)   {}void Print(){cout << &_year << "/" << _month << "/" << _day << "/" << _n << "/" << &_ref << endl;}
private:int _year;int _month;int _day=2;const int _n=4;int& _ref;A _aa;
};
int main()
{Date d1(2024, 5, 14);d1.Print();return 0;
}

现在有一个自定义类型A,将A_aa的声明放在Date的成员声明里,但是A_aa没有在Date的初始化列表当中定义,那A_aa会不会被定义呢?

我们需要理解下面这句话
我们不写默认构造函数,编译器会自动生成,编译器自动生成的默认构造函数不对内置类型进行处理,自定义类型调用他自己的默认构造函数

在Date的初始化列表当中由于没有写A的构造函数,所以在运行的过程当中会调用A的默认构造函数,而A的默认构造函数是在A这个类里面
在这里插入图片描述

例子2

当我们不给a默认构造呢(只写了int a,没有些int a=0)
在这里插入图片描述
因为我们给_a初始化成a,但是a没有给值,所以会报错

例子3

而当我们不给_a初始化成a时,也就是_a(),这样a就是初始化成0
在这里插入图片描述

例子4

我们也可以这样写
在这里插入图片描述

初始化列表可以调用函数
例子1
class Date
{
public:Date():_p((int*)malloc(sizeof(4))){//函数体if (_p == nullptr){perror("malloc fail");}}void Print(){cout << _p << endl;}
private:int* _p;
};
int main()
{Date d1;d1.Print();return 0;
}

在这里插入图片描述

例子2
class Date
{
public:Date(int year, int month, int day):_ref(_year), _month(month), _day(day), _n(4),_p((int*)malloc(sizeof(4))){//函数体if (_p == nullptr){perror("malloc fail");}}void Print(){cout << &_year << "/" << _month << "/" << _day << "/" << _n << "/" << &_ref << endl;cout << _p << endl;}
private:int _year;int _month;int _day = 2;const int _n = 4;int& _ref;int* _p;
};
int main()
{Date d1(2024, 5, 14);d1.Print();return 0;
}

在这里插入图片描述

例子3
class A
{
public:void Print(){cout << a << " " << p1 << " " << *p2 << endl;}
private:int a = 1;int* p1 = nullptr;int* p2 = (int*)malloc(4);};
int main()
{A a;a.Print();
}

因为缺省值是给初始化列表的,这里的int* p2 = (int*)malloc(4)和上面初始化列表当中的 ,_p((int*)malloc(sizeof(4)))写法是相同的,既然初始化列表可以这样写,那缺省值也是可以这样写的

所以缺省值不一定是常量
在这里插入图片描述

我的疑惑
class Date
{
public:Date():_p((int*)malloc(sizeof(4))){//函数体if (_p == nullptr){perror("malloc fail");}}void Print(){cout << _p << endl;}
private:int* _p;
};
int main()
{Date d1();d1.Print();return 0;
}

这段代码和上面的例子1的唯一区别就是Date d1有无括号,但是就是因为这个括号导致报错了,我也不清楚为什么会这样
例子2中Date d1有括号,并且也定义了_p,为什么就可以正常运行
在这里插入图片描述
在这里插入图片描述
除了上面的一些问题还有关于_p初始化的一些问题等

拓展
例子1
class C
{
public:C(int x = 0):_x(x){}void Print(){cout << _x << endl;}
private:int _x;
};
int main()
{C c1(1);c1.Print();
}

在这里插入图片描述

例子2
class C
{
public:C(int x = 0):_x(x){}void Print(){cout << _x << endl;}
private:int _x;
};
int main()
{C c2 = 2;c2.Print();
}

单参数构造函数支持隐式类型的转换,这里的2构造出了一个C的对象,我们先称为c3,然后将c3拷贝构造给c2,这样的话C c2=2就可以理解成c2=c3,

在这里插入图片描述

不同类型的赋值

另外之前提到过不同类型赋值过程也和这个是一样的
比如现在有一个int类型的a和double类型的b
在这里插入图片描述
现在要将b用来给a赋值,在赋值的过程中b会创建出一个临时变量,然后a拷贝这个临时变量,因为double类型有8个字节,而int类型只有4个字节,所以拷贝的时候就出现了数据丢失
在这里插入图片描述
在这里插入图片描述

同样的当一个char类型的变量赋值给int类型的变量,因为char类型只有1个字节,而int类型有4个字节,所以当char类型赋值给int类型的时候会出现类型提升
在这里插入图片描述

所以现在倒回来理解C c2=2应该就容易一点了

在这里插入图片描述

编译器优化拷贝构造函数的情景
例子1

我们也可以验证一下他时候调用了拷贝构造函数

在这里插入图片描述
这里没有调用拷贝构造函数是因为编译器优化了,同一个表达式连续步骤的构造,一般会合二为一

例子2
class C
{
public:C(int x = 0):_x(x){}C(const C& cc){cout << "C(const C& cc)" << endl;}void Print()const{cout << _x << endl;}
private:int _x;
};
int main()
{const C& c2 = 2;c2.Print();
}

这里的c2引用的是临时变量,而临时变量具有常性
在这里插入图片描述

总结

类中以下成员必须放在初始化列表中初始化
引用成员变量
const修饰成员变量
自定义类型成员(且该类没有构造默认成员函数时)
其他成员可以在函数体内初始化也可以在初始化列表里初始化

这里的函数体具体是指哪里呢?

    Date(int year, int month, int day):_ref(_year), _month(month), _day(day), _n(4)   ,_aa(1){//函数体}

explicit关键字

对于上面的代码有许多情况都是通过隐式类型转换,如果我们不想让这种转换发生,我们可以通过explicit去修饰

例子1

class C
{
public:C(int x = 0):_x(x){}C(const C& cc){cout << "C(const C& cc)" << endl;}void Print()const{cout << _x << endl;}
private:int _x;
};
int main()
{const C& c2 = 2;c2.Print();
}

在这里插入图片描述

例子2

多参数的类也是可以支持explicit修饰

class A
{
public:A(int a1,int a2):_a1(a1),_a2(a2){}
private:int _a1;int _a2;
};
int main()
{A b1 = { 1,2 };const A& b2 = { 1,2 };A b3(1,2);return 0;
}

需要注意的是A b1 = { 1,2 }中用的是花括号
在构造时我们我们可以写成A b3(1,2)

当加上explicit之后

class A
{
public:explicit A(int a1,int a2):_a1(a1),_a2(a2){}
private:int _a1;int _a2;
};
int main()
{A b1 = { 1,2 };const A& b2 = { 1,2 };A b3(1,2);return 0;
}

在这里插入图片描述

补充

看一下下面这道题

class A
{
public:A(int a):_a1(a),_a2(_a1){}void Print() {cout<<_a1<<" "<<_a2<<endl;}
private:int _a2;int _a1;
};
int main() {A aa(1);aa.Print();
}
A. 输出1  1
B.程序崩溃
C.编译不通过
D.输出1  随机值

_a2输出的是一个随机值,这是因为成员变量在类中声明次序就是其在初始化列表中的初始化顺序,与其在初始化列表中的先后次序无关
注意看private的中的_a1和_a2的先后顺序,_a2是在_a1前面的,所以_a2要比_a1先赋值
在这里插入图片描述

在这里插入图片描述
当我们调整顺序后,输出就是1 1了
在这里插入图片描述

相关文章:

构造函数深入理解

目录 构造函数构造函数体赋值初始化列表初始化列表格式初始化列表的意义以及注意点const修饰的成员变量初始化对象成员具体初始化的地方缺省值存在的意义例子1例子2 初始化与赋值引用成员变量的初始化注意点1注意点2我的疑惑 自定义类型成员初始化例子1例子2例子3例子4 初始化列…...

Rocky Linux 9 快速安装docker 教程

前述 CentOS 7系统将于2024年06月30日停止维护服务。CentOS官方不再提供CentOS 及后续版本&#xff0c;不再支持新的软件和补丁更新。CentOS用户现有业务随时面临宕机和安全风险&#xff0c;并无法确保及时恢复。由于 CentOS Stream 相对不稳定&#xff0c;刚好在寻找平替系统…...

go语言并发编程1-Gouroutine

参考文档&#xff1a;www.topgoer.com 使用方法 直接包装成函数&#xff0c;go关键字触发即可 注意事项 1 main方法结束后&#xff0c;main方法内启动的子协程会立即结束&#xff0c;无论是否执行完毕&#xff1b; 启动多个groutine 使用sync包的WaitGroup来控制&#xf…...

Sylar服务器框架——Http模块

1、http.h 定义了HttpMethod和HttpStatus /* Request Methods */ #define HTTP_METHOD_MAP(XX) \XX(0, DELETE, DELETE) \XX(1, GET, GET) \XX(2, HEAD, HEAD) \XX(3, POST, POST) \XX(4, PUT, …...

7km远距离WiFi实时图传模块,无人机海上无线传输方案,飞睿智能WiFi MESH自组网技术

在浩瀚无垠的海洋上&#xff0c;无人机正在开启一场前所未有的技术创新。它们不再只是天空的舞者&#xff0c;更是海洋的守望者&#xff0c;为我们带来前所未有的视野和数据。而这一切的背后&#xff0c;都离不开一项创新性的技术——飞睿智能远距离WiFi实时图传模块与无线Mesh…...

2024年上半年网络工程师下午真题及答案解析

试题一(20分) 某高校网络拓扑如下图所示&#xff0c;两校区核心&#xff08;CORE-1、CORE-2&#xff09;&#xff0c;出口防火墙&#xff08;NGFW-1、NGFW-2&#xff09;通过校区间光缆互联&#xff0c;配置OSPF实现全校路由收敛&#xff0c;两校区相距40km。两校区默认由本地…...

Jmeter下载、安装及配置

1 Jmeter介绍 Jmeter是进行负载测试的工具&#xff0c;可以在任何支持Java虚拟机环境的平台上运行&#xff0c;比如Windows、Linux、Mac。 Jmeter模拟一组用户向目标服务器发送请求&#xff0c;并统计目标服务器的性能信息&#xff0c;比如CPU、memory usage。 2 Jmeter下载 …...

掌握高效实用的VS调试技巧

&#x1f525; 个人主页&#xff1a;大耳朵土土垚 1.编程常见的错误 1.1编译型错误 编程编译型错误是指在编译代码时发现的错误。编译器在编译过程中会检查代码是否符合语法规范和语义要求&#xff0c;如果发现错误会产生编译错误。 直接看错误提示信息&#xff08;双击&#…...

实验2 字符及字符串输入输出与分支程序设计实验

字符及字符串输入输出 从键盘输入两个一位十进制数&#xff0c;计算这两个数之和&#xff0c;并将结果在屏幕上显示出来。 分支程序设计 从键盘输入一字符&#xff0c;判断该字符是小写字母、大写字母、数字或者其他字符。若输入为小写字母&#xff0c;显示“You Input a Lo…...

docker容器间网络仿真工具-pumba

docker-tc&pumba docker-tc:docker-tc项目仓库 pumba:pumba项目仓库 这两个项目理论上都可以实现对容器间的网络环境进行各种模拟干预&#xff0c;包括延迟&#xff0c;丢包&#xff0c;带宽限制等。 但是我在实际使用时&#xff0c;发现docker-tc这个工具在进行网络进行模…...

A36 STM32_HAL库函数 之PCD通用驱动 -- B -- 所有函数的介绍及使用

A36 STM32_HAL库函数 之PCD通用驱动 -- B -- 所有函数的介绍及使用 1 该驱动函数预览1.11 HAL_PCD_SOFCallback1.12 HAL_PCD_ResetCallback1.13 HAL_PCD_SuspendCallback1.14 HAL_PCD_ResumeCallback1.15 HAL_PCD_ISOOUTIncompleteCallback1.16 HAL_PCD_ISOINIncompleteCallbac…...

vue2 + element三级菜单实现模板

需求&#xff1a; 需要一个含有三级菜单的结构模板&#xff0c;用于业务快速开发。 解决&#xff1a; sidebar.vue <template><el-menu :default-active"defaultActive" class"el-menu-vertical-demo" active-text-color"#ffd04b"&…...

vue H5页面video 视频流自动播放, 解决ios不能自动播放问题

视频组件 <videostyle"width: 100%; height: 100%;object-fit: fill"class"player"refplayer_big_boxcontrolspreloadautoplay //自动播放muted //是否静音playsinline"true"x5-playsinline""webkit-playsinline"tru…...

自闭症儿童:探索症状背后的多彩内心世界

在星启帆自闭症康复中心&#xff0c;我们每天与一群独特而珍贵的孩子相遇——他们&#xff0c;是自闭症谱系障碍的患儿。自闭症&#xff0c;这一复杂的神经发育障碍&#xff0c;以其多样化的症状表现&#xff0c;为每个孩子的生活轨迹绘上了不同的色彩。 自闭症孩子的症状各异…...

在Centos7上安装PostgreSQL16的详细步骤

文章目录 环境一、准备二、postgresql下载方法一&#xff1a;wget下载方法二&#xff1a;下载压缩包解压 三、创建用户组、用户四、创建数据主目录五、配置环境变量六、initdb初使化数据库七、配置服务八、设置开机自启动九、设置防火墙十、启动数据库服务 环境 CPU: 4 核心或以…...

MySQL 图形化界面

填完信息之后&#xff0c;圆圈处可以验证是否可以连接数据库 展示所有数据库&#xff08;因为有的可能连上&#xff0c;却没有数据库显示&#xff09;...

【人工智能】GPT-5的即将到来:从高中生进化到,,,博士生?

GPT-5的即将到来&#xff1a;从高中生进化到,博士生&#xff1f; 随着近月GPT-4o的出世&#xff0c;OpenAI也在进行一系列的采访和介绍接下来的展望和目标。 在6月22日的采访中&#xff0c;美国达特茅斯工程学院公布了OpenAI首席技术官米拉穆拉蒂的访谈内容。穆拉蒂确认&#…...

【收录率高丨投稿范围广 | 往届均已EI检索】第四届光学与通信技术国际学术会议(ICOCT 2024,8月9-11)

欢迎参加第四届光学与通信技术国际学术会议&#xff08;ICOCT 2024&#xff09;&#xff0c;该会议将于2024年8月9-11日在南京举办。自2021年首次会议以来&#xff0c;ICOCT已经发展成为光学和通信领域较有影响力的国际会议之一&#xff0c;聚焦最前沿的技术进展与未来发展趋势…...

小阿轩yx-LVS负载均衡群集

小阿轩yx-LVS负载均衡群集 构建群集服务器—通过整合多台服务器使用 LVS 达到服务器的高可用和负载均衡并以同一个 IP 地址对外提供相同的服务 LVS 群集应用基础 群集称呼来自英文单词“Cluster”在服务器领域则表示大量服务器的集合体&#xff0c;区分单个服务器 Cluster …...

CPP知识点记录总结

1、类的const成员函数 const成员函数的const 实际修饰的是该成员函数隐含的this指针&#xff0c;表明在该成员函数中不能对类的任何成员进行修改。 class A {void fun() const {// 常成员函数&#xff0c;在函数名后用const修饰} } 一文带你入门C类和对象【十万字详解&#…...

选吉他不踩坑:合板、单板、全单材质深度解析,新手看懂这篇就够

对于新手来说&#xff0c;挑选吉他时最容易被“合板”“单板”“全单”这些专业术语绕晕。其实&#xff0c;这三者的核心区别在于木材的构成方式&#xff0c;而木材直接决定了吉他的音色、手感以及使用寿命。今天我们就抛开品牌干扰&#xff0c;纯科普这三种材质的底层逻辑&…...

STM32标准库项目如何用VSCode一键编译下载?详解tasks.json与Makefile的联动配置

STM32标准库项目在VSCode中实现一键编译下载的终极指南 1. 为什么选择VSCode进行STM32开发&#xff1f; 传统嵌入式开发往往依赖于Keil、IAR等商业IDE&#xff0c;但这些工具存在几个明显痛点&#xff1a; 高昂的授权费用&#xff1a;商业IDE的许可证价格让个人开发者和小团队望…...

Qwen3-VL-WEBUI新手教程:无需编程,用WebUI轻松玩转多模态AI

Qwen3-VL-WEBUI新手教程&#xff1a;无需编程&#xff0c;用WebUI轻松玩转多模态AI 1. 什么是Qwen3-VL-WEBUI&#xff1f; Qwen3-VL-WEBUI是阿里云推出的一个开箱即用的多模态AI工具&#xff0c;内置了目前Qwen系列中最强大的视觉语言模型Qwen3-VL-4B-Instruct。这个镜像最大…...

面向对象高级三:内部类 枚举 泛型 java.lang包下常用API

一.内部类1.内部类概述 2.成员内部类&#xff08;实例内部类&#xff09;&#xff08;1&#xff09;成员内部类可以定义类的一切成员&#xff08;2&#xff09;当创建对象时不能直接给内部类创建对象而要先创建外部类的对象 然后new成员内部类的对象&#xff08;3&#xff09;在…...

RCLAMP0542T.TCT‌静电保护TVS 二极管阵列 SEMTECH 电子元器件IC 芯片

RCLAMP0542T.TCT‌ 是由 ‌SEMTECH‌ 公司推出的一款超低电容、双通道ESD&#xff08;静电放电&#xff09;保护 TVS 二极管阵列&#xff0c;具备0.45pF 超低电容、5A 浪涌承受能力和超小型 SLP1610P4T 封装&#xff0c;专为高速数据接口设计&#xff0c;广泛应用于通信设备、消…...

SVG-Edit:开源矢量编辑在浏览器工具中的创新实践

SVG-Edit&#xff1a;开源矢量编辑在浏览器工具中的创新实践 【免费下载链接】svgedit Powerful SVG-Editor for your browser 项目地址: https://gitcode.com/gh_mirrors/sv/svgedit SVG-Edit是一款基于浏览器环境的开源矢量图形编辑工具&#xff0c;提供在线SVG编辑能…...

闽北哥-柔弱胜刚强:真正的强者,从不硬碰

柔弱胜刚强 ——真正的强者&#xff0c;从不硬碰“为什么真正厉害的人&#xff0c; 看起来都有些柔弱&#xff1f;&#x1f33f; 因为—— 刚强自毁&#xff0c;柔弱长存。&#x1f52e; 这不是权谋&#xff0c; 而是—— 天地运行的铁律。”&#x1f30a; 一、误解千年&#x…...

比亚迪多款新车激光雷达性能超越华为:千线级感知开启智驾新纪元

2026年,中国智能驾驶行业正式进入“千线级激光雷达”时代。继华为发布896线双光路激光雷达后,比亚迪携速腾聚创EM4数字化激光雷达强势反击,以1080线物理扫描、600米最远探测的硬核参数,在核心感知硬件上实现对华为的全面超越。这一突破不仅标志着比亚迪补齐了智能化短板,更…...

从Address Editor入手:在Block Design中精准调整Bram存储深度的实战解析

1. 当Bram存储深度无法修改时&#xff0c;你该怎么做&#xff1f; 第一次在Vivado中使用Block Design搭建系统时&#xff0c;很多人都会遇到一个奇怪的现象&#xff1a;明明在Bram IP核的参数设置界面看到了"Depth"这个选项&#xff0c;但无论如何点击都无法修改。这…...

对抗攻击新思路:为什么Diffusion模型比GAN更适合生成隐蔽攻击样本?

扩散模型在对抗攻击领域的突破性优势&#xff1a;从理论到实践 当我们在讨论机器学习安全时&#xff0c;对抗攻击一直是个令人着迷又充满挑战的话题。想象一下&#xff0c;只需对输入图像做几乎不可察觉的微小改动&#xff0c;就能让最先进的分类模型完全"失明"——这…...