C++程序设计-第四/五章 函数和类和对象【期末复习|考研复习】

2024-03-11 15:20

本文主要是介绍C++程序设计-第四/五章 函数和类和对象【期末复习|考研复习】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

总结整理不易,希望大家点赞收藏。

给大家整理了一下C++程序设计中的重点概念,以供大家期末复习和考研复习的时候使用。


C++程序设计系列文章传送门:
第一章 面向对象基础
第四/五章 函数和类和对象
第六/七/八章 运算符重载/包含与继承/虚函数和多态性
第九/十一/十二章 模板/输入/输出流/标准模板库


文章目录

  • 前言
  • 第四章 函数 函数和类和对象
    • 4.1 说明带参数的宏与内联函数有什么不同
    • 4.2 全局变量和局部变量有什么区别是怎么实现的操作系统和编译器是怎么知道?
  • 第五章 类和对象
    • 5.1 C中的Class和C++的 struct有什么区别
    • 5.2 数组与链表有什么区别各有什么优缺点
    • 5.3 简述成员函数全局函数和友元函数这些概念的异同
    • 5.4 完整举例const限定符的作用,跟C语言的const有什么区别
    • 5.5 完整举例static关键字的作用,跟C语言Java中的static有什么区别?
    • 5.6 构造函数是否有返回值类型?
    • 5.7 什么是拷贝构造函数?在什么情况下被调用?
    • 5.8 什么是深拷贝?什么是浅拷贝?他们有什么区别?
    • 5.9 头文件中的infdef/deifine/endif有什么区别?
    • 5.10 什么时候友元是有用的?说明使用友元的优缺点
  • 6 练手题
  • 下一章传送门


不重要的章节我们直接跳过,因此直接从第一章跳到第四章

第四章 函数 函数和类和对象

4.1 说明带参数的宏与内联函数有什么不同

1、编译器处理方式不同:带参数的宏是在预处理阶段进行处理,它会将所有使用该宏的地方直接替换成宏定义中的代码,并且没有任何类型检查和错误检查。而内联函数是在编译阶段进行处理,编译器会将内联函数的代码插入到函数调用的地方,可以进行类型检查和错误检查。
2、参数求值次数不同:带参数的宏在被调用时,宏定义中的代码会被简单地文本替换,因此宏参数的求值次数可能比较多,这可能会导致不符合预期的行为。而内联函数在被调用时,参数的求值次数与普通函数相同。
3、代码生成方式不同:带参数的宏在被处理时,每次都会生成新的代码,这可能会导致生成的代码量较大。而内联函数在编译时被处理成了一份代码,可以被多次使用,这有助于减小代码量,提高代码的可读性和可维护性。
4、调试方式不同:带参数的宏在调试时可能会产生困难,因为调试器看到的是宏定义中的代码,而不是调用宏时的代码。而内联函数则可以通过调试器进行单步调试,从而更容易地进行调试。

4.2 全局变量和局部变量有什么区别是怎么实现的操作系统和编译器是怎么知道?

操作系统和编译器通过符号表(symbol table)来识别和管理变量。
1、作用域不同:全局变量在整个程序中都可以访问,而局部变量只在它所在的代码块可以访问。
2、存储位置不同:全局变量存储在程序的数据段中,而局部变量通常存储在栈或寄存器中。
3、生命周期不同:全局变量的生命周期与程序的运行时间一致,而局部变量的生命周期只存在于其所在的代码块中,在离开该代码块时会被销毁。

第五章 类和对象

5.1 C中的Class和C++的 struct有什么区别

默认访问权限:在 C++ 中,class 的默认访问权限是私有的,而 struct 的默认访问权限是公有的。
继承:class 支持私有继承、公有继承和保护继承,而 struct 只支持公有和保护继承。
模板参数限制:class 作为模板参数时可以是任何类型,而 struct 只能作为模板参数用于构建类型。这是因为 Class 可以包含成员函数和成员类型,而 struct 只能包含成员变量和成员类型。

5.2 数组与链表有什么区别各有什么优缺点

内存分配方式:数组在内存中是连续的一段空间,而链表中的节点可以存储在任意位置,通过指针链接。
访问元素的方式:数组可以通过下标直接访问元素。而链表需要从头节点开始顺序遍历。
插入和删除元素的效率:数组在插入和删除元素时需要移动其他元素,时间复杂度为O(n)。而链表在插入和删除元素时只需要修改指针,时间复杂度为O(1)。
优缺点:数组的优点是访问元素快速,而链表的优点是插入和删除元素快速。在需要频繁访问元素但不需要频繁插入和删除元素时,数组是一个更好的选择。而在需要频繁插入和删除元素但不需要频繁访问元素时,链表是更好的选择。此外,链表可以支持动态分配内存,而数组在声明时需要确定大小。

