2020华为程序员精选面试题及答案(程序员面试必入的高能总结)

您所在的位置:网站首页 华为面试题及答案96-76=1 2020华为程序员精选面试题及答案(程序员面试必入的高能总结)

2020华为程序员精选面试题及答案(程序员面试必入的高能总结)

2023-06-29 17:51| 来源: 网络整理| 查看: 265

1. static有什么用途?(请至少说明两种)

1) 在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。

2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。

3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用

 

2. 引用与指针有什么区别?

1) 引用必须被初始化,指针不必。

2) 引用初始化以后不能被改变,指针可以改变所指的对象。

3) 不存在指向空值的引用,但是存在指向空值的指针。

 

3. 描述实时系统的基本特性

在特定时间内完成特定的任务,实时性与可靠性。

 

4. 全局变量和局部变量在内存中是否有区别?如果有,是什么区别?

全局变量储存在静态数据库,局部变量在堆栈。

 

5. 什么是平衡二叉树?

左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1。

 

6. 堆栈溢出一般是由什么原因导致的?

没有回收垃圾资源。

 

7. 什么函数不能声明为虚函数?

constructor函数不能声明为虚函数。

 

8. 冒泡排序算法的时间复杂度是什么?

时间复杂度是O(n^2)。

 

9. Internet采用哪种网络协议?该协议的主要层次结构?

Tcp/Ip协议

主要层次结构为: 应用层/传输层/网络层/数据链路层/物理层。

 

10. IP地址的编码分为哪俩部分?

IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。

 

11. 用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。

循环链表,用取余操作做

 

12. 某32位系统下, C++程序,请计算sizeof 的值.

char str[] = “http://www.ibegroup.com/”

char *p = str ;

int n = 10;

请计算

sizeof (str ) = ?(1)

sizeof ( p ) = ?(2)

sizeof ( n ) = ?(3)

void Foo ( char str[100]){

请计算

sizeof( str ) = ?(4)

}

void *p = malloc( 100 );

请计算

sizeof ( p ) = ?(5)

 

(1)17 (2)4 (3) 4 (4)4 (5)4

 

 

13. 阅读下面代码,回答问题.

1). void GetMemory(char **p, int num){

*p = (char *)malloc(num);

}

void Test(void){

char *str = NULL;

GetMemory(&str, 100);

strcpy(str, "hello");

printf(str);

}

请问运行Test 函数会有什么样的结果?

 

输出“hello”

 

2). char *GetMemory(void){

char p[] = "hello world";

return p;

}

void Test(void){

char *str = NULL;

str = GetMemory();

printf(str);

}

请问运行Test 函数会有什么样的结果?

 

无效的指针,输出不确定

 

14. C++中为什么用模板类。

( 1 ) 可用来创建动态增长和减小的数据结构

(2)它是类型无关的,因此具有很高的可复用性。

(3)它在编译时而不是运行时检查数据类型,保证了类型安全

(4)它是平台无关的,可移植性

(5)可用于基本数据类型

 

15. 程序什么时候应该使用线程,什么时候单线程效率高。

1.耗时的操作使用线程,提高应用程序响应

2.并行操作时使用线程,如C/S架构的服务器端并发线程响应用户的请求。

3.多CPU系统中,使用线程提高CPU利用率

4.改善程序结构。一个既长又复杂的进程可以考虑分为多个线程,成为几个独立或半独

立的运行部分,这样的程序会利于理解和修改。

其他情况都使用单线程。

 

16. Linux有内核级线程吗?

线程通常被定义为一个进程中代码的不同执行路线。从实现方式上划分,线程有两种类型:“用户级线程”和“内核级线程”。

用户线程指不需要内核支持而在用户程序中实现的线程,其不依赖于操作系统核心,应用进程利用线程库提供创建、同步、调度和管理线程的函数来控制用户线程。这种线程甚至在象 DOS 这样的操作系统中也可实现,但线程的调度需要用户程序完成,这有些类似 Windows 3.x 的协作式多任务。另外一种则需要内核的参与,由内核完成线程的调度。其依赖于操作系统核心,由内核的内部需求进行创建和撤销,这两种模型各有其好处和缺点。用户线程不需要额外的内核开支

,并且用户态线程的实现方式可以被定制或修改以适应特殊应用的要求,但是当一个线程因 I/O 而处于等待状态时,整个进程就会被调度程序切换为等待状态,其他线程得不到运行的机会;而内核线程则没有各个限制,有利于发挥多处理器的并发优势,但却占用了更多的系统开支。

Windows NT和OS/2支持内核线程。Linux 支持内核级的多线程。

17. C++中什么数据分配在栈或堆中,New分配数据是在近堆还是远堆中?完整版加Linux专业学习交流qq群1023370945完整版加Linux专业学习交流qq群1023370945

由于篇幅原因,完整版请加QQ开发交流裙1023370945免费获取

更多、更全、更新BATJ等大厂面试题同步更新!

感谢关注Linux技术宅!学习c/c++ Linux服务器高阶知识,知识点有C/C++,Linux,golang技术,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等等,都可以加入Linux后台服务器开发、音视频学习群,更有LINUX免费文档 面试资料群文件可自行下载!

另外腾讯课堂每晚8点零声学院都会有免费的公开课,地址:https://ke.qq.com/course/417774?flowToken=1020253 

好好学习 天天向上!祝大家面试成功!升职加薪!走上人生巅峰!一起来学习成长进步吧!



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3