1,如果遇到派生类成员和基类成员的名称冲突的情况,程序会采用派生类成员执行相应的操作。如果需要使用基类中的同名成员,则必须在程序中使用全局分辨符“::”

虚基类 —— 派生类在继承基类时加入“virtual”关键字,应用中将只存在一个基类的拷贝;

如果同意继承层次中既有虚基类又有非虚基类,那么程序执行时会先调用虚基类构造函数,然后调用非虚基类构造函数,最后调用派生类构造函数

如果类中有成员类,成员类的构造函数被优先调用

2,类的默认访问方式是private

protected —— 相对于派生对象是公有的成员,相对于没有派生关系的对象是私有的成员

3,从C++本身来讲,struct 和 class 除了默认的成员访问权限不同之外,二者之间没有任何的区别 —— struct 中默认的成员访问权限是public,设计继承关系时,如果没有显式指定派生类与父类的继承方式,class的继承方式默认是private,而struct的继承方式默认是public

4,通过扩充派生类的构造函数,来实现向基类构造函数传递参数的操作: Derived(int x,int y):Base(y)

5,把函数体同函数调用相关联成为捆绑 (早期捆绑——由编译器和连接器在程序运行之前的编译阶段完成的;晚期捆绑——程序运行阶段动态确定调用的函数体)

晚期捆绑只对虚函数起作用,而且只发生在使用一个包含虚函数的基类地址时 —— 晚期捆绑是实现多态的基础

如果一个函数在基类中被声明为 virtual ,那么在所有的派生类中它都是virtual ,派生类中的重载的虚函数的返回类型必须与基类中的原型相同

虚函数不要重复定义(在继承类中)

6,纯虚函数 —— 被标明为不具体实现的虚成员函数,其允许函数先声明一个操作名称而不给出操作内容,当派生类继承它以后在根据具体的需求给出适当的定义

virtual void foo()=0; 实现一个公共的接口 —— 纯虚函数规定了继承该类的程序必须实现纯虚函数,否则程序就不能实例化

含有纯虚函数的类成为抽象类 —— 不能被实例化

如果派生类中没有将纯虚函数实现,则这个派生类仍然是一个抽象类

构造函数不能使virtual —— 没有意义;析构函数可以是virtual的 —— 当使用delete操作符删除对象时,隐含对析构函数的一次调用,若是虚函数,采用动态捆绑

7,sizeof 返回一个变量或数据类型在内存中所占用的字节数

地址是内存单元的编号,指针则用于存放内存地址

指针的运算 —— 取地址运算:&,返回指定变量在内存中的存储地址 ; * ,取内容运算,返回指针所指向的变量的内容

函数指针 —— 函数类型  (*指针变量名)(参数);    函数指针指向存储区中某个函数的入口地址,因此可以通过函数指针调用相应的函数,也可以充当函数的参数(传递形参的应是某个函数的入口地址 )

#include <stdio.h>
#include <IOSTREAM.H>
int Get(int (*)(int),int);
int gett(int);

void main()
{
	int num;
	num=100;
	cout<<Get(gett,num)<<endl;
}

int Get(int (*p)(int),int)
{
	return (*p)(int);
}

int gett(int i)
{
	return i;
}
 
指针函数 —— 返回类型为指针的函数
 
 
8,指针与const
const 位于指针声明符之前 —— 常量指针 —— 指针所指向的对象是一个常量

const char * ss= “world”; —— 程序中不能试图对ss所指向的存储单元中的内容做出修改

const 修饰符位于指针生命符之后 —— 指针常量 —— 指针所标识的地址不可改变

