首页 > 其他分享 >腾讯技术岗位笔试&面试题(五)

腾讯技术岗位笔试&面试题(五)

时间:2024-12-16 20:54:41浏览次数:4  
标签:面试题 函数 成员 笔试 定义 运算符 腾讯 模板 define

说在前面

本篇文章是腾讯技术面试题目汇总第五篇
后续将持续推出互联网大厂,如阿里,腾讯,百度,美团,头条等技术面试题目,以及答案和分析。
欢迎大家点赞关注转发。

1.define、const、typedef、inline使用方法?

一、const与#define的区别:

  1. const定义的常量是变量带类型,而#define定义的只是个常数不带类型;
  2. define只在预处理阶段起作用,简单的文本替换,而const在编译、链接过程中起作用;
  3. define只是简单的字符串替换没有类型检查。而const是有数据类型的,是要进行判断的,可以避免一些低级错误;
  4. define预处理后,占用代码段空间,const占用数据段空间;
  5. const不能重定义,而define可以通过#undef取消某个符号的定义,进行重定义;
  6. define独特功能,比如可以用来防止文件重复引用。

二、#define和别名typedef的区别

  1. 执行时间不同,typedef在编译阶段有效,typedef有类型检查的功能;#define是宏定义,发生在预处理阶段,不进行类型检查;
  2. 功能差异,typedef用来定义类型的别名,定义与平台无关的数据类型,与struct的结合使用等。#define不只是可以为类型取别名,还可以定义常量、变量、编译开关等。
  3. 作用域不同,#define没有作用域的限制,只要是之前预定义过的宏,在以后的程序中都可以使用。而typedef有自己的作用域。

三、define与inline的区别

  1. define是关键字,inline是函数;

  2. 宏定义在预处理阶段进行文本替换,inline函数在编译阶段进行替换;
  3. inline函数有类型检查,相比宏定义比较安全;

在C/C++中,对函数参数的扫描是从后向前的。C/C++的函数参数是通过压入堆栈的方式来给函数传参数的(堆栈是一种先进后出的数据结构),最先压入的参数最后出来,在计算机的内存中,数据有2块,一块是堆,一块是栈(函数参数及局部变量在这里),而栈是从内存的高地址向低地址生长的,控制生长的就是堆栈指针了,最先压入的参数是在最上面,就是说在所有参数的最后面,最后压入的参数在最下面,结构上看起来是第一个,所以最后压入的参数总是能够被函数找到,因为它就在堆栈指针的上方。printf的第一个被找到的参数就是那个字符指针,就是被双引号括起来的那一部分,函数通过判断字符串里控制参数的个数来判断参数个数及数据类型,通过这些就可算出数据需要的堆栈指针的偏移量了,下面给出printf(“%d,%d”,a,b);(其中a、b都是int型的)的汇编代码.

2.#include 的顺序以及尖叫括号和双引号的区别

表示编译器只在系统默认目录或尖括号内的工作目录下搜索头文件,并不去用户的工作目录下寻找,所以一般尖括号用于包含标准库文件;
表示编译器先在用户的工作目录下搜索头文件,如果搜索不到则到系统默认目录下去寻找,所以双引号一般用于包含用户自己编写的头文件。

3.lambda函数

  1. 利用lambda表达式可以编写内嵌的匿名函数,用以替换独立函数或者函数对象;
  2. 每当你定义一个lambda表达式后,编译器会自动生成一个匿名类(这个类当然重载了()运算符),我们称为闭包类型(closure type)。那么在运行时,这个lambda表达式就会返回一个匿名的闭包实例,其实一个右值。所以,我们上面的lambda表达式的结果就是一个个闭包。闭包的一个强大之处是其可以通过传值或者引用的方式捕捉其封装作用域内的变量,前面的方括号就是用来定义捕捉模式以及变量,我们又将其称为lambda捕捉块。
  3. lambda表达式的语法定义如下:
    [capture] (parameters) mutable ->return-type {statement};
  4. lambda必须使用尾置返回来指定返回类型,可以忽略参数列表和返回值,但必须永远包含捕获列表和函数体;

