第二章:类与对象(下)

news2025/1/10 13:12:59

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 再谈构造函数
    • 构造函数体赋值
    • 初始化列表
    • explicit 关键字
      • 隐式类型转换
  • static成员
    • 面试题
  • 友元
    • 友元函数
    • 友元类
  • 内部类
  • 匿名对象
  • 拷贝对象时的一些编译器优化
  • 再次理解类和对象
  • 总结


前言

类与对象是C++非常重要的概念。


再谈构造函数

构造函数体赋值

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

class Date
{
public:
	Date(int year, int month, int day)
	{
		_year = year;
		_month = month;
		_day = day;
	}
private:
	int _year = 2023;//这些是声明,2023是缺省值
	int _month;
	int _day;
};

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

初始化列表

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

哪个对象调用构造函数,初始化列表是它所有成员变量定义的位置。

不管是否显示在初始化列表写,编译器每个变量都会在初始化列表定义初始化

class Date
{
public:
	Date(int year, int month, int day)
		: _year(year)//这里成员变量的定义,没在函数体内,而是在赋值前定义
		, _month(month)
		, _day(day)
	{}
private:
	int _year; 
	int _month;
	int _day;
};
class A
{
public:
	A()
		:n(10)
        //如果去掉了:n(10),会导致未提供n的初始值
	{
		_a1 = 4;
	}

	void Print() {
		cout << _a1 << " " << _a2 << endl;
	}
private:
	int _a1 = 3;//声明 3是缺省值
	int _a2 = 2;
	const int n;
};
int main() {
	A aa;
	aa.Print();
}
  1. 每个成员变量在初始化列表中只能出现一次(初始化只能初始化一次)

  2. 类中包含以下成员,必须放在初始化列表位置进行初始化:
    引用成员变量、const成员变量、自定义类型成员(且该类没有默认构造函数时)

class A
{
public:
	A(int a)
		:_a(a)
	{}
private:
	int _a;
};


class B
{
public:
	B(int a, int ref)
		:_aobj(a)
		, _ref(ref)
		, _n(10)
	{}
private:
	A _aobj; // 没有默认构造函数
	int& _ref; // 引用
	const int _n; // const
};
  1. 尽量使用初始化列表初始化,因为不管你是否使用初始化列表,对于自定义类型成员变量,一定会先使用初始化列表初始化。
class Time
{
public:
	Time(int hour = 0)
		:_hour(hour)
	{
		cout << "Time()" << endl;
	}
private:
	int _hour;
};


class Date
{
public:
	Date(int day)
	{}
private:
	int _day;
	Time _t;
};


int main()
{
	Date d(1);
}
  1. 成员变量在类中声明次序就是其在初始化列表中的初始化顺序,与其在初始化列表中的先后次序无关
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();
} 
//输出随机值
//_a2是随机值

explicit 关键字

隐式类型转换

构造函数不仅可以构造与初始化对象,对于单个参数或者除第一个参数无默认值其余均有默认值的构造函数,还具有类型转换的作用。

C++11支持调用多参数构造函数来隐式类型转换

class A
{
public:
	A(int a)
		:_a1(a)
	{
		cout << "A(int a)" << endl;
	}
    A(int a1, int a2)
        :_a1(a1)
        ,_a2(a2)
    {}

	A(const A& aa)
		:_a1(aa._a1)
	{
		cout << "A(const A& aa)" << endl;
	}

private:
	int _a1;
    int _a2;
};

int main()
{
    //单参数构造函数 c++98
	A aa1(1); //构造函数
	A aa2 = 1;//隐式类型转换 构造 + 拷贝 =》 构造
                          //产生临时对象
  
    //多参数构造函数 C++11
    A aa3 = {1, 2};

	//A& ref = 10;
	const A& ref = 10;
    const A& ret = {10, 20};

}

