[转]常引用,const CString&,引用的效率

本文探讨了C++中常引用的有效应用,特别是在函数参数传递中的优势,避免了对象复制带来的性能损耗,并确保了参数不会被意外修改。

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

原文地址: http://blog.youkuaiyun.com/djimon/article/details/4276776

    C++的兴起,给一些形而上学或者一知半解的伪面向对象程序员,提供了诸多口实。致使他们在日常的编程中,疯狂的使用对象,常使我不寒而栗。上帝要毁灭一个人之前,总是先让他疯狂。

C++中,琳琅满目的书籍,也不遗余力的如此吹捧。可是事实证明,到目前为止,我们国家还没有任何一位高人写出任何一本令我叹为观止的C++教程,我不得不感慨万分。显然,每个接受C++面向对象思想的人,都应该清楚,所谓面向对象,绝对不是要面向一个矮胖的数据块,而是要用抽象的思维去建立一个几乎能够媲美现实世界的程序架构。

我们还是回到问题的本身。

对于函数中参数的传递来说,我确定一定以及肯定地认为,只要你无意使传入对象返回任何结果,你就应该将它声明为常引用。

什么叫常引用?很多人的脑袋开始像饥肠辘辘的肚子一样,叽叽咕咕的叫起来。

还是得先看看引用吧。

C++决定,任何人,任何时候,可以给一个已知的对象(或者变量)再起一个名字----这就是引用。表达式可以是这样:

int i = 9;

int& ii = i;

CString str(“idealsoft”);

CString& strAlias = str;

经常犹抱琵琶半遮面的引用,为它的粗心付出了代价。那个取地址的操作符“&”,很不情愿的站在了别名(alias)的左边,虽然它的心还在右边,虽然它还是在取用右边人物的地址,是的,是这样的,这就是引用,实质上就是将一个现有的地址赋给另外一个常地址。

我们都知道引用是不能再次赋值的,这符合const变量的特征,它被来自原变量的地址初始化。其实,就像它一样:

char* const p = “idealsoft”;

一个内容可以改变,而自身无法改变的指针,给了我们另外的一个神秘而诡异的名字,它就是传说中的引用。好,我们把它再加上一个const,让它的内容也不能被改变:

const char* const p = “idealsoft”;

这是什么妖怪?我曾经似乎在以前的const详解里边说过,这种指针在编程的时候基本上没有用武之地。那它到底是什么?其实,它就是一个常引用,就像是水中的月亮,你只能看,却永远也别指望碰到它。

好,我们就来看看水中的月亮。

Print(const CString& str) //骄傲的水中之月

{

printf(“I’m just %s/n”, str); //曾经我问过,为什么printf能够打印CString?

}

……

int main()

{

CString str(“idealsoft”);

Print(str);

}

我们为什么要用常引用?而不直接用C++“标榜”的对象,或者其它?显然,我们已经知道引用就相当于一个不可变的指针,在参数传递的时候,完全不必将整个对象压栈,而仅需压入一个指针,你可以想象一个充斥着一望无垠对象的程序,它的效率将会怎样的不堪入目。常引用则同时避免了,我们的参数被恶意的篡改。

打印之后,水中之月依然冷艳而一尘不染,在以后的日子里,想必,你也会像我一样,立即决定非她不娶并决定和她厮守终身。

6-1 P92-6图书馆类(带输出运算法重载) 分数 100 作者 陈佰平 单位 杭州电子科技大学 设计一个具有构造、复制赋值、移动构造和移动赋值功能的书本Book类,再设计一个含类型为Book的数据成员的图书馆类Library, 完成两个类的代码,通过main()函数测试。 函数接口定义: // 书 class Book { public: Book(const char *name, const char *isbn = "", float price=0.0, const char *text=""); // 构造函数 Book(const Book &copy); // 复制构造函数 Book(Book &&copy) noexcept; // 移动构造函数 Book & operator=(const Book &copy); // 重载赋值运算符 Book & operator=(Book && copy) noexcept; // 移动赋值 void setText (const char *text); // 修改书的描述 ~Book() { delete [] strText; } // 析构函数 void Show() const; // 显示书本:名称(isbn, 价格): 书的描述 friend ostream& operator<<(ostream& out,const class Book& bk); private: char name[128]; // 书名 char ISBN[32]; // ISBN号 float price; // 价格 char *strText; // 书的描述 }; // 图书馆 class Library { public: Library(const char *name, int size=100); // 默认构造函数 Library(const Library & copy); // 拷贝构造 Library(Library && copy) noexcept; // 移动构造 Library & operator= (const Library &copy); // 赋值 Library & operator= (Library &&copy) noexcept; // 移动赋值 void Show(); // 显示名称和藏书数量 void addBook(const Book &book); // 增加一本书的收藏 vector<Book> & getBooks(); // 获取图书 friend ostream& operator<<(ostream& out,const class Library& lib); private: char name[128]; // 图书馆的名字 vector<Book> books; // 收藏的书 }; 根据题干和main()自行推导函数接口。 裁判测试程序样例: #include <iostream> #include <cstring> #include <utility> #include <vector> using namespace std; // 书 class Book { public: Book(const char *name, const char *isbn = "", float price=0.0, const char *text=""); // 构造函数 Book(const Book &copy); /
03-26
``` int CSocketClientJNMES::SendMTFData(const string & info, string & resultMSG, const string & hostname, const int & port, const string & apiPath) { CInternetSession session(_T("MyPostAgent")); try { CHttpConnection* pServer = session.GetHttpConnection ( m_GFunction.String2CString(hostname), port, _T(""), _T("") ); m_Loger.RecordLogTcpClientJNURL("hostname:" + hostname + "port:" + to_string(port) + "CHttpConnection* pServer"); CHttpFile* pFile = pServer->OpenRequest ( CHttpConnection::HTTP_VERB_POST, m_GFunction.String2CString(apiPath) ); m_Loger.RecordLogTcpClientJNURL(apiPath + "CHttpFile* pFile = pServer->OpenRequest"); CString strHeaders = _T("Content-Type: application/json"); CString strData = m_GFunction.String2CString(info); m_Loger.RecordLogTcpClientJNURL("info:" + info); pFile->SendRequest ( strHeaders, (DWORD)strHeaders.GetLength(), (LPVOID)(LPCTSTR)strData, (DWORD)strData.GetLength() ); m_Loger.RecordLogTcpClientJNURL("pFile->SendRequest"); DWORD dwStatusCode; pFile->QueryInfoStatusCode(dwStatusCode); CString strResponse; if (dwStatusCode == HTTP_STATUS_OK) { TCHAR szBuffer[1024]; while (pFile->Read(szBuffer, 1023) > 0) { strResponse += szBuffer; } AfxMessageBox(strResponse); } resultMSG = m_GFunction.CString2String(strResponse); m_Loger.RecordLogTcpClientJNURL("resultMSG:" + resultMSG); pFile->Close(); delete pFile; delete pServer; } catch (CInternetException* pEx) { TCHAR szError[1024]; pEx->GetErrorMessage(szError, 1024); AfxMessageBox(szError); pEx->Delete(); } return 0; }```分析代码并优化
最新发布
04-05
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值