4.hello world 程序开始到打印到屏幕上的全过程?

  1. 用户告诉操作系统执行HelloWorld程序(通过键盘输入等)
  2. 操作系统:找到helloworld程序的相关信息,检查其类型是否是可执行文件;并通过程序首部信息,确定代码和数据在可执行文件中的位置并计算出对应的磁盘块地址。
  3. 操作系统:创建一个新进程,将HelloWorld可执行文件映射到该进程结构,表示由该进程执行helloworld程序。
  4. 操作系统:为helloworld程序设置cpu上下文环境,并跳到程序开始处。
  5. 执行helloworld程序的第一条指令,发生缺页异常
  6. 操作系统:分配一页物理内存,并将代码从磁盘读入内存,然后继续执行helloworld程序
  7. helloword程序执行puts函数(系统调用),在显示器上写一字符串
  8. 操作系统:找到要将字符串送往的显示设备,通常设备是由一个进程控制的,所以,操作系统将要写的字符串送给该进程
  9. 操作系统:控制设备的进程告诉设备的窗口系统,它要显示该字符串,窗口系统确定这是一个合法的操作,然后将字符串转换成像素,将像素写入设备的存储映像区
  10. 视频硬件将像素转换成显示器可接收和一组控制数据信号
  11. 显示器解释信号,激发液晶屏
  12. OK,我们在屏幕上看到了HelloWorld

5.模板类和模板函数的区别是什么?

函数模板的实例化是由编译程序在处理函数调用时自动完成的,而类模板的实例化必须由程序员在程序中显式地指定。即函数模板允许隐式调用和显式调用而类模板只能显示调用。在使用时类模板必须加,而函数模板不必

6.为什么模板类一般都是放在一个h文件中

  1. 模板定义很特殊。由template<…>处理的任何东西都意味着编译器在当时不为它分配存储空间,它一直处于等待状态直到被一个模板实例告知。在编译器和连接器的某一处,有一机制能去掉指定模板的多重定义。所以为了容易使用,几乎总是在头文件中放置全部的模板声明和定义。
  2. 在分离式编译的环境下,编译器编译某一个.cpp文件时并不知道另一个.cpp文件的存在,也不会去查找(当遇到未决符号时它会寄希望于连接器)。这种模式在没有模板的情况下运行良好,但遇到模板时就傻眼了,因为模板仅在需要的时候才会实例化出来,所以,当编译器只看到模板的声明时,它不能实例化该模板,只能创建一个具有外部连接的符号并期待连接器能够将符号的地址决议出来。然而当实现该模板的.cpp文件中没有用到模板的实例时,编译器懒得去实例化,所以,整个工程的.obj中就找不到一行模板实例的二进制代码,于是连接器也黔驴技穷了。

7.C++中类成员的访问权限和继承权限问题。

  1. 三种访问权限
    • public:用该关键字修饰的成员表示公有成员,该成员不仅可以在类内可以被 访问,在类外也是可以被访问的,是类对外提供的可访问接口;
    • private:用该关键字修饰的成员表示私有成员,该成员仅在类内可以被访问,在类体外是隐藏状态;
    • protected:用该关键字修饰的成员表示保护成员,保护成员在类体外同样是隐藏状态,但是对于该类的派生类来说,相当于公有成员,在派生类中可以被访问。
  2. 三种继承方式
    • 若继承方式是public,基类成员在派生类中的访问权限保持不变,也就是说,基类中的成员访问权限,在派生类中仍然保持原来的访问权限;
    • 若继承方式是private,基类所有成员在派生类中的访问权限都会变为私有(private)权限;
    • 若继承方式是protected,基类的共有成员和保护成员在派生类中的访问权限都会变为保护(protected)权限,私有成员在派生类中的访问权限仍然是私有(private)权限。

8.cout和printf有什么区别?

cout<<是一个函数,cout<<后可以跟不同的类型是因为cout<<已存在针对各种类型数据的重载,所以会自动识别数据的类型。输出过程会首先将输出字符放入缓冲区,然后输出到屏幕。
cout是有缓冲输出:
cout < < "abc " < <endl;
或cout < < "abc\n ";cout < <flush; 这两个才是一样的.
endl相当于输出回车后,再强迫缓冲输出。
flush立即强迫缓冲输出。
printf是无缓冲输出。有输出时立即输出

9.重载运算符?

  1. 我们只能重载已有的运算符,而无权发明新的运算符;对于一个重载的运算符,其优先级和结合律与内置类型一致才可以;不能改变运算符操作数个数;
  2. . :: ?: sizeof typeid **不能重载;
  3. 两种重载方式,成员运算符和非成员运算符,成员运算符比非成员运算符少一个参数;下标运算符、箭头运算符必须是成员运算符;
  4. 引入运算符重载,是为了实现类的多态性;
  5. 当重载的运算符是成员函数时,this绑定到左侧运算符对象。成员运算符函数的参数数量比运算符对象的数量少一个;至少含有一个类类型的参数;
  6. 从参数的个数推断到底定义的是哪种运算符,当运算符既是一元运算符又是二元运算符(+,-,*,&);
  7. 下标运算符必须是成员函数,下标运算符通常以所访问元素的引用作为返回值,同时最好定义下标运算符的常量版本和非常量版本;
  8. 箭头运算符必须是类的成员,解引用通常也是类的成员;重载的箭头运算符必须返回类的指针;