class Date
{
public:
	// 1. 单参构造函数,没有使用explicit修饰,具有类型转换作用
    // explicit修饰构造函数,禁止类型转换---explicit去掉之后,代码可以通过编译
	explicit Date(int year)
		:_year(year)
	{}
	/*
	// 2. 虽然有多个参数,但是创建对象时后两个参数可以不传递,没有使用explicit修饰,具有类型转换作用
	// explicit修饰构造函数,禁止类型转换
	explicit Date(int year, int month = 1, int day = 1)
	: _year(year)
	, _month(month)
	, _day(day)
	{}
	*/
	Date& operator=(const Date& d)
	{
		if (this != &d)
		{
			_year = d._year;
			_month = d._month;
			_day = d._day;
		}
		return *this;
	}
private:
	int _year;
	int _month;
	int _day;
};
void Test()
{
	Date d1(2022);
	// 用一个整形变量给日期类型对象赋值
	// 实际编译器背后会用2023构造一个无名对象,最后用无名对象给d1对象进行赋值,现在被优化成:构造+拷贝 => 构造
	d1 = 2023;
	// 将1屏蔽掉,2放开时则编译失败,因为explicit修饰构造函数,禁止了单参构造函数类型转换的作用
}

上述代码可读性不是很好,用explicit修饰构造函数,将会禁止构造函数的隐式转换

static成员

声明为static的类成员称为类的静态成员,用static修饰的成员变量,称之为静态成员变量;用static修饰的成员函数,称之为静态成员函数静态成员变量一定要在类外进行初始化。

面试题

实现一个类,计算程序中创建出了多少个类对象。

class A
{
public:
	A() { ++_scount; }
	A(const A& t) { ++_scount; }
	~A() { --_scount; }
	static int GetACount() { return _scount; }
private:
	static int _scount;
    //静态成员变量,不属于某个对象,属于所有对象,属于类
};
int A::_scount = 0;//定义初始化
void TestA()
{
	cout << A::GetACount() << endl;
	A a1, a2;
	A a3(a1);
	cout << A::GetACount() << endl;
}
  1. 静态成员为所有类对象所共享,不属于某个具体的对象,存放在静态区

  2. 静态成员变量必须在类外定义,定义时不添加static关键字,类中只是声明

  3. 类静态成员即可用 类名::静态成员 或者 对象.静态成员 来访问,需要public修饰静态变量

  4. 静态成员函数没有隐藏的this指针,不能访问任何非静态成员

  5. 静态成员也是类的成员,受public、protected、private 访问限定符的限制

//实现一个类,计算程序中创建出了多少个类对象。
class A
{
public:
	A(int a = 0)
	{
		++count;
	}

	A(const A& aa)
	{
		++count;
	}

	// 静态成员函数 -- 没有this指针
	static int GetCount()
	{
		// _a++; // 不能直接访问非静态成员
		return count;
	}

private:
	// 不属于某个对象,所于所有对象,属于整个类
	static int count; // 声明

	int _a = 0;
};

int A::count = 0; // 定义初始化

void func()
{
	A aa1;
	A aa2(aa1);
	A aa3 = 1;

	A aa4[10];
}

int main()
{
	func();

	//cout << A::count << endl;
	//cout << aa2.count << endl;
	//cout << aa3.count << endl;
	//A* ptr = nullptr;
	//cout << ptr->count << endl;

	//A aa;
	//cout << aa.GetCount()-1 << endl;
	cout << A::GetCount()<< endl;

	return 0;
}
  1. 静态成员函数可以调用非静态成员函数吗?
    不可以,静态成员函数 – 没有this指针

  2. 非静态成员函数可以调用类的静态成员函数吗?
    可以

友元

友元提供了一种突破封装的方式,有时提供了便利。但是友元会增加耦合度,破坏了封装,所以友元不宜多用。

友元分为:友元函数和友元类

友元函数

问题:现在尝试去重载operator<<,然后发现没办法将operator<<重载成成员函数。因为cout的输出流对象和隐含的this指针在抢占第一个参数的位置。this指针默认是第一个参数也就是左操作数了。但是实际使用中cout需要是第一个形参对象,才能正常使用。所以要将operator<<重载成全局函数。但又会导致类外没办法访问成员,此时就需要友元来解决operator>>同理。

