【选择题】校招笔试选择题第一辑

题目

  1. 以下程序的运行结果是( )
#include <stdio.h>
int main(void) {
	printf("%s , %5.3s\n", "computer", "computer");
	return 0;
}

A. computer , puter
B. computer ,   com
C. computer , computer
D. computer , compu.ter

  1. 在32位cpu上选择缺省对齐的情况下,有如下结构体定义:
struct A{
	unsigned a : 19;
	unsigned b : 11;
	unsigned c : 4;
	unsigned d : 29;
	char index;
};

sizeof(struct A)的值为( )

A. 9
B. 12
C. 16
D. 20

  1. 32位系统中,定义**a[3][4],则变量占用内存空间为( )。
    A. 4
    B. 48
    C. 192
    D. 12

  2. 假设在一个 32 位 little endian 的机器上运行下面的程序,结果是多少?

#include <stdio.h>
int main(){
	long long a = 1, b = 2, c = 3;
	printf("%d %d %d\n", a, b, c);
	return 0;
}

A.1,2,3
B.1,0,2
C.1,3,2
D.3,2,1

  1. 有以下程序,程序运行后的输出结果是( )
#include<iostream>
#include<cstdio>
using namespace std;
int main(){
	int m=0123, n=123;
	printf("%o %o\n", m, n);
	return 0;
}

A. 0123 0173
B. 0123 173
C. 123 173
D. 173 173

  1. 定义char dog[]=“wang\0miao”;那么sizeof(dog)与strlen(dog)分别是多少( )
    A. 10,4
    B. 4,4
    C. 9,9
    D. 9,4

  2. 下面两个结构体,在#pragma pack(4)和#pragma pack(8)的情况下,结构体的大小分别是( )

struct One{
	double d;
	char c;
	int i;
}
struct Two{
	char c;
	double d;
	int i;
}

A. 16 24,16 24
B. 16 20,16 20
C. 16 16,16 24
D. 16 16,24 24

  1. 有一个类A,其数据成员如下:
class A {
...
private:
	int a;
public:
	const int b;
	float* &c;
	static const char* d;
	static double* e;
};

则构造函数中,成员变量一定要通过初始化列表来初始化的是( )
A. a b c
B. b c
C. b c d e
D. b c d
E. b
F. c

  1. C++ 中,有如下类模板定义:
template<class T>
class BigNumber{
	long n;
public:
	BigNumber(T i) :n(i) {}
	BigNumber operator+(BigNumber b) {
	return BigNumber(n + b.n);
	}
}; 

已知 b1, b2 是 BigNumber 的两个对象,则下列表达式中错误的是( )
A. 3+3
B. b1+3
C. b1+b2
D. 3+b1

  1. 关于引用以下说法错误的是( )
    A. 引用必须初始化,指针不必
    B. 引用初始化以后不能被改变,指针可以改变所指的对象
    C. 不存在指向空值的引用,但是存在指向空值的指针
    D. 一个引用可以看作是某个变量的一个“别名”
    E. 引用传值,指针传地址
    F. 函数参数可以声明为引用或指针类型

  2. 以下代码共调用多少次拷贝构造函数:( )

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

  1. 在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是 ( )
    A. 无操作数的运算符
    B. 二元运算符
    C. 前缀一元运算符
    D. 后缀一元运算符

  2. 在C++中,为了让某个类只能通过new来创建(即如果直接创建对象,编译器将报错),应该( )
    A. 将构造函数设为私有
    B. 将析构函数设为私有
    C. 将构造函数和析构函数均设为私有
    D. 没有办法能做到

  3. print()函数是一个类的常成员函数,它无返回值,下列表示中正确的是( )
    A. const void print();
    B. void const print();
    C. void print() const;
    D. void print(const);

  4. 如果MyClass为一个类,执行”MyClass a[5], *b[6]”语言会自动调用该类构造函数的次数是( )
    A. 2
    B. 5
    C. 4
    D. 9

  5. 以下程序输出是( )

#include <iostream>
using namespace std;
int main(void)
{
	const int a = 10;
	int * p = (int *)(&a);
	*p = 20;
	cout<<"a = "<<a<<", *p = "<<*p<<endl;
	return 0;
}

