记录:阿里C++开发初面问题

面试问题

代码

题1:二叉树的层序遍历
题2:两个字符串的最大公共子串

项目

科研项目:给定两个点,路径规划如何实现?
基于路网节点环境数据,输入两个坐标点,算法训练,输出多条可行走的路线。。。
C++项目简单介绍一下

C++提问

(1)智能指针有哪些,问了shared指针实现机制
std::auto_ptr 已被废弃;
在C++中,动态内存的管理是用一对运算符完成的:new和delete,new:在动态内存中为对象分配一块空间并返回一个指向该对象的指针,delete:指向一个动态独享的指针,销毁对象,并释放与之关联的内存。

动态内存管理经常会出现两种问题:一种是忘记释放内存,会造成内存泄漏;一种是尚有指针引用内存的情况下就释放了它,就会产生引用非法内存的指针。

为了更加容易(更加安全)的使用动态内存,引入了智能指针的概念。智能指针的行为类似常规指针,重要的区别是它负责自动释放所指向的对象。标准库提供的两种智能指针的区别在于管理底层指针的方法不同,shared_ptr允许多个指针指向同一个对象,unique_ptr则“独占”所指向的对象。标准库还定义了一种名为weak_ptr的伴随类,它是一种弱引用,指向shared_ptr所管理的对象,这三种智能指针都定义在memory头文件中。

unique_ptr独享它指向的对象。也就是说,同时只有一个unique_ptr指向同一个对象,当这个unique_ptr被销毁时,指向的对象也随即被销毁。

shared_ptr 使用一种叫做RAII(Resource Acquisition Is Initialization)的技术作为实现基础:
1)在对象构造时获取资源,接着控制对资源的访问使之在对象的生命周期内始终保持有效,最后在对象析构的时候释放资源
raii技术的好处是:
不需要显式释放资源
对象所拥有的资源在其生命周期内始终有效
防止忘记调用delete释放内存或者程序异常退出时没有释放内存。
2)同时它能够将值语义转为引用语义(即shared_ptr可以让多个指针指向相同的对象,共享同一块地址空间),shared_ptr使用引用技术方式来统计当前对象被引用的次数,每一次执行析构函数,引用计数就会-1,当引用计数减为0时自动删除所指对象,回收对象空间。

shared_ptr可以说近乎完美,但是通过引用计数实现的它,虽然解决了指针独占的问题,但也引来了引用成环的问题,这种问题靠它自己是没办法解决的,所以在C++11的时候将shared_ptr和weak_ptr一起引入了标准库,用来解决循环引用的问题。

(2)虚函数是什么,虚函数实现机制(为什么派生类对象调用的是派生类的成员函数而不是基类的)
答案:虚函数表
(3)C++没有Java的内存回收机制,有没有什么办法可以实现像Java一样的自动回收
答案:使用智能指针和析构函数。C++的语言机制保证了,当一个对象创建的时候,自动调用构造函数,当对象超出作用域的时候会自动调用析构函数。所以,在RAII的指导下,我们应该使用类来管理资源,将资源和对象的生命周期绑定。“资源获取即初始化”,在使用智能指针管理内存资源时,“资源”指的是通过new或malloc申请的内存资源,“初始化”指的是使用申请的内存资源来初始化栈上的智能指针类对象。使用智能指针管理内存资源的好处显而易见,通过智能指针对象在声明周期结束时,自动调用析构函数,在析构函数中完成对内存资源的释放,即自动的调用内存资源的释放代码,避免因忘记对内存资源的释放导致内存泄漏。
(4)STL的容器经常使用哪些
1)vector的存储方式、使用是什么样的
2)map是怎么实现的
键值对
3)map的键值对是怎么存储的?
回答了数组,不太对
4)map跟unoedered_map有什么区别?
答案:map:基于红黑树,元素有序存储。插入和查询时间复杂度与树高相同,即O(logn)。
unordered_map:基于散列表,元素无序存储。插入和查询大多数情况下其复杂度接近于O(1)。
5)unordered_map的查找是通过什么实现的?
答案:红黑树、key值比较

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值