class Date
{
public:
	Date(int year, int month, int day)
		: _year(year)
		, _month(month)
		, _day(day)
	{}
	// d1 << cout; -> d1.operator<<(&d1, cout); 不符合常规调用
// 因为成员函数第一个参数一定是隐藏的this,所以d1必须放在<<的左侧
	ostream& operator<<(ostream& _cout)
	{
		_cout << _year << "-" << _month << "-" << _day << endl;
		return _cout;
	}
private:
	int _year;
	int _month;
	int _day;
};

友元函数可以直接访问类的私有成员,它是定义在类外部普通函数,不属于任何类,但需要在类的内部声明,声明时需要加friend关键字。

class Date
{
	friend ostream& operator<<(ostream& _cout, const Date& d);
	friend istream& operator>>(istream& _cin, Date& d);
public:
	Date(int year = 1900, int month = 1, int day = 1)
		: _year(year)
		, _month(month)
		, _day(day)
	{}
private:
	int _year;
	int _month;
	int _day;
};
ostream& operator<<(ostream& _cout, const Date& d)
{
	_cout << d._year << "-" << d._month << "-" << d._day;
	return _cout;
}
istream& operator>>(istream& _cin, Date& d)
{
	_cin >> d._year;
	_cin >> d._month;
	_cin >> d._day;
	return _cin;
}
int main()
{
	Date d;
	cin >> d;
	cout << d << endl;
	return 0;
}
  • 友元函数可访问类的私有和保护成员,但不是类的成员函数

  • 友元函数不能用const修饰

  • 友元函数可以在类定义的任何地方声明,不受类访问限定符限制

  • 一个函数可以是多个类的友元函数

  • 友元函数的调用与普通函数的调用原理相同

友元类

友元类的所有成员函数都可以是另一个类的友元函数,都可以访问另一个类中的非公有成员。

  • 友元关系是单向的,不具有交换性
    比如上述Time类和Date类,在Time类中声明Date类为其友元类,那么可以在Date类中直接访问Time类的私有成员变量,但想在Time类中访问Date类中私有的成员变量则不行。

  • 友元关系不能传递
    如果C是B的友元, B是A的友元,则不能说明C时A的友元。

  • 友元关系不能继承,在继承位置再给大家详细介绍。

class Time
{
	friend class Date; // 声明日期类为时间类的友元类,则在日期类中就直接访问Time类中的私有成员变量
public:
	Time(int hour = 0, int minute = 0, int second = 0)
		: _hour(hour)
		, _minute(minute)
		, _second(second)
	{}
private:
	int _hour;
	int _minute;
	int _second;
};


class Date
{
public:
	Date(int year = 1900, int month = 1, int day = 1)
		: _year(year)
		, _month(month)
		, _day(day)
	{}
	void SetTimeOfDate(int hour, int minute, int second)
	{
		// 直接访问时间类私有的成员变量
		_t._hour = hour;
		_t._minute = minute;
		_t._second = second;
	}
private:
	int _year;
	int _month;
	int _day;
	Time _t;
};

内部类

概念:如果一个类定义在另一个类的内部,这个内部类就叫做内部类。内部类是一个独立的类,它不属于外部类,更不能通过外部类的对象去访问内部类的成员。外部类对内部类没有任何优越的访问权限。

注意:内部类就是外部类的友元类,参见友元类的定义,内部类可以通过外部类的对象参数来访问外部类中的所有成员。但是外部类不是内部类的友元。

特性:

  1. 内部类可以定义在外部类的public、protected、private都是可以的。

  2. 注意内部类可以直接访问外部类中的static成员,不需要外部类的对象/类名。

  3. sizeof(外部类)=外部类,和内部类没有任何关系。

class A
{
private:
	static int k;
	int h;
public:
	class B // B天生就是A的友元,跟A是独立,只是受到A的类域限制
	{
	public:
		void foo(const A& a)
		{
			cout << k << endl;//OK
			cout << a.h << endl;//OK
		}
	};
};
int A::k = 1;
int main()
{
	A::B b;
	b.foo(A());
	return 0;
}

匿名对象

