面试笔试总结(一)之 C++基础
C++
1.智能指针 内存管理 垃圾回收 指针问题 资源管理(内存就是资源)
可以通过引用计数的机制。。。实现内存回收,不要让内存泄漏。
涉及到内存的泄露的问题:
- 当创建一个对象的时候(new)而在对象使用完毕,没有delete就会发生内存泄漏。
- 或者有很多指针指向同一块内存,当有一个使用完毕delete了,剩下的指针就会无处可指
- 循环引用导致的指针泄漏
很多人会忘记,这时候智能指针就派上用处了,可以帮助程序员自动在析构函数中释放。两个类:
第一个问题想法:同归于尽smartPointer中的指针就是object的指针
- smartpointer类构造函数析构函数:有一个自己的构造函数把传过来的object指针付给自己,销毁时候delete自己就ok了。
- 有一个私有成员:object的指针 ptr。
- 构造完成就相当于object的ptr就是object的p。
- 所以释放自己的ptr就相当于销毁object的p;
class Object {
public:
int a,b;
};
int main(){
while(true){
smartPointer p(new Object());
Process(p);
}
}
void Process(Object &p){
//do something;
}
class smartPointer{
public:
smartPointer(Object *p){
ptr=p;
}
~smartPointer(){
delete ptr;
}
private: Object *ptr;
};
第二个问题:
引用计数类~~~~~~~~~~~!!!!!!!!!!记录当前有多少指针指向这个内存。
STL不是基于引用计数的:outo_ptr 同一时刻一个指针只能有一个被一个对象拥有。。。缺点:不能赋值操作,不能参数传递~,
基于计数的:boost库的shared_ptr!!!!!!!!!
可能在:
构造,复制,赋值=
发生指针指向和指针计数的问题
定义指向counter的指针Smartpointepro
定义指向内存(object)的指针counter
友元类 可以访问Counter类的成员