5.3 简述成员函数全局函数和友元函数这些概念的异同

成员函数是一个属于类的函数,它可以访问类的私有成员变量和保护成员变量。成员函数可以被类的对象调用,并且可以重载。
全局函数是一个在任何类或命名空间之外定义的函数。全局函数不属于任何类,不能访问类的私有成员变量和保护成员变量。全局函数也可以重载。
友元函数是一个定义在类外部但是有权访问类私有成员的非成员函数。友元函数必须在类定义中进行声明,并且可以访问类的所有私有成员变量和保护成员变量。友元函数也可以重载。
异同点:
定义位置:成员函数定义在类的内部,全局函数和友元函数定义在类的外部。
访问权限:成员函数可以访问类的私有成员变量和保护成员变量,而全局函数和友元函数不能访问类的私有成员变量和保护成员变量。
调用方式:成员函数必须通过类的对象调用,而全局函数和友元函数可以直接调用或通过对象调用。
重载:成员函数、全局函数和友元函数都可以重载。
归属关系:成员函数属于类,而全局函数和友元函数不属于任何类。
作用范围:成员函数的作用范围限定于类的对象,而全局函数和友元函数的作用范围不受限制。

5.4 完整举例const限定符的作用,跟C语言的const有什么区别

在C语言中,用const修饰的变量,其本质上还是个变量,可以通过指针来修改该变量的值。在C++中 ,在编译的时候,当碰到用const修饰的变量时,编译器是直接将变量的值和变量的符号对应起来一起存到符号表中。不会为const变量分配空间。在编译的时候如果前面有extern和取地址符 & 时,会为变量分配存储空间是为了兼容C语言

5.5 完整举例static关键字的作用,跟C语言Java中的static有什么区别?

在C语言中,static关键字可以用于函数和变量,用于函数时表示该函数只能在当前文件中被调用,用于变量时表示该变量只能在当前文件中被访问。在C++中,static关键字可以用于类的成员变量和成员函数,用于成员变量时表示该变量是类的静态成员,所有对象共享该变量,用于成员函数时表示该函数是类的静态成员函数,可以直接通过类名调用。

5.6 构造函数是否有返回值类型?

构造函数没有返回值类型。

5.7 什么是拷贝构造函数?在什么情况下被调用?

拷贝构造函数是一种特殊的构造函数,函数的名称必须和类名称一致,它的唯一的一个参数是本类型的一个引用变量,该参数是const类型,不可变的。例如:类X的拷贝构造函数的形式为X(const X & x)。
调用情况:
1、当用类的一个对象去初始化该类的另一个对象的时候。
2、如果函数的形参是类的对象,调用此函数的时候,进行形参和实参相结合时,拷贝构造函数被调用。
3、如果函数的返回值是类的一个对象,函数执行完成返回调用者时,会建立一个匿名对象,在对匿名对象进行拷贝构造。

5.8 什么是深拷贝?什么是浅拷贝?他们有什么区别?

浅拷贝:当编写一个类时,并且没有添加拷贝构造,此时系统会默认添加一个拷贝构造(浅拷贝)。浅拷贝是指:创建一个新对象时,把对象的初始属性都复制一份,若是存在引用类型,则拷贝的是其内存地址,当它的值发生改变时,另一个的值也会受到改变。若存在析构函数,可能会出现析构多次的情况。
深拷贝:深拷贝就是将对象从内存中完全拷贝出来,并且重新开辟一片空间来进行存放,当其中一个值发生改变时并不会影响另一个的值,两者互不影响。

5.9 头文件中的infdef/deifine/endif有什么区别?

当多个文件中同时包含相同的头文件,将头文件放到#ifndef/#deifne#endif中防止大量冲突。#ifndef <标识> #define <标识> … … #endif

5.10 什么时候友元是有用的?说明使用友元的优缺点

友元是一种定义在类外部的普通函数,但它需要在类体内进行声明,为了与该类的成员函数加以区别,在声明时前面加以关键字friend。友元不是成员函数,但是它可以访问类中的私有成员。
friend ostream& operator<<(ostream& _cout, const Date& d);
友元的作用在于提高程序的运行效率,但是,它破坏了类的封装性和隐藏性,使得非成员函数可以访问类的私有成员。

6 练手题

在这里插入图片描述

下一章传送门

第六/七/八章 运算符重载/包含与继承/虚函数和多态性

这篇关于C++程序设计-第四/五章 函数和类和对象【期末复习|考研复习】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