class A
{
public:
	A(int a = 0)
		:_a(a)
	{
		cout << "A(int a)" << endl;
	}
	~A()
	{
		cout << "~A()" << endl;
	}
private:
	int _a;
};
class Solution {
public:
	int Sum_Solution(int n) {
		//...
		return n;
	}
};
int main()
{
	A aa1;
	// 不能这么定义对象,因为编译器无法识别下面是一个函数声明,还是对象定义
	//A aa1();
	// 但是我们可以这么定义匿名对象,匿名对象的特点不用取名字,
	// 但是他的生命周期只有这一行,我们可以看到下一行他就会自动调用析构函数
	A();
	A aa2(2);
	// 匿名对象在这样场景下就很好用,当然还有一些其他使用场景,这个我们以后遇到了再说
	Solution().Sum_Solution(10);
	return 0;
}

匿名对象,生命周期只在这一行

拷贝对象时的一些编译器优化

在传参和传返回值的过程中,一般编译器会做一些优化,减少对象的拷贝,这个在一些场景下还是非常有用的。

构造 + 拷贝 => 构造

class A
{
public:
	A(int a = 0)
		:_a(a)
	{
		cout << "A(int a)" << endl;
	}
	A(const A& aa)
		:_a(aa._a)
	{
		cout << "A(const A& aa)" << endl;
	}
	A& operator=(const A& aa)
	{
		cout << "A& operator=(const A& aa)" << endl;
		if (this != &aa)
		{
			_a = aa._a;
		}
		return *this;
	}
	~A()
	{
		cout << "~A()" << endl;
	}
private:
	int _a;
};

void f1(A aa) //传值传参
{}

A f2()//传值返回
{
	A aa;
	return aa;
}

void f3(const A& aa)//引用传参
{
  
}

void f4()//返回匿名对象
{
    return A();
}

int main()
{
    //构造 + 拷贝构造 -> 优化为直接构造
    A aa1 = 1;
    
	// 传值传参
	A aa1;
	f1(aa1);// 拷贝构造,无优化

  
    // 隐式类型,连续构造+拷贝构造->优化为直接构造
	f1(1);
  
    // 一个表达式中,连续构造+拷贝构造->优化为一个构造
	f1(A(2));
----------------------------------------------------------------       	
  
    f3(aa1);   //无优化
    f3(1);     //直接构造,无优化
    f3(A(2));  //无优化
  
  
-----------------------------------------------------------------
  
	// 传值返回
    //构造 + 拷贝构造
	f2();
	cout << endl;
  
	// 一个表达式中,构造+拷贝构造+拷贝构造->优化成 构造+拷贝构造
	A aa2 = f2();
	cout << endl;
    
    // 构造 + 构造 + 拷贝构造 + 赋值重载
    A aa2;
    aa2 = f2();
  
	// 一个表达式中,连续拷贝构造+赋值重载->无法优化
	aa1 = f2();
	cout << endl;
-----------------------------------------------------------------
    
    //构造 + 拷贝构造 -> 构造
    func4();
  
    //构造 + 拷贝构造 + 拷贝构造 -> 构造
    A aa3 = func4(); 
	return 0;
}

接收返回值对象,尽量拷贝构造方式接收,不要赋值接收
函数中返回对像时,尽量返回匿名对象
函数传参尽量使用const &传参

再次理解类和对象

现实生活中的实体计算机并不认识,计算机只认识二进制格式的数据。如果想要让计算机认识现实生活中的实体,用户必须通过某种面向对象的语言,对实体进行描述,然后通过编写程序,创建对象后计算机才可以认识。 比如想要让计算机认识洗衣机,就需要:

  1. 用户先要对现实中洗衣机实体进行抽象—即在人为思想层面对洗衣机进行认识,洗衣机有什么属性,有那些功能,即对洗衣机进行抽象认知的一个过程

  2. 经过1之后,在人的头脑中已经对洗衣机有了一个清醒的认识,只不过此时计算机还不清楚,想要让计算机识别人想象中的洗衣机,就需要人通过某种面相对象的语言(比如:C++、Java、Python等)将洗衣机用类来进行描述,并输入到计算机中

  3. 经过2之后,在计算机中就有了一个洗衣机类,但是洗衣机类只是站在计算机的角度对洗衣机对象进行描述的,通过洗衣机类,可以实例化出一个个具体的洗衣机对象,此时计算机才能洗衣机是什么东西。

  4. 用户就可以借助计算机中洗衣机对象,来模拟现实中的洗衣机实体了。