A. 编译阶段报错运行阶段报错
B. a = 10, *p = 10
C. a = 20, *p = 20
D. a = 10, *p = 20
E. a = 20, *p = 10

  1. 如果有一个类是 myClass , 关于下面代码正确描述的是 ( )
myClass::~myClass(){
	delete this;
	this = NULL;
}

A. 正确,我们避免了内存泄漏
B. 它会导致栈溢出
C. 无法编译通过
D. 这是不正确的,它没有释放任何成员变量。

  1. 请问以下说法,哪个是正确的 ( )
    A. 每个类都有一个无参数的构造函数。
    B. 每个类都有一个拷贝构造的函数。
    C. 每个类能有多个构造函数。
    D. 每个类能有多个析构函数。

  2. C++中关于堆和栈的说法,哪个是错误的 ( )
    A. 堆的大小仅受操作系统的限制,栈的大小一般较小
    B. 在堆上频繁的调用new/delete容易产生内存碎片,栈没有这个问题
    C. 堆和栈都可以静态分配
    D. 堆和栈都可以动态分配

  3. C++将父类的析构函数定义为虚函数,下列正确的是哪个( )
    A. 释放父类指针时能正确释放子类对象
    B. 释放子类指针时能正确释放父类对象
    C. 这样做是错误的
    D. 以上全错

  4. 分析一下这段程序的输出( )

#include<iostream>
using namespace std;
class B
{
public:
	B()
	{
		cout << "default constructor" << " ";
	}
	~B()
	{
		cout << "destructed" << " ";
	}
	B(int i): data(i)
	{
		cout << "constructed by parameter" << data << " ";
	}
private: int data;
};
B Play( B b)
{
	return b;
}
int main(int argc, char *argv[])
{
	B temp = Play(5);
	return 0;
}

A. constructed by parameter5 destructed destructed
B. constructed by parameter5 destructed
C. default constructor" constructed by parameter5 destructed
D. default constructor" constructed by parameter5 destructed destructed

  1. 有一个类B继承自类A,他们数据成员如下:
class A {
...
privateint a;
};

class B : public A {
...
private:
	int a;
public:
	const int b;
	A &c;
	static const char* d;
	B* e;
}

则构造函数中,成员变量一定要通过初始化列表来初始化的是( )
A. a b c
B. b c e
C. b c d e
D. c e
E. b d
F. b c

  1. 以下程序的输出是( )
class Base {
public:
	Base(int j): i(j) {}
	virtual~Base() {}
	void func1() {
		i *= 10;
		func2();
	}
	int getValue() {
		return i;
	}
protected:
	virtual void func2() {
		i++;
	}
protected:
	int i;
};

class Child: public Base {
public:
	Child(int j): Base(j) {}
	void func1() {
		i *= 100;
		func2();
	}
protected:
	void func2() {
		i += 2;
	}
};
int main() {
	Base * pb = new Child(1);
	pb->func1();
	cout << pb->getValue() << endl; delete pb;
}

A. 11
B. 101
C. 12
D. 102

  1. 有如下C++代码:
struct A{
	void foo(){printf("foo");}
	virtual void bar(){printf("bar");}
	A(){bar();}
};
struct B:A{
	void foo(){printf("b_foo");}
	void bar(){printf("b_bar");}
};

那么

A *p = new B;
p->foo();
p->bar();

输出为( )
A. barfoob_bar
B. foobarb_bar
C. barfoob_foo
D. foobarb_fpp

  1. 以下程序输出结果是( )
class A
{
public:
	virtual void func(int val = 1)
	{ std::cout<<"A->"<<val <<std::endl;}
	virtual void test()
	{ func();}
};

class B : public A
{
public:
	void func(int val=0) {std::cout<<"B->"<<val <<std::endl;}
};

int main(int argc ,char* argv[])
{
	B*p = new B;
	p->test();
	return 0;
}

A. A->0
B. B->1
C. A->1
D. B->0

  1. 下面这段代码运行时会出现什么问题?
class A
{
public:
	void f()
	{
		printf("A\n");
	}
};

