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++ Primer Plus习题】13.4

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

基本知识点

1、c++的输入加上ios::sync_with_stdio(false);  等价于 c的输入,读取速度会加快(但是在字符串的题里面和容易出现问题) 2、lower_bound()和upper_bound() iterator lower_bound( const key_type &key ): 返回一个迭代器,指向键值>= key的第一个元素。 iterator upper_bou

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提供个模板形参的名

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模拟实现

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给