先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新大数据全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip204888 (备注大数据)
正文
A 用一个对象去初始化同一个类的另一个新对象时
B 将类的一个对象赋值给该类的另一个对象时
C 函数的形参对象,调用函数进行形参和实参结合时
D 函数的返回值是类的对象,函数执行返回调用时
这道题需要对拷贝构造了解才可以解题,理解其概念
A 就是场景1
B 赋值调用的不是拷贝构造,调用的是赋值运算符重载
C 这种情况会讲实参拷贝构造一份给给形参
D 就是场景3
这道题的答案是B
💦第六题
以下代码共调用多少次拷贝构造函数:
Widget f(Widget u)
{
Widget v(u);
Widget w=v;
return w;
}
main(){
Widget x;
Widget y=f(f(x));
}
A 1
B 3
C 5
D 7
这道题有一定的难度,我们上一道题已经了解了构造场景,我们这道题来验证一下
y对象的构造将来也需要调用构造函数
f(x)在传参数会调用一次,用v(u)拷贝一次,用v构造w又一次,返回需要借助w调用临时对象,所以又有一次,结束之后需要利用临时对象再次进入f(x)中进行调用,这里也有4次,最后用返回值构造y,一共有9次
注意:按照我们刚刚的算法没有任何问题,但是当函数返回值是类类型对象时,编译器可能会对返回值的类型进行优化
在返回值的时候我们需要创建临时对象,编译器可能会直接拿着临时对象使用,这样子可以少调用一次
这道题的答案是D
💦第七题
如果友元函数重载一个运算符时,其参数表中没有任何参数则说明该运算符是()
A 一元运算符
B 二元运算符
C 选项A)和选项B)都可能
D 重载错误
这道题需要知道什么时候需要运算符重载
如果重载成友元函数,但没有任何参数,所以错误,必须要有一个参数是类类型的对象
这道题的答案是D
💦第八题
class A;
class B;
int main() {
A a;
B b;
return 0;
}
在 main 函数中,变量 a 和 b 的构造函数和析构函数的调用顺序是()
A b构造 - a构造 - a析构 - b析构
B a构造 - a析构 - b构造 - b析构
C b构造 - a构造 - b析构 - a析构
D a构造 - b构造 - b析构 - a析构
F 函数先构造a 再构造b,析构是在栈上的,所以后构造的先析构
这道题的答案是D
💦第九题
下面 C++ 程序的运行结果为()
#include <iostream>
using namespace std;
class cla {
static int n;
public:
cla() { n++; }
~cla() { n--; }
static int get\_n() { return n; }
};
int cla::n = 0;
int main() {
cla\* p = new cla;
delete p;
cout << "n=" << cla::get\_n() << endl;
return 0;
}
A n=3
B n=4
C n=1
D n=0
在cla中定了类静态类型的对象,所以是所有类共享的,将n初始为0,然后构造n++,之后析构n–
在main函数中,先构造,然后n = 1,然后析构,n = 0,然后打印,所以n的值并不会变
这道题的答案是D
💦第十题
运行的程序总要与内存进行交互。内存作为操作系统中的重要资源,对内存的分配和释放进行管理是一项非常重要的工作,以下说法中错误的是 ______。
A 内存泄露是内存管理中的常见问题
B 悬挂引用指的是对某个对象的应用实际上指向一个错误的内存地址
C 在C、C++等系统语言中,有自动的内存管理机制,不需要考虑内存管理的问题
D 程序的动态性越强,内存管理就越重要,内存分配程序的选择也就更重要
C/C++没有内存回收机制,所有在堆上申请的内存都需要用户手动释放
A 因为没有内存回收机制,所以内存泄漏这个问题需要用户处理
B 我们用个Swap来进行举例,看起来是用整型变量,实际上是使用地址
C 没有内存回收机制,需要考虑内存管理问题
D 程序的动态性越强,内存管理就越重要,内存分配程序的选择也就更重要
这道题的答案是C
编程题
🔥第一题
链接:两种排序方法
- 解题思路
思路很简单,将接受的字符串都放到vector容器中,利用string的operator>=运算符重载来按ascii比较字符串,利用string的size来比较字符串的长度
- 代码演示
#include <iostream>
#include <vector>
#include <string>
using namespace std;
int main()
{
vector<string> v;
int n;
cin >> n;
v.resize(n);
for(auto &str : v)
{
cin >> str;
}
bool lsort = true, csort = true;
for(int i = 0;i < n;i++)
{
if(v[i - 1].size() > v[i].size())
{
lsort = false;//并非按长度排序
break;
}
}
for(int i = 1 ; i< n;i++)
{
if(v[i - 1] > v[i])
{
csort = false;//并非按字典排序
break;
}
}
//判断是哪种情况
if(lsort && csort)
cout << "both" << endl;
else if(lsort)
cout << "lengths" << endl;
else if(csort)
cout << "lexicographically" << endl;
else
cout << "none" << endl;
return 0;
}
🔥第二题
链接:求最小公倍数
- 解题思路
最小公倍数 = 两数之积除以最大公约数,这里使用碾转相除法进行最大公约数的求解:即a与b的最大公约数可以转化为a、b之间的余数为两者之间最小的数之间的公约数。所以对于输入的两个数进行连续求余,直到余数为0,求余的分母即为结果。
- 代码演示
#include <iostream>
using namespace std;
// 方法一:暴力破解,用最大的数枚举得到最小公倍数
// int main() {
// int A, B;
// while (cin >> A >> B) {
// int m = max(A, B);
// while (1) {
// if (m % A == 0 && m % B == 0) {
// cout << m << endl;
// break;
// }
// m++;
// }
// }
// return 0;
// }
// 方法二: 更优解法,数学公式:两个数的最小公倍数就是两个数的乘积 / 最小公约数
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
% B == 0) {
// cout << m << endl;
// break;
// }
// m++;
// }
// }
// return 0;
// }
// 方法二: 更优解法,数学公式:两个数的最小公倍数就是两个数的乘积 / 最小公约数
**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**
**需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注大数据)**
[外链图片转存中...(img-udXxWoEE-1713339249657)]
**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**