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

【C#补全计划】万类之父中的方法

一、Object中的静态方法

1. Equals方法

        (1)作用:判断两个对象是否相等。最终的判断权交给左侧对象的Equals方法

        (2)值类型比较:判断值是否相等

using System;namespace ObjectFun
{class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true}}
}

运行结果如下:

        (3)引用类型比较:判断引用地址是否相等

using System;namespace ObjectFun
{class Test{}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true}}
}

运行结果如下:

2. ReferenceEquals方法:

        (1)作用:比较两个对象的引用地址是否相等

        (2)值类型比较:始终返回false

using System;namespace ObjectFun
{class Test{}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false}}
}

运行结果如下:

        (3)引用类型比较:判断引用地址是否相等

using System;namespace ObjectFun
{class Test{}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true}}
}

运行结果如下:

二、Object中的成员方法

1. GetType方法

        (1)作用:获取对象运行时的类型

        (2)代码:

using System;namespace ObjectFun
{class Test{}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true// 调用Object类的成员方法// GetType方法: 获取对象运行时的类型Console.WriteLine("\nGetType方法:");Type type1 = 1.GetType(); // 获取整数1的类型Type type2 = t1.GetType(); // 获取t1的类型Console.WriteLine("数字1的类型: " + type1);Console.WriteLine("t1对象的类型: " + type2);}}
}

运行结果如下:

2. MemberwiseClone方法

        (1)作用:创建当前对象的浅拷贝对象

        (2)代码:

