Temporary Objects

本文介绍了一种用于在员工列表中查找特定员工地址的算法实现。通过迭代器遍历链表,对比员工姓名来定位地址信息。文章展示了使用C++标准库中的list容器,并讨论了不同实现方式及其潜在的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

string FindAddr(list<Employee> emps, string name) // const &, string& dangerous.
{
	// for most containers, calling end() returns a temporary object that must be constructed and detroyed.
	for(list<Employee>::iterator i = emps.begin(); i != emps.end(); i++)// emps.end(). i++
	{
		if( *i == name ) // implicit conversions. string to Employee?
		{
			return i->addr;
		}
	}
	return "";
}

const T T::operator++(int)
{
	T old(*this);
	++*this;
	return old;
}


const string& FindAddr( /* pass emps and name by reference */ )
{
	for( /* ... */ )
	{
		if( i->name == name )
		{
			return i->addr;
		}
	}
	static const string empty;
	return empty;
}

string& a = FindAddr(emps, "John Doe"); 
emps.clear();  // if emps is cleared. then, it not exist. and a is null.
cout << a; // error

string FindAddr(const list<Employee>& emps, const string& name) 
{
	list<Empoyee>::const_iterator iend(emps.end());
	for(list<Employee>::const_iterator i = emps.begin(); i != iend; ++i)
	{
		if(*i->name == name) // implicit conversions. string to Employee?
		{
			return i->addr;
		}
	}
	return "";
}

string FindAddr(const list<Employee>& emps, const string& name)
{
	list<Empoyee>::const_iterator i(find(emps.begin(), emps.end(), name));
	if (i != emps.end())
	{
		return i->addr;
	}

	return "";
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值