class B: public A
{
public:
	virtual void f()
	{
		printf("B\n");
	}
};

int main()
{
	A *a = new B;
	a->f();
	delete a;
	return 0;
}
  1. 代码执行后,a和b的值分别为( )
class Test {
public:
	int a;
	int b;
	virtual void fun() {}
	Test(int temp1 = 0, int temp2 = 0)
	{
		a = temp1;
		b = temp2;
	}
	int getA()
	{
		return a;
	}
	int getB()
	{
		return b;
	}
};
int main()
{
	Test obj(5, 10);
	// Changing a and b
	int* pInt = (int*)&obj;
	*(pInt + 0) = 100;
	*(pInt + 1) = 200;
	cout << "a = " << obj.getA() << endl;
	cout << "b = " << obj.getB() << endl;
	return 0;
}

A. 200 10
B. 5 10
C. 100 200
D. 100 10

参考答案

  1. B
    %m:ns:其中m表示输出字符串的宽度;n表示左起截取目标字符串 n 个字符进行输出,并且是右对齐,左边补空格。
  2. C
    参考学习C语言结构体【内存对齐】与【实现位段】
  3. B
    a先和方括号结合,a是一个三行四列的二维数组;**是指针类型,32位系统下是4个字节,所以有4 * 12 = 48
  4. B
    小端存储:低位数据存放到低地址处。
    内存中,
    a的存储是:01 00 00 00 00 00 00 00
    b的存储是:02 00 00 00 00 00 00 00
    c的存储是:03 00 00 00 00 00 00 00
    之后调用printf函数,要创建函数栈帧。栈帧的创建是从高地址往低地址创建。
    函数传参压栈是从右向左进行的。
    所以有如下的栈帧情况:
    在这里插入图片描述
    %d打印,是打印4个字节,
    所以第一次打印01 00 00 00,所以第一次打印00 00 00 00,所以第一次打印02 00 00 00
    即1,0,2。
  5. C
    m是八进制数,n是十进制数,%o是按照八进制进行打印。
  6. A
    sizeof计算变量所对应类型占的字节数。
  7. C
    参考C语言结构体【内存对齐】与【实现位段】。
  8. B
    初始化列表只能对类中非静态成员变量进行初始化。
    const修饰的成员变量,引用类型的成员变量,类类型对象且该类没有默认的构造函数,这三种成员必须在初始化列表位置进行初始化。
  9. D
    如果类中具有单个参数的构造函数,该构造函数具有类型转换的作用。编译器在编译代码阶段,会调用单参构造函数进行类型转换。
  10. E
    引用底层是使用指针实现的,引用本质还是指针。
  11. D
  12. C
  13. B
    new的原理是:a.申请空间,b.调用构造函数对申请的空间进行初始化。如果构造函数私有了,就无法new创建对象了。delete的原理:a.调用类的析构函数,b.释放空间。析构函数私有了,会影响对象空间的delete释放。
  14. C
    常成员函数是指const成员函数,此时的const修饰this指针,表示在该成员函数中,不能修改类的非静态成员变量。
  15. B
    MyClass a[5]有是5个MyCLass类型对象的一个数组,需要调用5次MyClass类的构造函数;MyClass* b[6]是一个指针数组,该数组中的每个元素存放的都是MyClass*类型的指针。
  16. D
    C++中cosnt修饰的变量,就相当于一个常量,是具有替换作用的。在编译阶段,会将const修饰的变量替换成常量。
  17. C
    首先,不能在析构函数中delete this
~myClass(){
	delete this;
}

上面代码可以通过编译,但运行会奔溃。
delete this有两个作用,一是调用析构函数释放对象中的资源,二是调用operator delete释放对象的空间。
所以,析构函数中delete this会形成无限递归,导致程序运行栈溢出崩溃。
并不是所有的对象都是从对象new出来的,所以不能一味地delete this
this=NULL编译会失败,要知道this类型是myClass* const的,this指针的指向不能被修改。

  1. C
    类里面也可以没有拷贝构造函数。
  2. C
    堆只能动态分配(运行时决定分配空间的大小),栈静态和动态分配都可以。
  3. A
  4. A
  5. F
    d在类外初始化。
  6. C
  7. A
  8. B
    虚函数接口继承。
  9. 运行时崩溃。子类的虚表指针安放有问题。
  10. A
    头部存放的有虚表指针。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/213170.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