using System;namespace ObjectFun
{class Test{public int value;public Test2 obj;public Test(){}public Test(int value, Test2 obj){this.value = value;this.obj = obj;}public Test clone(){return (Test)this.MemberwiseClone(); // 创建当前对象的浅拷贝}}class Test2{public int value;public Test2(){}public Test2(int value){this.value = value;}}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true// 调用Object类的成员方法// GetType方法: 获取对象运行时的类型Console.WriteLine("\nGetType方法:");Type type1 = 1.GetType(); // 获取整数1的类型Type type2 = t1.GetType(); // 获取t1的类型Console.WriteLine("数字1的类型: " + type1);Console.WriteLine("t1对象的类型: " + type2);// MemberwiseClone方法: 创建当前对象的浅拷贝对象Console.WriteLine("\nMemberwiseClone方法:");Test test = new Test(1, new Test2(2));Test clone = test.clone();Console.WriteLine("克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);clone.value = 11; // 修改克隆对象的值clone.obj.value = 22; // 修改克隆对象的引用类型成员的值Console.WriteLine("修改克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);// 可以理解为:值类型复制值,引用类型复制引用地址// 浅拷贝对象与原对象共享引用类型成员的内存地址,修改克隆对象的引用类型成员会影响原对象}}
}

运行结果如下:

三、Object中的虚方法

1. Equals方法

        (1)作用:比较两个对象的引用是否相同

        (2)代码:

using System;namespace ObjectFun
{class Test{public int value;public Test2 obj;public Test(){}public Test(int value, Test2 obj){this.value = value;this.obj = obj;}public Test clone(){return (Test)this.MemberwiseClone(); // 创建当前对象的浅拷贝}}class Test2{public int value;public Test2(){}public Test2(int value){this.value = value;}public override bool Equals(object? obj) // 重写Equals方法以比较Test2对象的值{if (obj is Test2 other) // 使用模式匹配检查类型并转换{return this.value == other.value; // 比较值是否相等}return false; // 类型不匹配,返回false}}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true// 调用Object类的成员方法// GetType方法: 获取对象运行时的类型Console.WriteLine("\nGetType方法:");Type type1 = 1.GetType(); // 获取整数1的类型Type type2 = t1.GetType(); // 获取t1的类型Console.WriteLine("数字1的类型: " + type1);Console.WriteLine("t1对象的类型: " + type2);// MemberwiseClone方法: 创建当前对象的浅拷贝对象Console.WriteLine("\nMemberwiseClone方法:");Test test = new Test(1, new Test2(2));Test clone = test.clone();Console.WriteLine("克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);clone.value = 11; // 修改克隆对象的值clone.obj.value = 22; // 修改克隆对象的引用类型成员的值Console.WriteLine("修改克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);// 可以理解为:值类型复制值,引用类型复制引用地址// 浅拷贝对象与原对象共享引用类型成员的内存地址,修改克隆对象的引用类型成员会影响原对象// 调用Object类的虚方法// Equals方法: 比较两个对象的引用是否相同, 相当于ReferenceEquals方法Console.WriteLine("\nEquals方法:");Test2 t2_1 = new Test2(1);Test2 t2_2 = new Test2(1); // 值相同但引用地址不同Console.WriteLine("t2_1 t2_2重写Equals方法比较: " + t2_1.Equals(t2_2)); // true, 因为重写了Equals方法, 只比较值是否相等}}
}

运行结果如下:

2. GetHashCode方法

        (1)作用:获取对象的哈希码

        (2)哈希码:通过一种算法算出的,表示对象的唯一标编码。不同的对象可能有相同的哈希码,但相同的对象一定有相同的哈希码

        (3)代码:

using System;namespace ObjectFun
{class Test{public int value;public Test2 obj;public Test(){}public Test(int value, Test2 obj){this.value = value;this.obj = obj;}public Test clone(){return (Test)this.MemberwiseClone(); // 创建当前对象的浅拷贝}}class Test2{public int value;public Test2(){}public Test2(int value){this.value = value;}public override bool Equals(object? obj) // 重写Equals方法以比较Test2对象的值{if (obj is Test2 other) // 使用模式匹配检查类型并转换{return this.value == other.value; // 比较值是否相等}return false; // 类型不匹配,返回false}}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true// 调用Object类的成员方法// GetType方法: 获取对象运行时的类型Console.WriteLine("\nGetType方法:");Type type1 = 1.GetType(); // 获取整数1的类型Type type2 = t1.GetType(); // 获取t1的类型Console.WriteLine("数字1的类型: " + type1);Console.WriteLine("t1对象的类型: " + type2);// MemberwiseClone方法: 创建当前对象的浅拷贝对象Console.WriteLine("\nMemberwiseClone方法:");Test test = new Test(1, new Test2(2));Test clone = test.clone();Console.WriteLine("克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);clone.value = 11; // 修改克隆对象的值clone.obj.value = 22; // 修改克隆对象的引用类型成员的值Console.WriteLine("修改克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);// 可以理解为:值类型复制值,引用类型复制引用地址// 浅拷贝对象与原对象共享引用类型成员的内存地址,修改克隆对象的引用类型成员会影响原对象// 调用Object类的虚方法// Equals方法: 比较两个对象的引用是否相同, 相当于ReferenceEquals方法Console.WriteLine("\nEquals方法:");Test2 t2_1 = new Test2(1);Test2 t2_2 = new Test2(1); // 值相同但引用地址不同Console.WriteLine("t2_1 t2_2重写Equals方法比较: " + t2_1.Equals(t2_2)); // true, 因为重写了Equals方法, 只比较值是否相等// GetHashCode方法: 获取对象的哈希码// 哈希码: 通过一种算法算出的,表示对象的唯一标编码。不同的对象可能有相同的哈希码,但相同的对象一定有相同的哈希码// 可以通过重写GetHashCode方法来定制哈希码的计算方式Console.WriteLine("\nGetHashCode方法:");Console.WriteLine("t1的哈希码: " + t1.GetHashCode()); // 输出t1的哈希码Console.WriteLine("t2的哈希码: " + t2.GetHashCode()); // 输出t2的哈希码Console.WriteLine("t3的哈希码: " + t3.GetHashCode()); // 输出t3的哈希码Console.WriteLine("test的哈希码: " + test.GetHashCode()); // 输出test的哈希码Console.WriteLine("clone的哈希码: " + clone.GetHashCode()); // 输出clone的哈希码Console.WriteLine("t2_1的哈希码: " + t2_1.GetHashCode()); // 输出t2_1的哈希码Console.WriteLine("t2_2的哈希码: " + t2_2.GetHashCode()); // 输出t2_2的哈希码}}
}

运行结果如下:

3. ToString方法

        (1)作用:获取对象的字符串表示形式

        (2)代码:

using System;namespace ObjectFun
{class Test{public int value;public Test2 obj;public Test(){}public Test(int value, Test2 obj){this.value = value;this.obj = obj;}public Test clone(){return (Test)this.MemberwiseClone(); // 创建当前对象的浅拷贝}public override string ToString() // 重写ToString方法以返回对象的字符串表示形式{return "值:" + value + ", 引用类型成员值: " + (obj != null ? obj.value : "null");}}class Test2{public int value;public Test2(){}public Test2(int value){this.value = value;}public override bool Equals(object? obj) // 重写Equals方法以比较Test2对象的值{if (obj is Test2 other) // 使用模式匹配检查类型并转换{return this.value == other.value; // 比较值是否相等}return false; // 类型不匹配,返回false}}class Program{static void Main(string[] args){// 调用Object类的静态方法// Equals方法: 比较两个对象是否相同Console.WriteLine("Equals方法:");// 值类型比较: 比较两个对象的值是否相等Console.WriteLine("1 1值类型比较: " + Object.Equals(1, 1)); // trueConsole.WriteLine("1 2值类型比较: " + Object.Equals(1, 2)); // true// 引用类型比较: 比较两个对象的内存地址是否相同Test t1 = new Test();Test t2 = new Test();Test t3 = t1; // 让t3指向t1的引用地址Console.WriteLine("t1 t2引用类型比较: " + Object.Equals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.Equals(t1, t3)); // true// ReferenceEquals方法: 比较两个对象的引用是否相同Console.WriteLine("\nReferenceEquals方法:");// 值类型比较: 始终返回falseConsole.WriteLine("1 1值类型比较: " + Object.ReferenceEquals(1, 1)); // falseConsole.WriteLine("1 2值类型比较: " + Object.ReferenceEquals(1, 2)); // false// 引用类型比较: 比较两个对象的内存地址是否相同Console.WriteLine("t1 t2引用类型比较: " + Object.ReferenceEquals(t1, t2)); // falseConsole.WriteLine("t1 t3引用类型比较: " + Object.ReferenceEquals(t1, t3)); // true// 调用Object类的成员方法// GetType方法: 获取对象运行时的类型Console.WriteLine("\nGetType方法:");Type type1 = 1.GetType(); // 获取整数1的类型Type type2 = t1.GetType(); // 获取t1的类型Console.WriteLine("数字1的类型: " + type1);Console.WriteLine("t1对象的类型: " + type2);// MemberwiseClone方法: 创建当前对象的浅拷贝对象Console.WriteLine("\nMemberwiseClone方法:");Test test = new Test(1, new Test2(2));Test clone = test.clone();Console.WriteLine("克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);clone.value = 11; // 修改克隆对象的值clone.obj.value = 22; // 修改克隆对象的引用类型成员的值Console.WriteLine("修改克隆对象后: ");Console.WriteLine("test.value:" + test.value + ", test.obj.value:" + test.obj.value);Console.WriteLine("clone.value:" + clone.value + ", clone.obj.value:" + clone.obj.value);// 可以理解为:值类型复制值,引用类型复制引用地址// 浅拷贝对象与原对象共享引用类型成员的内存地址,修改克隆对象的引用类型成员会影响原对象// 调用Object类的虚方法// Equals方法: 比较两个对象的引用是否相同, 相当于ReferenceEquals方法Console.WriteLine("\nEquals方法:");Test2 t2_1 = new Test2(1);Test2 t2_2 = new Test2(1); // 值相同但引用地址不同Console.WriteLine("t2_1 t2_2重写Equals方法比较: " + t2_1.Equals(t2_2)); // true, 因为重写了Equals方法, 只比较值是否相等// GetHashCode方法: 获取对象的哈希码// 哈希码: 通过一种算法算出的,表示对象的唯一标编码。不同的对象可能有相同的哈希码,但相同的对象一定有相同的哈希码// 可以通过重写GetHashCode方法来定制哈希码的计算方式Console.WriteLine("\nGetHashCode方法:");Console.WriteLine("t1的哈希码: " + t1.GetHashCode()); // 输出t1的哈希码Console.WriteLine("t2的哈希码: " + t2.GetHashCode()); // 输出t2的哈希码Console.WriteLine("t3的哈希码: " + t3.GetHashCode()); // 输出t3的哈希码Console.WriteLine("test的哈希码: " + test.GetHashCode()); // 输出test的哈希码Console.WriteLine("clone的哈希码: " + clone.GetHashCode()); // 输出clone的哈希码Console.WriteLine("t2_1的哈希码: " + t2_1.GetHashCode()); // 输出t2_1的哈希码Console.WriteLine("t2_2的哈希码: " + t2_2.GetHashCode()); // 输出t2_2的哈希码// ToString方法: 获取对象的字符串表示形式// 可以通过重写ToString方法来自定义字符串的表示形式Console.WriteLine("\nToString方法:");Console.WriteLine("t1重写ToString方法: " + t1.ToString()); // 输出t1的字符串表示Console.WriteLine("test重写ToString方法: " + test.ToString()); // 输出t2的字符串表示}}
}

运行结果如下:

        今天的学习就到这里了。感谢阅读。

        再见!

http://www.xdnf.cn/news/1277623.html

相关文章:

  • Linux环境下实现简单TCP通信(c)
  • 《算法导论》第 16 章 - 贪心算法
  • [激光原理与应用-221]:设计 - 皮秒紫外激光器 - 常见技术难题、原因与解决方案
  • 博览会(树形DP)
  • 性能解析案例
  • Speaking T2 - Dining Hall to CloseDuring Spring Break
  • 论文复现与分析内容关于一种实用的车对车(V2V)可见光通信(VLC)传播模型
  • 攻击实验(ARP欺骗、MAC洪范、TCP SYN Flood攻击、DNS欺骗、DHCP饿死)
  • Doubletrouble靶机练习
  • Leaflet地图高亮与编辑功能实现
  • Jmeter性能测试之检测服务器CPU/Memory/磁盘IO/网络IO
  • 深度学习-卷积神经网络-AlexNet
  • 【走进Docker的世界】Docker环境搭建
  • 震动马达实现库函数版(STC8)
  • 机器学习——多元线性回归
  • C++移动语义、完美转发及编译器优化零拷贝
  • [创业之路-541]:经营分析会 - 企业的经营分析会,研发负责人负责提供哪些信息?
  • 【RocketMQ 生产者和消费者】- ConsumeMessageOrderlyService 顺序消费消息
  • 不同于传统的简并模分离圆极化天线,基于耦合谐振器的圆极化天线的原理是什么?
  • 如何通过API接口实现批量获取淘宝商品数据?(官方与非官方渠道分享)
  • 代码随想录算法训练营第六十天|图论part10
  • Java 基础编程案例:从输入交互到逻辑处理
  • ATF(TF-A)安全通告 TFV-12(CVE-2024-5660)
  • JDBC的连接过程(超详细)
  • 机器学习——标准化、归一化
  • 从零开始理解百度语音识别API的Python实现
  • nginx 反向代理传递原始域名
  • 前端开发中的常见问题与实战解决方案​
  • PostgreSQL 批量COPY导入优化参数配置
  • GC如何判断对象可以被回收?