10.函数重载函数匹配原则

  1. 名字查找
  2. 确定候选函数
  3. 寻找最佳匹配

原文链接:https://mp.weixin.qq.com/s/xJzW_6hNmMDfPk_cm0xxHQ

欢迎start和follow我们的仓库,里面有更多信息,包含大厂技术岗位面试笔试题库/大厂面试经验分享/学习资料/最新求职信息和内推职位/学长学姐交流学习/计算机毕设课题和源码/算法求职/各城市大厂推荐等,旨在帮助学计算机、编程的同学少走弯路,减少信息差,成功拿到理想的offer

标签:面试题,函数,成员,笔试,定义,运算符,腾讯,模板,define
From: https://www.cnblogs.com/autodriver/p/18611092

相关文章

  • LeetCode面试题04 检查平衡性
    题目:实现一个函数,检查二叉树是否平衡。在这个问题中,平衡树的定义如下:任意一个节点,其两棵子树的高度差不超过1。一、平衡树定义:二叉树,一种由节点组成的树形数据结构,每个节点最多有两个子节点,分别称作左子节点和右子节点。而平衡二叉树,可不是普通的二叉树,它有着严苛的要求:对......
  • 人脸修复与增强腾讯开源项目GFPGAN介绍
    GFPGAN简述GFPGAN(GenerativeFacialPriorGAN)是一种基于生成对抗网络(GAN)的面部图像修复与增强模型。它由腾讯ARCLab的研究团队开发,目的是以高效和高质量的方式修复低分辨率、受损或老化的人脸图像,同时保留其真实感和身份一致性。GFPGAN是当前图像处理领域的热门......
  • 腾讯通升级替代方案,可与RTX并行使用,兼容Linux系统
    一、腾讯通RTX继续使用的主要难题随着腾讯通RTX停止更新并从官网下架,用户不仅无法继续获得更新、技术支持和资源下载,还面临以下无法解决的使用问题:●不兼容国产系统与移动端:腾讯通RTX仅支持Windows和Mac操作系统,无法在基于Linux内核的国产操作系统(如统信UOS、银河麒麟)及移动设......
  • 腾讯文档自动打卡(西南交通大学每日晚归打卡)
    功能实现每日晚归打卡的自动打卡(需要提前登录电脑QQ)实现步骤:使用Chrome/Edge浏览器,自动登录,输入姓名,学号,自动定位(定位失败时尝试重新定位)使用方法直接双击运行main.exe即可$_{(大概率报毒,需要点击仍要运行)}$第一次运行需要输入姓名,学号,打卡的链接(不要输......
  • 用腾讯云AI代码助手开发一款数据库敏感信息检查工具
    引言作为一个优秀的IT技术民工,需要始终学习先进的技术并将技术转换为生产力,目前AI领域编码辅助工具层出不穷,开发者有必要或者说必须要掌握相关工具的使用,以提高编码效率,降低编码错误。这次我通过一个简单的项目和大家分享一下腾讯云AI代码助手的使用。AI开发实践开发环......
  • 高频面试题:bean的生命周期
    在Spring框架中,bean的生命周期由Spring容器管理。Spring提供了一系列的接口和回调方法,允许你在bean的生命周期中的特定阶段执行自定义逻辑。以下是Spring中管理bean生命周期的主要步骤和接口:1.实例化BeanSpring容器首先会使用bean的构造函数或工厂方法创建bean的实例。2.......
  • 2025mysql经典面试题合集!
    1.解释MySQL中的JOIN操作。JOIN操作用于结合两个或多个数据库表的行。类型包括INNERJOIN(只返回两表匹配的行)、LEFTJOIN(返回左表的所有行及右表匹配的行)、RIGHTJOIN(返回右表的所有行及左表匹配的行)等。2.如何优化MySQL查询?优化MySQL查询的方法包括:使用合适的索引、避免......
  • 2025全网最全Redis面试题合集
    1.使用Redis有哪些好处?(1)速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)(2)支持丰富数据类型,支持string,list,set,sortedset,hash(3)支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行(4)丰富的......
  • 米哈游大数据面试题及参考答案
    怎么判断两个链表是否相交?怎么优化?判断两个链表是否相交可以采用多种方法。一种方法是使用双指针。首先分别遍历两个链表,得到两个链表的长度。然后让长链表的指针先走两个链表长度差的步数。之后,同时移动两个链表的指针,每次比较两个指针是否指向相同的节点。如果指向相同......
  • 有效的括号(字节面试题 最优解)
    题目来源20.有效的括号-力扣(LeetCode)题目描述给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。示例1:输入:s......