C++ 补课(二)的更多相关文章

  1. IM开发基础知识补课(五):通俗易懂,正确理解并用好MQ消息队列

    1.引言 消息是互联网信息的一种表现形式,是人利用计算机进行信息传递的有效载体,比如即时通讯网坛友最熟悉的即时通讯消息就是其具体的表现形式之一. 消息从发送者到接收者的典型传递方式有两种: 1)一种我 ...

  2. IM开发基础知识补课(四):正确理解HTTP短连接中的Cookie、Session和Token

    本文引用了简书作者“骑小猪看流星”技术文章“Cookie.Session.Token那点事儿”的部分内容,感谢原作者. 1.前言 众所周之,IM是个典型的快速数据流交换系统,当今主流IM系统(尤其移动 ...

  3. IM开发基础知识补课(七):主流移动端账号登录方式的原理及设计思路

    1.引言 在即时通讯网经常能看到各种高大上的高并发.分布式.高性能架构设计方面的文章,平时大家参加的众多开发者大会,主题也都是各种高大上的话题——什么5G啦.AI人工智能啦.什么阿里双11分分钟多少万 ...

  4. 从游击队到正规军(二):马蜂窝旅游网的IM客户端架构演进和实践总结

    一.引言 移动互联网技术改变了旅游的世界,这个领域过去沉重的信息分销成本被大大降低.用户与服务供应商之间.用户与用户之间的沟通路径逐渐打通,沟通的场景也在不断扩展.这促使所有的移动应用开发者都要从用户 ...

  5. 快速理解高性能HTTP服务端的负载均衡技术原理(转)

    1.前言 在一个典型的高并发.大用户量的Web互联网系统的架构设计中,对HTTP集群的负载均衡设计是作为高性能系统优化环节中必不可少的方案.HTTP负载均衡的本质上是将Web用户流量进行均衡减压,因此 ...

  6. 优秀后端架构师必会知识:史上最全MySQL大表优化方案总结

    本文原作者“ manong”,原创发表于segmentfault,原文链接:segmentfault.com/a/1190000006158186 1.引言   MySQL作为开源技术的代表作之一,是 ...

  7. 达达O2O后台架构演进实践:从0到4000高并发请求背后的努力

    1.引言   达达创立于2014年5月,业务覆盖全国37个城市,拥有130万注册众包配送员,日均配送百万单,是全国领先的最后三公里物流配送平台. 达达的业务模式与滴滴以及Uber很相似,以众包的方式利 ...

  8. 阿里技术分享:阿里自研金融级数据库OceanBase的艰辛成长之路

    本文原始内容由作者“阳振坤”整理发布于OceanBase技术公众号. 1.引言 OceanBase 是蚂蚁金服自研的分布式数据库,在其 9 年的发展历程里,从艰难上线到找不到业务场景濒临解散,最后在双 ...

  9. 一套高可用、易伸缩、高并发的IM群聊架构方案设计实践

    本文原题为“一套高可用群聊消息系统实现”,由作者“于雨氏”授权整理和发布,内容有些许改动,作者博客地址:alexstocks.github.io.应作者要求,如需转载,请联系作者获得授权. 一.引言 ...

  10. 知乎技术分享:从单机到2000万QPS并发的Redis高性能缓存实践之路

    本文来自知乎官方技术团队的“知乎技术专栏”,感谢原作者陈鹏的无私分享. 1.引言 知乎存储平台团队基于开源Redis 组件打造的知乎 Redis 平台,经过不断的研发迭代,目前已经形成了一整套完整自动 ...

随机推荐

  1. 关于table布局

    html-table 宝贝 状态 单价 数量 商品总价 运费 1sdsdf 2 3fffff 4sdfsfsffsdfs 5dsfs 6

  2. ora_tool

    #!/bin/ksh # # Copyright (c) 1998, 2002, Oracle Corporation.  All rights reserved. #   version() {   ...

  3. GoldenGate 日常监控

    正确启动数据库 源端启动数据库 SQL>  startup 源端启动goldengate GGSCI >  start mgr GGSCI >  start * 目标端启动数据库 S ...

  4. CSS的flex布局和Grid布局

    一.什么是 flex 布局 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这 ...

  5. bzoj1604 牛的邻居 STL

    Description 了解奶牛们的人都知道,奶牛喜欢成群结队.观察约翰的N(1≤N≤100000)只奶牛,你会发现她们已经结成了几个“群”.每只奶牛在吃草的时候有一个独一无二的位置坐标Xi,Yi(l ...

  6. 一次Linux LVM VG丢失完整找回过程记录

    某客户的一台PC服务器连接了一台HP EVA 的FC SAN存储,划了一个6T的LUN分作一个单独的VG使用,在某一次异常掉电之后,发现该VG完全丢失,使用vgs/pvs/lvs命令均无法找到此VG及 ...

  7. 紫书 习题 10-4 UVa 1644(素数筛)

    素数筛没什么好说的 #include<cstdio> #include<vector> #include<cstring> #define REP(i, a, b) ...

  8. 洛谷 P1125 笨小猴

    P1125 笨小猴 题目描述 笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼.但是他找到了一种方法,经试验证明,用这种方法去选择选项的时候选对的几率非常大! 这种方法的具体描述如下:假设max ...

  9. error C2440: “static_cast”: 无法从“LRESULT (__thiscall CTextProgressCtrl::* )(UINT,LPCTSTR)”转换为“LRESULT (__thiscall CWnd::* )(WPARAM,LPARAM)

    转自原文 error C2440 “static_cast” 无法从“void (__thiscall C* )(void)... error C2440: “static_cast”: 无法从“LR ...

  10. 【LeetCode-面试算法经典-Java实现】【057-Insert Interval(插入区间)】

    [057-Insert Interval(插入区间)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Given a set of non-overlapping in ...