haizei c++ 试听课程知识点 day1

2023-11-04 09:59

本文主要是介绍haizei c++ 试听课程知识点 day1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一天   基础

 

1.cout   是对象   用运算符<<将数据传递给此对象    当然是通过构造函数

2.cout 针对自定义类型的输出,需要用到 运算符重载。

class Point{public:Point(int x,int y);friend ostream &operator<<(ostream &out,const Point &p);//友元用来访问私有成员  private:int x,y;}Point::Point(int x,int y):x(x),y(y){}    //类构造函数声明和定义需要拆分开ostream &operator<<(ostream &out,const Point &p)          //  ostream &左值引用     此处为重载运算符的函数{out<<""<<p.x<<","<<p.y<<")";return out;}int main(){Point a(3,4);cout<<"hello world"<<endl;cout<<a<<endl;//如果不重载<<运算符   则编译器会报错return 0;}

 尽量不要用using namspace std;        而是需要明确指定需要引入的对象

例如需要使用  using std::cout;

      using std::endl;

3.技术想象力 

程序设计编程范式:

面向过程      面向对象         泛型编程         函数式编程

int  add1(int a,int b)     //面向过程{return a+b;}class ADD{    //面向对象public:int operator()(int a,int b){return a+b;}};template<tempename T,typename U>    //泛型编程auto add3(T a,U b)->decltype(a+b){    return a+b;  }    //返回值后置auto add4=[](int a,int b)->int{       //函数式编程    λ表达式  return a+b;}int main(){ADD add2;cout<<add1(3,4)<<endl;    // 看起来都是面向过程  但是每行均不同cout<<add2(3,4)<<endl;cout<<add3(3,4)<<endl;cout<<add4(3,4)<<endl;return 0;}

c++语法特别多的直接原因就是为了同时支持四种不同的编程范式。

c++与底层系统的联系    c++与网络的联系 

先学编程的思维方式和其余的相关基础知识  再学c++

4.编程学习方法

linux  直接用编译器 命令    而不用ide

了解程序运行的各个步骤  更加详细。

源代码-------》对象文件(编译后)------》可执行程序(链接后)

对象文件   obj   放着定义  目标文件

1.c   生成1.o 目标文件

2.c   生成2.o目标文件

3.c   生成3.o目标文件

这三个目标文件通过链接的过程 生成a.out  可执行程序文件。

 #include <vector>using namespace std;int add(int ,int);int main(){printf("hello world\n");printf("add(3,4)=%d\n",add(3,4));return 0;}int add(int a,int b){return a+b;}

编译过程基础知识:

g++   main.cpp       直接编译

g++   -c   main.cpp    生成目标文件   main.o   这里包含着函数定义

nm   -C  main.o       查看对象文件

  内容显示如下

    00000000000050      T add(int,int)      //定义

    00000000000000   T  _main        //定义

               U  _printf        //到外部查找定义

编译阶段主要作用:语法检查:    例如上例,如果有声明,但是没有定义 则编译也会通过。 注意这里的编译指的是g++  -c 
  报错:字符未找到等等  

 链接阶段主要作用:相关定义的匹配

main.o   中有add函数声明,而add函数的定义位于   a.o对象文件中,需要把main.o和a.o两个文件链接在一起。

 链接命令:g++  main.o  a.o

生成a.out   最后运行./a.out  

  报错:1.未定义的标识符    undefined symbols    未找到定义

     2.main.o和a.o中都有定义

      则提示   duplicate symbol     重复的标识符

声明位于头文件中,定义位于源文件中

5.

  引入第三方功能模块

  google测试框架举例

  

举例:

gtest   google测试框架  源代码

解压缩文件后    在文件夹中找到编译文件    Cmakelist.txt

make build  新建文件夹

cd build  

cmake ../    命令定位到上一层目录  找Cmakelist.txt文件    并将生成的结果文件生成到build文件夹内。

make      命令 进行编译

  从提示的信息可以看到     此命令   用来链接静态链接库    

    例如    linking CXX  static library ../lib/libgtest.a

  build/lib存放静态链接库    libgmock.a      libgmock_main.a       libgtest.a      libgtest_main.a

  include 文件夹存放 头文件

  cp   -R  include  ../   复制到上层目录

使用模块功能  在用户程序中包含对应的第三方功能模块的头文件

#include  <gtest/gtest.h>

如果提示文件无法找到     则是搜索头文件路径时   增加一个路径:g++ -I./include -c main.cpp   增加了当前目录下的include文件夹为附加的头文件搜索路径。

链接:加入第三方静态链接库  

  g++ -L./lib   main.o -lgtest      第三方静态链接库位于当前目录下的lib文件夹下

这篇关于haizei c++ 试听课程知识点 day1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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底层实现:基于红黑

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快