c++命名对象和匿名对象的解析

 更新时间:2021年10月26日 15:16:43   作者:原十  
像按值传递的对象(函数入参,函数返回值)都是匿名对象,那匿名对象的特点是什么呢?下面通过实例代码给大家解析c++命名对象和匿名对象的相关知识,感兴趣的朋友一起看看吧

最近在看muduo库,对里面的日志库比较感兴趣,于是看到了以下的语句:

 刚看到这些语句时,和平时遇到日志打印的语句不太一样,很疑惑这样一条语句是怎么把日志打印出来的。网上搜索一翻后,学到了一个知识点:匿名对象。其实在平时的编码中我们也经常会遇到匿名对象,只是没有关注。简单的一个匿名对象如:

std::string anonymous = std::string("anonymous");

像按值传递的对象(函数入参,函数返回值)都是匿名对象,那匿名对象的特点是什么呢?通过下面一段代码可知:

#ifndef __CLOGER_H__
#define __CLOGER_H__
 
#include <string>
#include <stdlib.h>
#include <stdio.h>
 
class CLoger
{
public:
    explicit CLoger(std::string &str): mStr(str)
    {
 
    }
 
    ~CLoger()
    {
        printf("destructor mStr = %s\n", mStr.c_str());
    }
 
    std::string &string()
    {
        return mStr;
    }
private:
    std::string mStr;
};
 
#endif
 
#include "anonymous_object.h"
int main()
{
    std::string name("name");
    CLoger loger(name); //具名对象,main函数退出后才会销毁
 
    std::string anonymous("anonymous");
    CLoger(anonymous).string(); //匿名对象,使用完即销毁,即此语句结束后立即调用其析构函数
    printf("main finish!\n");
    return 0;
}

运行结果如下:

1,命名对象(非new)在离开作用域后,调用析构函数。

2,匿名对象在离开定义它的语句后,调用析构函数。

了解匿名对象的特点后,回到上面的日志打印语句,如其中一条语句:

#define LOG_TRACE if (CLogger::logLevel() <= CLogger::TRACE) \

  CLogger(__FILE__, __LINE__, CLogger::TRACE, __func__).stream()

定义了一个匿名对象CLogger,在调用完这条语句后,调用其析构函数:

CLogger::~CLogger()
{
    mImpl.finish();  //打印结尾添加文件名和行号
    const CLogStream::Buffer& buf(stream().buffer());
    g_output(buf.data(), buf.length()); //函数指针调用,默认是输出到标准输出stdout,这里是日志最终输出的语句
 
    if (mImpl.mLevel == FATAL)
    {
        g_flush();
        abort();
    }
}

 所以,只要调用语句如LOG_INFO:

int main(int argc, char* argv[])
{  
    char name[256];
    strncpy(name, argv[0], 256);
    CAsyncLogging log(::basename(name), kRollSize);
    log.start();
    g_asyncLog = &log;
 
    bool longLog = argc > 1;
    // bench(longLog);
    LOG_INFO << "loggingTest!";
 
    return 0;
}

这个日志库已经被我抽离出来,可以单独编译一个日志库,有兴趣的同学可以到git下载。

到此这篇关于c++命名对象和匿名对象的解析的文章就介绍到这了,更多相关c++命名对象和匿名对象内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C语言 分支语句详解分析

    C语言 分支语句详解分析

    分支结构的执行是依据一定的条件选择执行路径,而不是严格按照语句出现的物理顺序。分支结构的程序设计方法的关键在于构造合适的分支条件和分析程序流程,根据不同的程序流程选择适当的分支语句
    2021-10-10
  • C++设计模式之外观模式

    C++设计模式之外观模式

    这篇文章主要介绍了C++设计模式之外观模式,本文详细讲解了C++中的Facade模式,并给出了实例代码,需要的朋友可以参考下
    2014-10-10
  • C++结构体与类指针知识点总结

    C++结构体与类指针知识点总结

    在本篇文章里小编给大家整理了关于C++结构体与类指针知识点以及相关内容,有兴趣的朋友们参考学习下。
    2019-09-09
  • C语言多种方法实现一个函数左旋字符串中K个字符

    C语言多种方法实现一个函数左旋字符串中K个字符

    这篇文章主要为大家介绍了C语言多种方法实现一个函数,可以左旋字符串中K个字符,文中附含详细的示例讲解,有需要的朋友可以借鉴参考下
    2021-10-10
  • C语言实现简单通讯录功能

    C语言实现简单通讯录功能

    这篇文章主要为大家详细介绍了C语言实现简单通讯录功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 一篇文章带你了解C++(STL基础、Vector)

    一篇文章带你了解C++(STL基础、Vector)

    这篇文章主要为大家详细介绍了C++ STL基础,vector向量容器使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能给你带来帮助
    2021-08-08
  • C语言实现共享单车管理系统

    C语言实现共享单车管理系统

    这篇文章主要为大家详细介绍了C语言实现共享单车管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C++实例分析讲解临时对象与右值引用的用法

    C++实例分析讲解临时对象与右值引用的用法

    对性能来说,许多的问题都需要和出现频率及本身执行一次的开销挂钩,有些问题虽然看似比较开销较大,但是很少会执行到,那也不会对程序有大的影响;同样一个很小开销的函数执行很频繁,同样会对程序的执行效率有很大影响。本章中作者主要根据临时对象来阐述这样一个观点
    2022-08-08
  • 通俗易懂讲解C语言与Java中二叉树的三种非递归遍历方式

    通俗易懂讲解C语言与Java中二叉树的三种非递归遍历方式

    二叉树是一种非常重要的数据结构,很多的数据结构都是基于二叉树的基础演变过来的。二叉树的前,中,后3种遍历方式,因为树的定义本身就是递归定义的,所以采用递归的方法来实现是很简单的
    2021-09-09
  • C语言实现快速排序

    C语言实现快速排序

    这篇文章主要为大家详细介绍了C语言实现快速排序算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08

最新评论