class Object {
public:
int a,b;
};
int main(){
while(true){
smartPointer p(new Object());
Process(p);
}
}
void Process(Object &p){
//do something;
}
class Conter_Smartpointer{
public:
Conter_Smartpointer(Object *p){//普通的构造 产生新内存
cSp=new Counter(p);
}
Conter_Smartpointer(Conter_Smartpointe &p){//指向同样的内存,复制
cSp=p.cSp;
cSp->cnt++;
}
Conter_Smartpointer& operate=(Conter_Smartpointer &p){//赋值
//right++ left --
cSp->cnt--;被右边的覆盖掉了,指向右边的内存了 原来的引用计数减一
p.cSp->cnt++;
if(cSp->cnt == 0){
delete cSp;
}
cSp=p.cSp;
}
~Conter_Smartpointer(){
cSp->cnt--;
if(cSp->cnt == 0){
delete cSp;
}
}
private: Counter *cSp;//指向同一个counter
};
class Counter(){
friend class Conter_Smartpointer;//Conter_Smartpointer可以访问counter类的成员(包括私有成员)
pravite:
int cnt;
Object *ptr;
Counter(){
p=NULL;
cnt=0;
}
Counter(Object *p){
ptr = p;
cnt=1;
}
第三个问题:
父亲指向儿子,儿子指向父亲,没有一个先释放。。环
解决:boost::weak_ptr
赋值传递:对传入的实参进行拷贝~在函数里处理不会影响原来的对象
引用:相反
资源管理(内存就是资源):
在c++常利用对资源的包装~防止内存泄漏
2.单例模式
设计模式:
一个类只能一个对象~
应用于:系统日志的输出,一个界面只有一个鼠标 鼠标类。。
1.一个类只能一个对象~
2.内存的释放
3.线程安全,多个类产生一个对象
有什么问题:
class Singleton(){
private:
Singleton(){
}
static Singleton* instance;
public:
static Singleton* GetInstance(){
if(instance == NULL){
instance = new Singleton();
}
}
}
想要产生一个类只能通过GetInstance()
让构造函数是私有的,这样别的类就不能访问这个构造函数
函数传递 和赋值的问题:可能会产生多个对象的问题
无析构:因为无对象:static 定义的类属于整个类,不存在析构。static一旦被构造赋值,就不允许修改。在静态存储区。
对于释放内存的问题,new出来的在堆中产生,必须手动释放
staic在静态存储区,这样操作系统自动释放内存
方法一:如何保证线程安全&&内存不用手动释放
static Singleton instance;当再次调用就直接使用instance:保证只产生一个对象
class Singleton(){
private:
Singleton(){
}
Singleton(Singleton &p){
}
Singleton& operate = (const Singleton &p){
}
public:
static Singleton* GetInstance(){
static Singleton instance;
return &instance;
}
}
方法二:保证线程安全
double check 加锁
面试笔试总结(一)之 C++基础的更多相关文章
- 赠送4本《 PHP 程序员面试笔试宝典》
< PHP 程序员面试笔试宝典>历时一年,由机械工业出版社出版,在 2018 年 11 月问世.全书共八个章节,涉及 面试笔试经验技巧.PHP 基础知识.PHP 进阶知识,PHP 面向对象 ...
- iOS开发——面试笔试精华(二)
面试笔试精华(二) 警告:一定要把英文题目过一遍,有些公司的题目故意弄成英文的!!! 1. Difference between shallow copy and deep copy? ...
- 新书出版 |《Oracle程序员面试笔试宝典》
新书出版 |<Oracle程序员面试笔试宝典> <Oracle程序员面试笔试宝典> 丛书[数据库 面试 笔试宝典]已在京东.淘宝和天猫预售,一共 5 本,目前市场上已有4本,丛 ...
- (转)C/C++ 程序设计员应聘常见 面试笔试 试题深入剖析
C/C++ 程序设计员应聘常见 面试笔试 试题深入剖析 http://www.nowcoder.com/discuss/1826?type=2&order=0&pos=23&p ...
- .Net工程师面试笔试宝典
.Net工程师面试笔试宝典 传智播客.Net培训班内部资料 http://net.itcast.cn 这套面试笔试宝典是传智播客在多年的教学和学生就业指导过程中积累下来的宝贵资料,大部分来自于学员从面 ...
- 《Java程序猿面试笔试宝典》之 什么是AOP
AOP(Aspect-Oriented Programming.面向切面编程)是对面向对象开发的一种补充,它同意开发者在不改变原来模型的基础上动态地改动模型从而满足新的需求.比如.在不改变原来业务逻辑 ...
- 《PHP面试笔试真题库》——PHP面试的好帮手
你好,是我琉忆. 一个文艺的PHP开发工程师. 很荣幸能够在这里带来我的第一本新书--<PHP程序员面试笔试真题库>. 一.创作过程 <PHP 程序员面试笔试真题库>是我的第三 ...
- 《PHP程序员面试笔试真题解析》——新书上线
你好,是我--琉忆.很高兴可以跟你分享我的新书. 很高兴,在出版了PHP程序员面试笔试宝典后迎来了我的第二本书出版--<PHP程序员面试笔试真题解析>. 如果你是一个热爱PHP的程序员,刚 ...
- 《PHP程序员面试笔试宝典》——如何克服面试中紧张的情绪?
本文摘自<PHP程序员面试笔试宝典>. PHP面试技巧分享,PHP面试题,PHP宝典尽在"琉忆编程库". 面试的成功与否,往小的方面讲,直接关系到求职者的工作问题,往大 ...
- 《PHP程序员面试笔试宝典》——什么是职场暗语?
本文摘自<PHP程序员面试笔试宝典> 文末有该书电子版下载. 随着求职大势的变迁发展,以往常规的面试套路因为过于单调.简明,已经被众多"面试达人"们挖掘出了各种&quo ...
随机推荐
- Python并行编程(五):线程同步之信号量
1.基本概念 信号量是由操作系统管理的一种抽象数据类型,用于在多线程中同步对共享资源的使用.本质上说,信号量是一个内部数据,用于标明当前的共享资源可以有多少并发读取. 同样在threading中,信号 ...
- HttpRunner 参数化数据驱动
HttpRunner 2.0 参数化数据驱动案例,废话不说,直接上干货. 1.测试用例目录结构 api:接口集 testcases:测试用例 testsuites:测试套件 data: ...
- 【多线程基础】- 多个线程顺序打印ABC
题目:3个线程名字分别是A,B,C 现在在console上连续打印10次 ABC . public class Test { public static void main(String[] args ...
- boost 智能指针intrusive_ptr
boost::intrusive_ptr一种“侵入式”的引用计数指针,它实际并不提供引用计数功能,而是要求被存储的对象自己实现引用计数功能,并提供intrusive_ptr_add_ref和intru ...
- Django小练习
1.获取系统所有Url from django.urls.resolvers import RegexURLPattern #定义函数 def get_all_url(patterns, prev, ...
- SQL Server 使用 Hierarchyid 操作层次结构数据
层次结构数据定义为一组通过层次结构关系互相关联的数据项. 在层次结构关系中,一个数据项是另一个项的父级或子级. sql server2008开始内置的 hierarchyid 数据类型使存储和查询层次 ...
- 持续(集成-->交付-->部署)
软件的开发工作的大致流程 编码 -> 构建 -> 集成 -> 测试 -> 交付 -> 部署 由上图可知「持续集成(Continuous Integration)」.「持续 ...
- 64. Minimum Path Sum(最小走棋盘 动态规划)
Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right which ...
- [转]linux内核分析笔记----内存管理
转自:http://blog.csdn.net/Baiduluckyboy/article/details/9667933 内存管理,不用多说,言简意赅.在内核里分配内存还真不是件容易的事情,根本上是 ...
- 关于TOSCA自动化测试工具, 我想问一些问题(持续整理中)
通过学习,实践踩坑,有以下问题不太明白 1. Artifacts and results from your complete test portfolio (cross-browser, mobi ...