1、C++ 类的声明:
class class_name
{
    private:
        /*
        *私有的数据和成员函数
        *只能被本类中的成员函数引用,类外不能调用
        *友元类例外
        */
    public:
        /*
        *公共的数据和成员函数
        *可以被本类中的成员函数引用,也可以被类的作用域内的其他函数引用
        */
    protected:
        /*
        *受保护的数据和成员函数
        *不能被类外访问,但可以被派生类的成员函数访问
        */
};

2、在类外定义成员函数
void class_name::fanction_name()
{
    //函数体
}

3、定义内置函数
inline void class_name::fanction_name()
{
    /*
    * 内置函数在正真执行时,是把函数代码嵌入到程序的调用点
    * 以减少调用成员函数的时间开销
    * 内置函数的要求:函数规模很小,调用频率较高
    */
}

4、定义类的对象
    class_name name_1,name_2;

5、对象成员的引用
(1) 通过对象名和成员运算符访问对象中的成员
    class_name name_1;
    name_1.fanction_name();

(2)通过指向对象的指针访问对象中的成员
    class_name name_1,*p; //定义对象 name_1 和 class_name 类的指针变量 p
    p = &name_1;          //是 p 指向对象 name_1
    p->fanction_name();

(3)通过对象的引用来访问对象中的成员
    class_name name_1;
    class_name & name_2 = name_1; //定义类的引用变量 name_2 并使之初始化为 name_1
    name_2.fanction_name();       
    /*
    *name_1 和 name_2 共同占用一段内存
    *所以 name_2.fanction_name() 就是 name_1.fanction_name()
    */

6、构造函数
(1)构造函数的简介:
    构造函数是用来处理对象的初始化;
    构造函数的名字必须与类名同名,不能任意命名;
    构造函数不能被用户调用,而是在建立对象时自动执行;
    构造函数不具有任何类型,不返回任何值;

(2)构造函数在类外的定义
    //先在定义类时的 public 中声明构造函数
    class_name();
    //在在类外定义
    class_name::class_name()
    {
        /*如果用户自己没有定义构造函数,则 C++ 系统会自动生成一个构造函数,
        * 只是这个构造函数的函数体是空的,不执行初始化操作
        */
    }

(3)带参数的构造函数
    class class_name
    {
        public:
            class_name(int,int,int); //声明带参数的构造函数
        private:
            int height;
            int width;
            int lengh;
    };

//在类外定义带参数的构造函数
    class_name::class_name(int a,int b,int c)
    {
        height = a;
        width = b;
        lengh = c;
    }

//定义对象并给三个成员变量赋初值
    class_name name_1(1,2,3);

(4)构造函数的重载
    在一个类中定义多个构造函数,以便对类的对象提供不同的初始化方法,
    这些构造函数具有相同的名字,而参数的个数或参数的类型不同
    编译器根据定义对象时给对象赋值的参数去确定对应的构造函数

//在类的定义中声明构造函数
    class_name(); //声明一个无参数的构造函数
    //声明一个有参数的构造函数,用参数的初始化表对数据成员初始化
    class_name(int a,int b,int c):height(a),width(b),lengh(c){}

//定义对象
    class_name::name_1;  //定义对象 name_1 不指定实参,这时调用第一个构造函数
    class_name::name_2(1,2,3);//定义对象 name_2 指定实参,这时调用第二个构造函数

7、析构函数
    //析构函数在定义类时的声明
    ~class_name();

//在类外的定义
    class_name::~class_name()
    {
        //析构函数的作用是在撤销对象占用的内存之前完成一些清理工作
    }

8、this指针
    在每一个成员函数中都包含一个特殊的指针 this ,它是指向本类对象的指针
    它的值是当前被调用的成员函数所在的对象的起始地址
    this 指针是用来区分不同对象的成员函数引用其对应的数据成员

9、派生与继承
(1)派生类的声明
    //声明基类是 class_name 以公用继承方式的派生类 class_name_1
    class class_name : public class_name_1
    {
        private:
            //派生类中新增的成员
        public:
    };

(2)派生类成员的访问属性
    基类成员函数不能访问派生类的成员
    派生类的成员函数根据继承方式不同而不同:

公用继承
    ———————————————————————————————————
    基类成员      |    派生类中的访问属性
    ———————————————————————————————————
    私有成员      |    不可访问
    ———————————————————————————————————
    公用成员      |    公用
    ———————————————————————————————————
    保护成员      |    保护
    ———————————————————————————————————
             私有继承
    ———————————————————————————————————
    基类成员      |    派生类中的访问属性
    ———————————————————————————————————
    私有成员      |    不可访问
    ———————————————————————————————————
    公用成员      |    私有
    ———————————————————————————————————
    保护成员      |    私有
    ———————————————————————————————————
              保护继承
    ———————————————————————————————————
    基类成员      |    派生类中的访问属性
    ———————————————————————————————————
    私有成员      |    不可访问
    ———————————————————————————————————
    公用成员      |    保护
    ———————————————————————————————————
    保护成员      |    保护
    ———————————————————————————————————

10、友元
(1)友元的含义:
    在一个类中声明一个外部函数或者另一个类的成员函数
    为友元,则这个函数就可以访问这个类的私有数据

