zoukankan      html  css  js  c++  java
  • C++与C的区别二

    1. new,delete的局部重载:

    #include <iostream>
    using namespace std;
    
    int objs = 0;
    
    class myclass
    {
    public:
        myclass()
        {
            //objs++;
            cout << "create" << endl;
        }
        ~myclass()
        {
            //objs--;
            cout << "delete" << endl;
        }
        //operator重载,针对new重新作出一种解释,只针对当前类
        static void * operator new(size_t size)
        {
            objs++;
            cout << "new-call" << endl;
            myclass *p = ::new myclass;    //全局new
            return p;
        }
        static void operator delete(void *p)
        {
            objs--;
            cout << "delete-call" << endl;
            ::delete p;
        }
    };
    //功能1:无法在堆上被创建的类
    void main()
    {
        myclass *p1 = new myclass;
        myclass *p2 = new myclass;
        myclass *p3 = new myclass;
        delete p1;
    
        int *p = new int(5);    //此时new重载对于这一句无效
    
        cout << objs << endl;
    
        cin.get();
    }

        

    #include <iostream>
    using namespace std;
    
    int objs = 0;
    void *g_p = nullptr;
    
    class myclass
    {
    public:
        myclass()
        {
            //objs++;
            cout << "create" << endl;
        }
        ~myclass()
        {
            //objs--;
            cout << "delete" << endl;
        }
    
        //operator重载,针对new重新作出一种解释,只针对当前类
        static void * operator new(size_t size)
        {
            if (g_p==nullptr)
            {
                objs++;
                cout << "new-call" << endl;
                myclass *p = ::new myclass;    //全局new
                g_p = p;    //单例,堆上创建对象只有一个
                return p;
            } 
            else
            {
                return g_p;
            }
        }
    
        static void operator delete(void *p)
        {
            if (g_p!=nullptr)
            {
                objs--;
                cout << "delete-call" << endl;
                ::delete p;
                g_p = nullptr;
            } 
        }
    };
    //功能1:无法在堆上被创建的类
    //功能2:实现统计分配内存,释放内存的次数
    //实现单例设计模式,实现避免反复delete出错
    //new delete在内部,只针对当前类,int double 无影响
    void main()
    {
        myclass *p1 = new myclass;
        myclass *p2 = new myclass;
    
        delete p1;
        delete p1;    //规避了两次delete的错误
    
        cin.get();
    }

        

    2. 全局new,delete重载:

    #include <iostream>
    using namespace std;
    
    //全局内存管理,统计释放内存,分配内存
    //new        new []        delete        delete []
    //分配内存优先于构造
    //析构优先于释放内存
    void * operator new(size_t size)
    {
        cout << "g_new call" << endl;
        void *p = malloc(size);    //全局的new,只能使用malloc
        return p;
    }
    void * operator new [](size_t size)
    {
        cout << "g_new [] call" << endl;
        cout << size << endl;
        return operator new(size);    //每个元素调用一次new
    }
    
    void operator delete(void *p)
    {
        cout << "g_delete call" << endl;
        free(p);
    }
    void operator delete [](void *p)
    {
        cout << "g_delete [] call" << endl;
        free(p);
    }
    
    class myclass
    {
    public:
        myclass()
        {
            cout << "create call" << endl;
        }
        ~myclass()
        {
            cout << "delete call" << endl;
        } 
    };
    
    void main()
    {
        int *p1 = new int(5);
        delete p1;
    
        myclass *p2 = new myclass;
        delete p2;
    
        myclass *px = new myclass[10];
        delete[]px;
    
        cin.get();
    }

        

     3. 绑定类成员函数:

    #include <iostream>
    #include <functional>
    
    using namespace std;
    using namespace std::placeholders;//站位
    
    struct MyStruct
    {
        void add1(int a)
        {
            cout << a << endl;
        }
        void add2(int a, int b)
        {
            cout << a << b << endl;
        }
        void add3(int a, int b, int c)
        {
            cout << a << b << c << endl;
        }
    };
    
    void main()
    {
        MyStruct my1;
        //my1.add(10);
    
        //绑定包装器,包装类成员函数,用于使用
        auto fun1 = bind(&MyStruct::add1, &my1, _1);//有1个参数  函数名、对象地址、参数
        fun1(10);
    
        auto fun2 = bind(&MyStruct::add2, &my1, _1,_2);//有2个参数
        fun2(100,200);
    
        auto fun3 = bind(&MyStruct::add3, &my1, _1,_2,_3);//有3个参数
        fun3(1000,2000,3000);
    
        cin.get();
    }

    4. 绑定lambda表达式以及仿函数:

    #include <iostream>
    #include <functional>
    
    using namespace std;
    using namespace std::placeholders;
    
    int add(int a, int b,int c)
    {
        return a + b+c;
    }
    
    struct MyStruct
    {
        int operator()(int a,int b)    //仿函数
        {
            return a + b;
        }
    };
    
    void main()
    {
        auto fun1 = bind(add, 10,12, _1);//适配器模式
        cout << fun1(1000) << endl;        //1022
    
        auto fun2 = bind([](int a, int b)->int {return a + b; }, 100, _1);
        cout << fun2(123) << endl;        //223
    
        MyStruct my1;
        cout << my1(1, 2) << endl;        //3
        auto fun3 = bind(my1, 100, _1);    //绑定
        cout << fun3(100) << endl;        //200
            
        cin.get();
    }

    5. 静态断言:

    #include <iostream>
    #include <cassert>
    using namespace std;
    
    int divv(int a, int b)
    {
        assert(b != 0);    //断言
        return a / b;
    }
    
    void main()
    {
        cout << divv(1, 0) << endl;
    
        cin.get();
    }
    #include <iostream>
    #include <cassert>
    using namespace std;
    
    static_assert(sizeof(void *) >= 8, "environment is not 64!");
    
    void main()
    {
    
        cin.get();
    }

        

    6. 内联函数:

    #include <iostream>
    #include <cstdlib>
    using namespace std;
    
    #define f(x) x*x*x        //C语言内联,C++要求类型严格匹配
    
    inline int get(int x)    //C++的内联函数
    {
        return x*x*x;
    }
    //提高程序运行速度
    
    //inline 只是对于编译器的建议
    //一般情况下,我们对内联函数做如下的限制:
    //(1)不能有递归;
    //(2)不能包含静态数据;
    //(3)不能包含循环;
    //(4)不能包含switch和goto语句;
    //(5)不能包含数组。
    //若一个内联函数定义不满足以上限制,则编译系统把它当做普通函数对待
    
    template<class T>
    inline T go(T t)
    {
        return t*t;
    }
    
    void main()
    {
        get(10);
    
        go(5);    //优化为内联函数
    
        auto fun = []() {};    //lambda表达式实际上也是内联函数
    
        cin.get();
    }

    7. CPP处理转义字符:

    #include <iostream>
    #include <string>
    #include <cstdlib>
    
    using namespace std;
    
    void main()
    {
        //string str(""C:\Program Files (x86)\Google\Chrome\Application\chrome.exe"");
        string str(R"("C:Program Files (x86)GoogleChromeApplicationchrome.exe")");            //  R"(......)" 
    
        system(str.c_str());
    
        cin.get();
    }
  • 相关阅读:
    从零基础到软件开发,应该走怎样的路?入门者不妨看看这 5 步!
    C/C++编程笔记:C语言入门知识点(二),请收藏C语言最全笔记!
    学编程不知如何入门?10 年经验的底层开发程序员,教你如何入门!
    C/C++编程笔记:C语言入门知识点(一),请收藏C语言最全笔记!
    编程入门须知:都说零基础不好学编程,那么什么是编程基础?
    C/C++编程笔记:编写完成了一个C/C++程序,如何做一个界面出来?
    编程入门必看:带你零基础了解编程和编程语言,入门应该学什么?
    python编程从零基础到项目实践第五章学习--字典
    python编程从零基础到项目实践第四章学习--列表与原组(2)元组相关
    python编程从零基础到项目实践第四章学习--列表与原组(1)列表相关
  • 原文地址:https://www.cnblogs.com/si-lei/p/9511246.html
Copyright © 2011-2022 走看看