zookeeper+kafka+ELK+filebeat集群

目录 一、zookeeper概述&#xff1a; 1、zookeeper工作机制&#xff1a; 2、zookeeper主要作用&#xff1a; 3、zookeeper特性&#xff1a; 4、zookeeper的应用场景&#xff1a; 5、领导者和追随者&#xff1a;zookeeper的选举机制 二、zookeeper安装部署&#xff1a; 三…

STM32-SPI 中断

SPI协议 1.1 SPI总线介绍 SPI接口是Motorola &#xff08;motorola | Smartphones, Accessories & Smart Home Devices&#xff09;首先提出的全双工三线/四线同步串行外围接口采用主从模式&#xff08;Master Slave&#xff09;架构。 时钟由Master控制&#xff0c;在时钟…

【Leetcode题单】(01 数组篇)刷题关键点总结02【统计数组中的元素】

【Leetcode题单】&#xff08;01 数组篇&#xff09;刷题关键点总结02【统计数组中的元素】&#xff08;6题&#xff09; 统计数组中的元素645. 错误的集合 Easy697. 数组的度 Easy448. 找到所有数组中消失的数字 Easy442. 数组中重复的数据 Medium41. 缺失的第一个正数 Hard27…

Docker镜像制作与推送

目录 Docker镜像制作 搭建私服 将本地镜像推送到私有库 Docker镜像制作 以创建一个新ubuntu镜像&#xff0c;并安装vim命令示例 运行一个ubuntu镜像&#xff0c;发现在镜像里面无法使用vim命令&#xff0c;因为该ubuntu镜像只包括了其最基本的内核命令 [rootlocalhost ~]…

找不到msvcp110.dll如何修复?分享5个亲测有效的修复方法

在计算机使用过程中&#xff0c;我们经常会遇到一些错误提示&#xff0c;其中之一就是“msvcp110.dll丢失”。这个错误通常发生在运行某些程序时&#xff0c;系统无法找到所需的动态链接库文件。那么&#xff0c;msvcp110.dll到底是什么呢&#xff1f;它又有什么作用&#xff1…

算法通关村第七关—理解二叉树的遍历(白银)

