标签:c templates pass-by-reference c03
我想拥有
template <class T>
void foo(T &t);
能够接受临时对象,而不会通过引用接受其他对象并在其上调用非const方法.可能在C 03?
我意识到我可能会强制用户将其对象的所有方法声明为const,并将所有成员声明为可变,然后使用const T& t引用,但这是一个丑陋的解决方法.
解决方法:
您可以创建第二个带有const类型引用的函数,并为非const类型引用创建一个副本.
template <class T>
void foo (T &t);
template <class T>
void foo (const T &x) {
T copy(x);
foo(copy);
}
可以找到一个示范here.
该技术具有无法区分临时对象和临时对象的限制.这样做的结果是你的原始foo()不允许自己传递一个const对象.这个提议允许他们,因此你失去了最初提供的安全性.您可以通过将foo的const类型版本重命名为foo_for_temp来弥补这一点.然后,调用者将知道该函数的意图.
标签:c,templates,pass-by-reference,c03 来源: https://codeday.me/bug/20190901/1780944.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。