在类和对象阶段,大家一定要体会到,类是对某一类实体(对象)来进行描述的,描述该对象具有那些属性,那些方法,描述完成后就形成了一种新的自定义类型,才用该自定义类型就可以实例化具体的对象。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3MbClEEN-1689233577543)(https://flowus.cn/preview/5a5dc4f3-210c-4a41-81ff-bc3fea2c44e9)]

总结

类与对象是C++非常重要的概念之一。
患难及困苦,是磨炼人格的最高学府。——苏格拉底

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

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

相关文章

物业管理微信小程序的设计与开发

1.物业管理微信小程序实现的功能 该微信小程序包含小程序端&#xff0c;后台管理端以及后端。 小程序端提供给业主使用&#xff0c;实现的功能模块有公告通知、访客预约、车位申请、装修申请、一键报修、报修单、意见反馈、缴费通知、一键求助、个人信息管理&#xff1b; 后台…

Docker安装xxl-job

创建数据库 xxl_job数据库下载地址&#xff1a;https://pan.baidu.com/s/1XkirmK8_NUGj967MuBIPlQ?pwddlyl 拉取镜像 docker pull xuxueli/xxl-job-admin:2.3.1 防火墙打开端口 firewall-cmd --zonepublic --add-port8088/tcp --permanent firewall-cmd --reload 启动运行…

Load balancer does not contain an instance for the service xxx-service

文章目录 问题描述&#xff1a;1、排查微服务应用的名字2、排查注解FeignClient注解3、排查SpringBoot、SpringCloud、Spring Cloud Alibaba、以及Nacos版本4、微服务在共同的命名空间和分组中5、修改配置 问题描述&#xff1a; 在使用NacosSpringBootOpenFeign搭建项目时&…

立式oled拼接屏有哪些产品优点?

葫芦岛oled拼接屏是一种高清晰度的显示屏&#xff0c;由多个oled屏幕拼接而成。它可以用于广告牌、展览、演示、会议等场合&#xff0c;具有高亮度、高对比度、高色彩饱和度、高刷新率等优点&#xff0c;能够吸引人们的眼球&#xff0c;提高信息传递效果。 葫芦岛oled拼接屏的优…

Docker笔记 Dockerfile镜像原理以及制作镜像

1. Docker 镜像原理 思考&#xff1a; Docker镜像本质是什么&#xff1f; 答&#xff1a;是一个分层的文件系统。Docker中一个centos镜像为什么只有200MB&#xff0c;而一个centos操作系统的iso文件要几个G&#xff1f; 答&#xff1a;Centos的iso镜像包含bootfs和rootfs&…

数据防泄密系统排名(数据防泄漏厂商排名)

在当今数字化时代&#xff0c;数据安全和隐私保护成为了企业和个人最为关注的问题之一。随着大数据的快速发展和广泛应用&#xff0c;数据泄露的风险也日益增加。为了应对这一挑战&#xff0c;各种数据防泄密系统应运而生&#xff0c;本文将为大家介绍数据防泄密系统的排名。 洞…

LayUi之手风琴的趣味案例

&#x1f973;&#x1f973;Welcome Huihuis Code World ! !&#x1f973;&#x1f973; 接下来看看由辉辉所写的关于LayUi的相关操作吧 目录 &#x1f973;&#x1f973;Welcome Huihuis Code World ! !&#x1f973;&#x1f973; 一.手风琴是什么 二.手风琴在什么时候使用…

亿发软件:工业4.0时代,MES智能制造系统引领传统生产制造业转型

随着制造企业迈入工业4.0时代&#xff0c;数字化智能制造的应用变得越来越重要。制造执行系统&#xff08;MES&#xff09;广泛应用于制造型企业生产管理中。工业智能制造MES系统帮助制造型企业实现智能制造升级&#xff0c;实现从需求、生产到交付全过程的智能工厂规划闭环管控…

no-unused-vars

找到 package.json 在rules输入 "no-unused-vars":"off"

【UE4 塔防游戏系列】01-前期准备

UE版本&#xff1a;4.24.3 课程视频链接&#xff1a;【虚幻4】UE4初学者进阶进阶教程&#xff08;合集&#xff09;-制作一个塔防游戏 1-8P&#xff08;全&#xff09;游戏单机游戏 步骤 1. 新建一个空白模板工程 2. 下载游戏资源 百度网盘 请输入提取码 提取码&#xf…

三菱fx2n以太网模块

大家好&#xff0c;今天要和大家分享一个有趣的故事&#xff0c;是关于一款神奇的以太网通讯处理器——捷米特JM-ETH-FX。这款产品来自捷米科技有限公司&#xff0c;是一款经济型的以太网通讯处理器&#xff0c;设计非常独特&#xff0c;能够满足日益增多的工厂设备信息化需求&…

基于linux下的高并发服务器开发(第一章)- 解决动态库加载失败的问题1.8

第一种方式&#xff1a;环境变量在终端配置&#xff0c;关掉终端就会失效 1、获取当前动态库所在路径 export LD_LIBRARY_PATH$LD_LIBRARY_PATH:/home/nowcoder/Linux/lesson06/library/lib ldd main ./main 第二种方式&#xff1a;永久配置环境变量&#xff08;用户级别配置…

测试面试时的经典问题分析

1. 接口测试是怎么做的&#xff0c;如何分析数据&#xff0c;可能需要讲一个实际的例子&#xff0c;比如请求的接口不对 参数不对 读取字段不对 接口我们做分为1.功能接口测试 2.接口自动化回归测试 我们接口的一个流程&#xff1a; a.需求分析 b.根据需求梳理接口测试点(评…

骨传导耳机效果怎么样?想入手骨传导耳机看这篇文章就够了

什么是骨传导传声&#xff1f;大家都知道声音是需要通过空气传播的&#xff0c;但是每个人听到的声音&#xff0c;除了大部分通过空气传播传入我们的耳朵&#xff0c;再由鼓膜振动传入听觉神经&#xff0c;还有一部分是通过骨骼的振动&#xff0c;不通过鼓膜的振动传递给听觉神…

mysql-windows 安装

今天&#xff0c;由于一个功能要用到mysql&#xff0c;所以下载了 mysql-8.0.33-winx64 的版本&#xff0c;突然发现&#xff0c;以前都是安装的Linux 版本&#xff0c;windows版本不会安装了&#xff0c;查看官网试着装了一次&#xff0c;记录本次经历&#xff1a; 软件下载 …

【项目管理】成本管理

一.成本管理的概述 在项目上对成本进行管理和控制是为了让项目经理真正了解完成项目所需要消耗的时间和所需要的资源&#xff0c;从而对其进行相应的成本控制。成本管理主要分成以下三个方面的内容&#xff1a; 二.成本估算 成本估算是对整个项目投入的各种资源的成本进行估算&…

数据结构--栈

一、栈 数组是一种连续存储、随机访问的线性表&#xff0c;链表属于分散存储、连续访问的线性表。它们每个数据都有其相对位置&#xff0c;有至多一个直接前驱和之多一个直接后继。栈&#xff08;Stack&#xff09;和队列&#xff08;Queue&#xff09;也属于线性表&#xff0c…

什么耳机带着舒服?这几款耳机戴过的人都说好

骨传导耳机凭借不入耳就能轻松听音乐的特点&#xff0c;被越来越多人所认识&#xff0c;相比传统的入耳式耳机&#xff0c;骨传导耳机拥有更多的可玩性&#xff0c;比如说跑步、游泳、健身都可以佩戴骨传导耳机&#xff0c;即使长时间佩戴也不会出现不适感&#xff0c;也不会出…

《CSDN铁粉经济学:如何快速涨粉并转化为铁粉》

目录 一、铁粉的定义 二、获取铁粉的方法 要获取铁粉&#xff0c;首先需要拥有粉丝。 &#x1f9e9;粉丝与铁粉的关系 &#x1f525;热榜与领域榜 三、我的创作路程 四、总结 首先解释什么是铁粉&#xff1a;官方定义为&#xff0c;在90天内阅读、购买专栏或其他互动&…