栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

上机4.1

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

上机4.1

part a

按值传递

#include 
using namespace std;
class tr
{
public:
	tr(int n)
	{
		i = n;
	}
	void set_i(int n)
	{
		i = n;
	}
	int get_i()
	{
		return i;
	}
private:
	int i;
};
void sqr_it(tr ob)
{
	ob.set_i(ob.get_i() * ob.get_i());
	cout << "在函数sqr_it内,形参对象ob的数据成员i的值为:" << ob.get_i();
	cout << endl;
}
int main()
{
	tr obj(10);
	cout << "调用函数sqr_it前,实参对象obj的数据成员i的值为:";
	cout << obj.get_i() << endl;
	sqr_it(obj);
	cout << "调用函数sqr_it后,实参对象obj的数据成员i的值为:";
	cout << obj.get_i() << endl;
	return 0;
}

运行结果如下 

这种传递是把实参表达式的值传送给对应的形参变量,所以调用函数本身不对实参进行操作,也就是说,即使形参的值在函数中发生了变化,实参的值也完全不会受到影响,仍为调用前的值。

 地址传递

void sqr_it(tr* ob)
{
	ob->set_i(ob->get_i() * ob->get_i());
	cout << "在函数sqr_it内,形参对象ob的数据成员i的值为:" << ob->get_i();
	cout << endl;
}
int main()
{
	tr obj(10);
	cout << "调用函数sqr_it前,实参对象obj的数据成员i的值为:";
	cout << obj.get_i() << endl;
	sqr_it(&obj);
	cout << "调用函数sqr_it后,实参对象obj的数据成员i的值为:";
	cout << obj.get_i() << endl;
	return 0;
}

结果如下

地址传递把实参的存储地址传送给对应的形参,从而使得形参指针和实参指针指向同一个地址。因此,被调用函数中对形参指针所指向的地址中内容的任何改变都会影响到实参。

引用传递

void sqr_it(tr& ob)
{
	ob.set_i(ob.get_i() * ob.get_i());
	cout << "在函数sqr_it内,形参对象ob的数据成员i的值为:" << ob.get_i();
	cout

结果如下

以引用为参数,则既可以使得对形参的任何操作都能改变相应的数据,又使得函数调用显得方便、自然。引用传递方式是在函数定义时在形参前面加上引用运算符“&”。

part b

用静态数据成员计算由同一类建立的对象数量

#include 
using namespace std;
class ctest
{
	static int count;
public:
	ctest()
	{
		++count; cout << "对象数量=" << count << 'n';
	}
};
int ctest::count = 0;
int main(void)
{
	ctest a[3];
	return 0;
}

 因为类的静态数据成员的存在不依赖与于任何类对象的存在,类的静态数据成员应该在代码中被显式地初始化,一般要在类外进行。

part c
#include 
using namespace std;
class tstudent
{
	static float m_classmoney;
public:
	void initstudent(char name[])
	{
		name[1] = 'A';
		name[2] = 'B';
		name[3] = 'C';
	}
	void expendmoney(float money)
	{
		m_classmoney = m_classmoney - money;
	}
	void showmoney()
	{
		cout << "班费还剩余:" << m_classmoney << 'n';
	}
};
float tstudent::m_classmoney = 1000;
int main()
{
	tstudent A;
	A.expendmoney(50);
	A.showmoney();
	tstudent B;
	B.expendmoney(98.5);
	B.showmoney();
	tstudent C;
	C.expendmoney(500.53);
	C.showmoney();
}

运行结果如下

         总结一下三种传递的不同,首先它们都是可以把值传递给函数的只不过是传递的方式不同,有一点是可以很明显的,指针传递和引用传递都会改变i的值,值传递不会,这就是值传递和另外的区别,而指针传递和引用传递的不同的地方则是指针传递的是i的地址,而引用传递则等于给i起了一个别名,然后通过别名来操作b的值,和它所在的内存地址。

        如上代码所示,静态数据成员的定义“float tstudent::m_classmoney = 1000;”需要在类外进行,因为静态数据成员不能在类中初始化,实际上类定义只是在描述对象的蓝图,在其中指定初值是不允许的。也不能在够造函数中初始化该成员,因为静态数据成员为类的各个对象共享,那么每次创建一个类的对象则静态数据成员都要被重新初始化。

        虽然这些概念较为抽象,难以理解,但是结合实际程序运行结果,还是能有直观的感受来帮助我学习,以后还是要多运行一些程序来锻炼自己

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/628826.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号