C++后台知识点总结(一)
C++基础部分:
1.数组和指针的区别
2. C++中struct和class的区别
3.构造函数能不能是虚函数?
不可以,因为虚函数的调用必须通过虚函数表查找来实现,只有通过类对象前4个字节(32位系统)虚函数表指针找到对应类的虚函数表,才能访问虚函数,而虚函数表指针的生成是在构造函数中完成的,如果构造函数是虚函数,那么就只能通过虚表指针才能访问到,关键是此时就需要让构造函数产生出虚表指针。陷入了先有蛋还是现有鸡的问题。
4.析构函数可不可以是纯虚函数?
不建议是,因为我们知道纯虚函数是没有实现体的,那么子类对象在析构的时候,父类组成部分就没办法释放,显然不行。但是对于大部分编译器来说,可以将析构函数申明为纯虚函数,然后在类外写纯虚函数的实现体,从语法上不会报错。
5.构造函数和析构函数的调用顺序
C++标准规定构造函数是先调用基类的再调用子类的,而析构函数则是先调用子类的再调用基类的。
数据库部分:
1.索引的优缺点
优点: (1) 可以有效减少数据检索的时间,提高查询效率;
(2) 建立索引的列可以保证行的唯一性;
(3) 可以加快表与表的连接,提高表与表之间的联合查询效率;
缺点: (1)创建索引、维护索引都需要花费时间和空间成本,每条索引都要占据数据库的存储空间;
(2)在增删改的时候都需要对索引进行动态维护,也会花费时间和空间成本;
2.索引的应用场景
接触比较多的主要有以下三个场景:(1) 数据量大并且查询频率较高的建议使用索引
(2) 表与表联合查询时,用于约束条件的字段建议使用索引
(3) 用于排序的字段建议使用索引
3.索引的原理
其实就是回答B树或者B+树的工作原理,这两种数据结构适合磁盘索引文件和元素。
4.事务的定义和基本使用
(1)基本定义:事务是一种数据库操作的机制,一般来说是指一组数据库操作的集合,实际表现为多个sql语句的集合,当数据库引擎执行该事务时,要么就全部不执行,要么就全部执行。事务是一个不可分割的工作逻辑单元。在数据库系统上执行并发操作时事务是作为最小的控制单元来使用的。(多用户登录系统一般采用事务机制)在执行的时候,如果事务执行成功,数据库引擎会提交该事务,即将事务的执行结果提交到数据库中,但是,如果执行不成功,我们可以进行回滚,即将数据库恢复到事务执行之前的状态。
(2)使用:不同数据库的事务实现有所不同,但大体上是相似的,一般分为四个操作:开启事务,执行事务,提交事务和回滚事务。
具体可以参考以下博客:
https://www.cnblogs.com/cold-ice/p/6039595.html
Linux部分
1.常用命令
(1)与CPU、内存和磁盘相关命令:top、free、df、fdisk
(2)查找相关命令:grep(可以搭配正则表达式)、find
(3)与文本处理相关的命令:sed(用于格式化修改)、awk(可以用于统计)、tr命令(可以实现简单的文本处理,包括替换、删除、去重、截断等功能),具体可以参考下面的资料:
http://man.linuxde.net/tr
https://blog.csdn.net/m0_37814112/article/details/80492076
(4)与网络相关:netstat(可以用于查看系统网络连接状态)、tcpdump(可以用于抓包分析)
2.共享内存
Linux下共享内存主要有两种实现机制,一种是采用mmap,另一种是采用XSI机制中的共享内存方法。mmap是内存文件映射,将一个文件映射到进程的地址空间,用户进程的地址空间的管理是通过vm_area_struct结构体进行管理的。mmap通过映射一个相同的文件到两个不同的进程,就能实现这两个进程的通信,采用该方法可以实现任意进程之间的通信。mmap也可以采用匿名映射,不指定映射的文件,但是只能在父子进程间通信。XSI的内存共享实际上也是通过映射文件实现,只是其映射的是一种特殊文件系统下的文件,该文件是不能通过read和write访问的。
------------------------------------------------------未完待续-------------------------------------------------------------
C++后台知识点总结(一)的更多相关文章
- web后台知识点整理
五.JEE 适用于创建server端的大型的软件服务系统 1. JEE : JAVA PLATFORM ENTERPRISE DEDITON 2.是一个规范集.技术集.框架集(API集) 一种技 ...
- 【灵魂拷问】你真的懂得Mysql的管理和使用吗?
作者 | Jeskson 来源 | 达达前端小酒馆 MySQL管理,数据库管理和数据表管理,用户管理. 初始化数据库,创建数据库,查看数据库,删除数据库. 创建数据表,查看数据表,修改数据表,删除数据 ...
- 【灵魂拷问】你为什么要来学习Node.js呢?
[灵魂拷问]你为什么要来学习Node.js呢? 学习node.js适合的人群: 需要必备一些HTML,CSS,JavaScript及编程有一定程度了解的读者阅读,一些简单的命令行操作,具备服务端开发经 ...
- Web数据交互技术
作者 | Jeskson 来源 | 达达前端小酒馆 web的概念 web叫全球广域网,可以叫做万维网,是一种分布式结构,建立在Internet上的网络服务.万维网共享分布在网络上的各个服务器中的所有互 ...
- 请求与上传文件,Session简介,Restful API,Nodemon
作者 | Jeskson 来源 | 达达前端小酒馆 请求与上传文件 GET请求和POST请求 const express = require('express'); const app = expre ...
- Express服务器开发
作者 | Jeskson 来源 | 达达前端小酒馆 Express服务器开发 创建Express应用程序,Express路由,pug视图模板的使用 Express简介: 让我们来创建Express应用 ...
- HTTP协议,到底是什么鬼?
作者 | Jeskson 来源 | 达达前端小酒馆 了解HTTP HTTP是什么呢?它是超文本传输协议,HTTP是缩写,它的全英文名是HyperText Transfer Protocol. 那么什么 ...
- Node.js安装使用-VueCLI安装使用-工程化的Vue.js开发
作者 | Jeskson 来源 | 达达前端小酒馆 搭建Node.js环境 什么是Node.js简介呢?它是一个基于JavaScript的运行环境,Node.js发布于2009年5月,对Chrome ...
- 【可视化】Vue基础
作者 | Jeskson 来源 | 达达前端小酒馆 Vue简介 Vue框架,框架的作者,尤雨溪,组件化,快速开发的特点. 生命周期 beforeCreate:组件刚刚被创建 created:组件创建完 ...
随机推荐
- Node.js 的回调模式
我们都知道在javaScript中,如果在head标签里面引入script脚本,在打开web的时候,浏览器会先加载head中的信息,再加载body的信息: 如果head中有link标签,浏览器会开启一 ...
- Luogu P1074靶形数独【搜索/剪枝】By cellur925
题目传送门 显然是一个搜索.但是开始没有任何的剪枝,暴力从\((1,1)\)点开始搜索,很自然地T了6个点. #include<cstdio> #include<algorithm& ...
- 在虚拟机中设置NAT模式实现主机和虚拟机的通信
1.打开虚拟机,对几个节点进行网络连接的设置.虚拟机设置/网络连接,选择“NAT模式” 2.编辑—>虚拟网络编辑器来查看NAT模式中所用到的网段. 从上图可以看出,NAT中的子网IP是192.1 ...
- JAVA 7新特性——在单个catch代码块中捕获多个异常,以及用升级版的类型检查重新抛出异常
在Java 7中,catch代码块得到了升级,用以在单个catch块中处理多个异常.如果你要捕获多个异常并且它们包含相似的代码,使用这一特性将会减少代码重复度.下面用一个例子来理解. Java 7之前 ...
- android webview.goback 问题
重写 shouldOverrideUrlLoading 不需要实现 view.loadUrl(url);直接return false;即可 如果实现了,则使用window.location.repla ...
- 51nod 2133 排队接水
Bryce1010模板 http://www.51nod.com/onlineJudge/questionCode.html#!problemId=2133 #include <bits/std ...
- siege官方文档(译)(一)
WHAT IS siege? Siege is an open source regression test and benchmark utility. Siege是一款开源回归测试和基准测试工具. ...
- CSS3基础知识学习
CSS3动画例子展示 http://www.17sucai.com/pins/demoshow/13948 HTML5和CSS3特效展示 http://www.html5tricks.com/30-m ...
- debian中sudo无法使用问题
原文链接:http://sharadchhetri.com/2013/08/07/sudo-command-not-found-debian-7/ To solve this issue instal ...
- mysql查询问题
需求:根据选择不同的分类id,查找到同时属于选中的分类的文章id sql语句: select result,GROUP_CONCAT(category_id) from (select categor ...