c++面试(数位物联)

2024-06-03 17:44
文章标签 c++ 面试 数位 物联

本文主要是介绍c++面试(数位物联),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.const 关健字的作用

定义常量,防止变量被意外修改,增强程序的可读性和维护性。
可以用于指针,声明指向常量的指针或常量指针。

2.static关健字的作用

(1)在函数内,用于修饰局部变量,使其生命周期延长到整个程序运行期间,且只初始化一次。
(2)用于修饰全局变量或函数,限制其作用域为本文件。

3.volatile关健字的作用

volatile关键字的作用:主要用于告诉编译器,该变量可能会被意想不到地改变(例如由硬件、多线程等因素),防止编译器进行过度的优化。

4.extern和volatile的作用域说明

extern的作用域通常是全局的,用于在一个文件中声明在其他文件中定义的变量或函数;volatile的作用域主要是在具体使用它的变量的作用范围内。

5.C++中的struct和class区别

默认的访问控制不同,struct默认成员是公共的,class默认成员是私有的。
但在其他方面基本相同,都可以包含成员变量和成员函数。

6.C++中vector和list的区别

vector底层是连续存储,随机访问效率高,但插入和删除可能效率较低且可能引起大量元素移动;list是双向链表,插入和删除效率高,但随机访问效率低。
vector更适合频繁随机访问的场景,list更适合频繁插入删除的场景。

7…要对绝对地址0x100000赋值1234,如何实现

错误,实现不了

#include <stdio.h>
#include <stdlib.h>int main()
{int a = 1234;int* p = &a;scanf("%p",&p);printf("&=%d\n",*p);return(0);
}

正确

#include <stdio.h>int main() {int *ptr = (int *)0x100000;*ptr = 1234;printf("赋值完成\n");return 0;
}

直接对绝对地址进行操作在实际编程中要谨慎使用,并且这种操作可能存在一定的风险和限制,具体取决于运行环境和系统权限等因素。

struct name1{
char str;short x;int num;};
求sizeof(name1) 
8
  1. 求函数返回值,
    传入-1,则在64位机器上函数返回()
int func(int x)
{int count =0;while(x)  //while非0就是真{count++;x=x&(x-1); //与运算}
}return count;}

A死循环B:64C:32D:16

A

在 64 位机器上,对于有符号整数(如 int 类型):
其表示范围通常是 -2^63 到 2^63 - 1。
即大致是 -9223372036854775808 到 9223372036854775807。
对于无符号整数(如 unsigned int 类型),表示范围是 0 到 2^64 - 1。

-1 的二进制表示为所有位都是 1。在执行 x&(x-1) 操作时,每次会将最右边的一个 1 变为 0,但因为初始的 x 是全 1,所以会不断进行这个过程而无法使 x 变为 0 从而结束循环,因此函数不会返回一个确定的值,而是陷入死循环

  1. 求函数返回值
float a[3]={1.5,2.5,3.5};
*pa=a;
*(pa++)*=3;

,则*pa的值是()

A:1.5B:2.5C:3.5D:4.5

	B

初始时 pa 指向数组 a 的首元素,
执行 (pa++)=3 ,先进行 *(pa) 即 a[0] 的值乘以 3 ,此时 a[0] 变为 4.5 ,然后 pa 向后移动一个位置指向 a[1] 。
所以此时 *pa 的值就是 a[1] 的值,即 2.5 。

  1. 求函数返回值
#include <stdlib.h>int main()
{
int a[5][5];int(*p)[4];p=a;printf("%p,%d\n",&p[4][2]-&a[4][2],&p[4][2]-&a[4][2]);return 0;
}
  1. 用C实现strstr,即在字符串中查找特定子串
#include <stdio.h>
#include <string.h>char *myStrStr(char *haystack, char *needle) {int haystackLen = strlen(haystack);int needleLen = strlen(needle);for (int i = 0; i <= haystackLen - needleLen; i++) {int j;for (j = 0; j < needleLen; j++) {if (haystack[i + j]!= needle[j]) {break;}}if (j == needleLen) {return haystack + i;}}return NULL;
}int main() {char str[] = "This is a test string";char subStr[] = "test";char *result = myStrStr(str, subStr);if (result) {printf("找到子串在: %s\n", result);} else {printf("未找到子串\n");}return 0;
}

这篇关于c++面试(数位物联)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027675

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现