深入理解前中后序遍历 给定一棵二叉树 二叉树前序遍历 public void preorder(TreeNode root,List<Integer>res){if&#xff08;rootnull){return;}res.add(root.val);preorder(root.left,res);preorder(root.right,res); }递归的过程如下图所示 从图中可以看到&#x…

〖大前端 - 基础入门三大核心之JS篇㊺〗- 定时器和延时器

说明&#xff1a;该文属于 大前端全栈架构白宝书专栏&#xff0c;目前阶段免费&#xff0c;如需要项目实战或者是体系化资源&#xff0c;文末名片加V&#xff01;作者&#xff1a;不渴望力量的哈士奇(哈哥)&#xff0c;十余年工作经验, 从事过全栈研发、产品经理等工作&#xf…

12月1号作业

实现运算符重载 #include <iostream>using namespace std; class Person{friend const Person operator-(const Person &L,const Person &R);friend bool operator<(const Person &L,const Person &R);friend Person operator-(Person &L,const …

第二十二章 指定元素和属性的命名空间 - 指定被视为Global元素的对象的命名空间

文章目录 第二十二章 指定元素和属性的命名空间 - 指定被视为Global元素的对象的命名空间指定被视为Global元素的对象的命名空间指定映射为元素的属性的命名空间案例1&#xff1a;属性被视为本地元素案例2:属性被视为Global元素 第二十二章 指定元素和属性的命名空间 - 指定被视…

Unity 简单打包脚本

打包脚本 这个打包脚本适用于做demo&#xff0c;脚本放在Editor目录下 using System; using System.Collections; using System.Collections.Generic; using System.IO; using UnityEditor; using UnityEngine;public class BuildAB {[MenuItem("Tools/递归遍历文件夹下…

【蓝桥杯】带分数

带分数 题目要求用一个ab/c的形式得到一个值&#xff0c;而且只能在1~9里面不重复的组合。 可以对1~9进行全排列&#xff0c;然后不断划分区间。 #include<iostream> #include<vector> using namespace std; int st[15]; int num[15]; int res; int n;int calc(i…

基于Python实现的滑动验证码自动识别工具源码

滑动验证码识别 今天的目标地址是字节的巨量纵横&#xff0c;目前东家是一家广告营销型的公司&#xff0c;专注于在各大平台投放信息流广告。巨量纵横为字节跳动的广告平台&#xff0c;用于管理推广账户。今天破解一下这个平台的登陆入口&#xff0c;为今后的数据爬取开个头。…

Android 源码编译

一&#xff0c;虚拟机安装 ​ 1.1 进入https://cn.ubuntu.com/download中文官网下载iso镜像 1.2 这里我们下载Ubuntu 18.04 LTS 1.3虚拟VM机安装ubuntu系统&#xff0c;注意编译源码需要至少16G运行内存和400G磁盘空间&#xff0c;尽量设大点 二 配置编译环境 2.1 下载andr…

进行主从复制时出现的异常FATAL CONFIG FILE ERROR (Redis 6.2.6)Reading the configuration file

错误如下所示&#xff1a; FATAL CONFIG FILE ERROR (Redis 6.2.6) Reading the configuration file, at line 1 >>> include/myredis/redis.conf Bad directive or wrong number of arguments出现错误的原因是.conf文件中命令之间缺少空格&#xff0c;如下所示&…

Sharding-Jdbc(4):Sharding-Jdbc分库

1 新建数据库 创建ds_0数据库和ds_1数据库&#xff0c;在两个数据库新建表如下&#xff1a; CREATE TABLE t_order (order_id bigint(20) NOT NULL,user_id bigint(20) NOT NULL,PRIMARY KEY (order_id) ) ENGINEInnoDB DEFAULT CHARSETutf8 COLLATEutf8_bin; 2 新建maven项目…

GAMES101:作业2记录

总览 在上次作业中&#xff0c;虽然我们在屏幕上画出一个线框三角形&#xff0c;但这看起来并不是那么的有趣。所以这一次我们继续推进一步——在屏幕上画出一个实心三角形&#xff0c;换言之&#xff0c;栅格化一个三角形。上一次作业中&#xff0c;在视口变化之后&#xff0…

yolo.txt格式与voc格式互转,超详细易上手

众所周知,yolo训练所需的标签文件类型是.txt的,但我们平时使用标注软件(labelimage等)标注得到的标签文件是.xml类型的,故此xml2txt之间的转换就至关重要了,这点大家不可能想不到,但是网上的文章提供的代码大多数都是冗余,或者难看,难以上手,故此作者打算提供一个相对…

51单片机PWM讲解

前言 51单片机我已经很久没用过了&#xff0c;毕竟是十年前的产物了&#xff0c;但是由于工作室的学弟学妹需要学习&#xff0c;加之马上就要举行循迹小车比赛&#xff0c;很多人反映看不懂PWM&#xff0c;或者看了不会用&#xff0c;于是写一篇文章简单介绍一下。 PWM普遍应…

“B2B+OMS方案”,赋能家电巨头构建BC订单一体化能力,促进业务增长|徐礼昭

某国际知名家电电器品牌&#xff0c;年营收超过5000亿元。该电器企业其整体业务分三大类&#xff1a;线上线下B2B2C业务、线下B2B业务以及DTC零售业务。 随着业务的发展&#xff0c;该电器品牌对2B业务及DTC业务的数字化系统能力支撑需要更加全面和立体&#xff0c;以适应业务…

5个优质免费自然语言处理学习资源 | 语言技术导航

探索并利用我们的5个免费自然语言处理&#xff08;NLP&#xff09;学习资源&#xff0c;更有效地理解和实施自然语言处理技术。适合初学者和进阶者&#xff0c;涵盖基础理论到实际应用。 近年来&#xff0c;随着人工智能&#xff08;AI&#xff09;解决方案的商业应用&#xff…