(2)友元的声明
    //在类的定义时声明外部函数 fanction_name 为友元
    friend void fanction_name(class_name &);    
    //在 class_name 类的定义时声明 class_name_1 的成员函数 fanction_name 为友元
    friend void class_name_1::fanction_name(class_name &);

C++类的复习的更多相关文章

  1. UML:类图复习-鸡生蛋,蛋生鸡

    这是前一阵<高级软件工程>课堂上,老师随堂出的一道讨论题,随手贴在这里: ps: 今天是520,正好聊一些OoXx,关于爱的扯淡话题:) 题目:“鸡生蛋,蛋孵鸡”,世间万物生生不息,如何用 ...

  2. 反射、反射机制、类加载、Class类专题复习

    一.反射概念 1.反射机制允许程序在执行期借助于ReflectionAPI取得任何类的内部信息(比如成员变量,构造器,成员方法等等),并能操作对象的属性及方法.反射在设计模式和框架底层都会用到. 2. ...

  3. [java] 可视化日历的实现(基于Calendar类 )

    写在前面 博文安排顺序如下 1.写在前面 2.源码 3.思路 4.相关知识 该小程序是对Date类及其相关类的复习 要求如下图:实现可视化日历 实现思路 1.先从键盘输入指定格式的字符串(str)2. ...

  4. Java类的继承与多态特性-入门笔记

    相信对于继承和多态的概念性我就不在怎么解释啦!不管你是.Net还是Java面向对象编程都是比不缺少一堂课~~Net如此Java亦也有同样的思想成分包含其中. 继承,多态,封装是Java面向对象的3大特 ...

  5. [Code::Blocks] Install wxWidgets & openCV

    The open source, cross platform, free C++ IDE. Code::Blocks is a free C++ IDE built to meet the most ...

  6. Java基础笔记-多线程

    线程: 方式一:继承Thread类并且复写run方法. 格式: class MyThread extends Thread { public void run() { 线程中要运行的代码. } } 其 ...

  7. CALayer & UIView 关系浅析

    原文链接:http://www.jianshu.com/p/8e6a313c158e 一.CALayer和UIView的关系 UIView显示在屏幕上归功于CALayer 可以说:UIView依赖CA ...

  8. CALayer --> UIView

    一.CALayer和UIView的关系 UIView显示在屏幕上归功于CALayer 可以说:UIView依赖CALayer,又高于CALayer 通过调用drawRect方法来渲染自身的内容,调节C ...

  9. 本人SW知识体系导航 - Programming menu

    将感悟心得记于此,重启程序员模式. js, py, c++, java, php 融汇之全栈系列 [Full-stack] 快速上手开发 - React [Full-stack] 状态管理技巧 - R ...

随机推荐

  1. webpack 配置学习笔记

    最简单的 webpack 配置 const path = require('path') module.exports = { entry: './app/index.js', output: { p ...

  2. 调用webservice接口

    这里是cxf服务器,采用myeclipse6.5,把wsdl放到本地的方式. 新建一个包, 把解析到的类放在这个包下面. 生成的代码结构: 调用: public static String callI ...

  3. [bzoj1798][Ahoi2009]Seq——线段树+多重标记下传

    题意 请你写一个数据结构,支持: 子序列同加 子序列同乘 统计子序列和 题目 线段树裸题,但对于我这种初学者还是非常难写. 我们维护两个标记,一个是在这个节点上作过的所有乘法操作,一个是加法操作,始终 ...

  4. 智能合约安全-parity多重签名钱包安全漏洞

    漏洞原因: 因为initWallet函数是公开函数( public function) , 攻击者调用initWallet,重新初始化钱包会把之前合约钱包所有者覆盖, 即可改变钱包所有者. 漏洞代码: ...

  5. [转]如何整理Linux磁盘碎片,竟与Windows的方式大不同 返回操作系统首页

    Linux 系统永远不需要整理磁盘碎片的神话相信很多人都听说过.由于 Linux 采用了优秀的日志文件系统(ext2.ext3.ext4, btrfs等),在绝大多数情况下确实是不需要进行磁盘碎片整理 ...

  6. 【bzoj2796】 [Poi2012]Fibonacci Representation

    给出一个数字,用FIB数列各项加加减减来得到. 问最少要多少个(可以重复使用) 大概试了一下,fibonacci数列的增长是很快的,大概到了90+项就超过了题目范围…… 所以每次找一个最近的fibon ...

  7. 【bzoj4636】蒟蒻的数列

    由于数据范围过大,直接线段树会炸,离散化或者动态开点都行. 打个标记在树上,最后把树dfs一边算一下即可. #include<bits/stdc++.h> #define N 100000 ...

  8. [ 手记 ] 关于tomcat开机启动设置问题

    今天尝试将tomcat设置为开机启动,大家都知道只需要将启动脚本添加到/etc/rc.local下面开机就会自动执行. /usr/local/tomcat8./bin/startup.sh >& ...

  9. 解决 org.aspectj.weaver.ResolvedType$Array cannot be cast to org.aspectj.weaver.ReferenceType

    参考:http://www.cnblogs.com/qgc88/p/3283217.html 解决方法: 删除aspectjweaver.jar和aspect.jar 加入aspectjweaver- ...

  10. debian 更换sh的默认链接为bash

    https://blog.csdn.net/mudongliangabcd/article/details/43458895