Linux环境基础和工具的使用

目录

1、Linux软件包管理器---yum

2、Linux开发工具

2.1、vim基本概念

2.2 vim基本操作

2.3 vim正常模式命令集

2.4 vim末行模式命令集

2.5 简单vim配置

2.5.1 配置文件的位置

3 Linux编译器--gcc/g++的使用

3.1 背景知识

3.2 gcc完成

4 Linux调试器--gdb使用

4.1 背景

4.2 gdb的使用

5 、Linux项目自动化构建工具--make/Mikefile

6、Linux系统下第一个小程序--进度条


1、Linux软件包管理器---yum

软件包:

  • 在Linux系统中安装软件,通常是下载程序源代码,然后进行编译,得到可执行程序。
  • 但是这样比较麻烦,这时就有人将一些常见的软件编译好,做成软件包,放在服务器中通过包管理就可以很方便的获取到这个编译好的软件包,从而可以直接进行安装。
  • 软件包和软件包管理器,相当于“App”和软件应用商店之间的1关系,yum就是Linux系统下的一种常见的软件包管理器,主要应用于Fedora, RedHat、Centos等发行版上.

查看软件包

        我们可以使用yum list 来列出当前一共有哪些软件包,由于软件包数量很多,因此在这里我使用grep命令来筛选出其中一个。

        从上述结果出我们可以看出:其中包含软件包名称,主版本号,次版本号,源程序发行号,软件包发行号,主机平台,cpu架构。

        “x86_x64”表示是64位系统的安装包(‘i686’表示32位系统的安装包,选着包时应该要与系统匹配)

        "el7" 表示操作系统发行版的版本. "el7" 表示的是 centos7/redhat7. "el6" 表示 centos6/redhat6.

        最后一列, os 表示的是 "软件源" 的名称, 类似于 "小米应用商店", "华为应用商店" 这样的概念.

安装软件

        我们可以使用 sudo yum install 软件包名称 来安装程序,当出现complete字样则说明安装成功,安装软件时由于要向系统目录中写入内容,一般需要使用sudo切换到root账户下才能完成,该命令只能一个一个安装,如果多个同时安装则会报错。

卸载软件

        我们今天使用 sudo yum remove 软件包名称 来卸载软件。

注意:在只用所有yum命令必须保证主机(虚拟机)网络通畅。

2、Linux开发工具

2.1、vim基本概念

        vim具有很多种命令模式,但是常用的有三种:命令模式(command mode)、插入模式(insert mode)、底行模式(last line mode)。

  •  正常、普通、命令模式(Normal mode):
              控制屏幕光标的移动,字符,字或行的删除,移动复制某区段进入insert mode 或者到last line mode
  • 插入模式(Insert mode)
               只有在insert mode下才能对文件进行文字输入,可以按【Esc】回到命令行模式。
  • 末行模式(last line mode)
    ​​​​          文件的保存或退出,也可以对文件进行替换,找字符串,列出行号等操作。

2.2 vim基本操作

进入vim,在系统提示符号输入vim及文件名称后,就进入vim全屏幕编辑画面:

  •         $ vim test.c
  •         不过有一点要特别注意,就是你进入vim之后,是处于[正常模式],你要切换到[插入模式]才能够输入文字。

[正常模式]切换至[插入模式]

  •         输入a
  •         输入i
  •         输入o

[插入模式]切换至[正常模式]         

  •         目前处于[插入模式],就只能一直输入文字,如果发现输错了字,想用光标键往回移动,将该字删除,可 以先按一下「ESC」键转到[正常模式]再删除文字。当然,也可以直接删除。

[正常模式]切换至[末行模式]

  •         「 shift + ;」, 其实就是输入「:」

 退出vim及保存文件,在[正常模式]下,按一下「:」冒号键进入「Last line mode」,例如: :

  •         :w (保存当前文件)
  •         : wq (输入「wq」,存盘并退出vim)         
  •         : q! (输入q!,不存盘强制退出vim

2.3 vim正常模式命令集

插入模式

        按「i」切换进入插入模式「insert mode」,

        按“i”进入插入模式后是从光标当前位置开始输入文件;

        按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;

        按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。

从插入模式切换为命令模式

        按「ESC」键。

移动光标

        vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母「h」、「j」、「k」、 「l」,分别控制光标左、下、上、右移一格

        按「G」:移动到文章的最后 按「 $ 」:移动到光标所在行的“行尾”

        按「^」:移动到光标所在行的“行首”

        按「w」:光标跳到下个字的开头

        按「e」:光标跳到下个字的字尾

        按「b」:光标回到上个字的开头

        按「#l」:光标移到该行的第#个位置,如:5l,56l

        按[gg]:进入到文本开始

         按[shift+g]:进入文本末端

        按「ctrl」+「b」:屏幕往“后”移动一页

        按「ctrl」+「f」:屏幕往“前”移动一页

        按「ctrl」+「u」:屏幕往“后”移动半页

        按「ctrl」+「d」:屏幕往“前”移动半页

删除文字

        「x」:每按一次,删除光标所在位置的一个字符

        「#x」:例如,「6x」表示删除光标所在位置的“后面(包含自己在内)”6个字符         「X」:大写的X,每按一次,删除光标所在位置的“前面”一个字符

        「#X」:例如,「20X」表示删除光标所在位置的“前面”20个字符

        「dd」:删除光标所在行

        「#dd」:从光标所在行开始删除#行

复制

        「yw」:将光标所在之处到字尾的字符复制到缓冲区中。

        「#yw」:复制#个字到缓冲区

        「yy」:复制光标所在行到缓冲区。

        「#yy」:例如,「6yy」表示拷贝从光标所在的该行“往下数”6行文字。

        「p」:将缓冲区内的字符贴到光标所在位置。注意:所有与“y”有关的复制命令都必须与“p”配合才能完 成复制与粘贴功能。

替换

        「r」:替换光标所在处的字符。

        「R」:替换光标所到之处的字符,直到按下「ESC」键为止。

撤销上一次操作

        「u」:如果您误执行一个命令,可以马上按下「u」,回到上一个操作。按多次“u”可以执行多次回 复。

        「ctrl + r」: 撤销的恢复

更改

        「cw」:更改光标所在处的字到字尾处

        「c#w」:例如,「c3w」表示更改3个字 跳至指定的行

        「ctrl」+「g」列出光标所在行的行号。

        「#G」:例如,「15G」,表示移动光标至文章的第15行行首。

2.4 vim末行模式命令集

        在使用末行模式之前,请记住先按「ESC」键确定您已经处于正常模式,再按「:」冒号即可进入末行模式。

列出行号

   「set nu」: 输入「set nu」后,会在文件中的每一行前面列出行号。

跳到文件中的某一行

        「#」:「#」号表示一个数字,在冒号后输入一个数字,再按回车键就会跳到该行了,如输入数字15, 再回车,就会跳到文章的第15行。

查找字符

        「/关键字」: 先按「/」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直按 「n」会往后寻找到您要的关键字为止。

        「?关键字」:先按「?」键,再输入您想寻找的字符,如果第一次找的关键字不是您想要的,可以一直 按「n」会往前寻找到您要的关键字为止。

保存文件

        「w」: 在冒号输入字母「w」就可以将文件保存起来

离开vim

        「q」:按「q」就是退出,如果无法离开vim,可以在「q」后跟一个「!」强制离开vim。

        「wq」:一般建议离开时,搭配「w」一起使用,这样在退出的时候还可以保存文件。

2.5 简单vim配置

2.5.1 配置文件的位置

        在目录 /etc/ 下面,有个名为vimrc的文件,这是系统中公共的vim配置文件,对所有用户都有效。

        而在每个用户的主目录下,都可以自己建立私有的配置文件,命名为:“.vimrc”。例如,/root目录下, 通常已经存在一个.vimrc文件,如果不存在,则创建之。

        切换用户成为自己执行 su ,进入自己的主工作目录,执行 cd ~

        打开自己目录下的.vimrc文件,执行 vim .vimrc

Vim 从入门到精通

3 Linux编译器--gcc/g++的使用

3.1 背景知识

1. 预处理(进行宏替换)

2. 编译(生成汇编)

3. 汇编(生成机器可识别代码)

4. 连接(生成可执行文件或库文件)

3.2 gcc完成

格式 gcc [选项] 要编译的文件 [选项] [目标文件]

预处理(进行宏替换)

  • 预处理功能主要包括宏定义,文件包含,条件编译,去注释等。
  • 预处理指令是以#号开头的代码行。
  • 实例: gcc –E hello.c –o hello.i
  • 选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
  • 选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序。

编译(生成汇编)

  • 在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查 无误后,gcc 把代码翻译成汇编语言。
  • 用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
  • 实例: gcc –S hello.i –o hello.s

汇编(生成机器可识别代码)

  • 汇编阶段是把编译阶段生成的“.s”文件转成目标文件
  • 读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了
  • 实例: gcc –c hello.s –o hello.o

连接(生成可执行文件或库文件)

  • 在成功编译之后,就进入了链接阶段。
  • 实例: gcc hello.o –o hello

在这里涉及到一个重要的概念:函数库

  • 我们的C程序中,并没有定义“printf”的函数实现,且在预编译中包含的“stdio.h”中也只有该函数的声明,而 没有定义函数的实现,那么,是在哪里实“printf”函数的呢?
  • 最后的答案是:系统把这些函数实现都被做到名为 libc.so.6 的库文件中去了,在没有特别指定时,gcc 会到 系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,这样就能实现函 数“printf”了,而这也就是链接的作用

函数库分为动态库和静态库两种

  • 静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,因此生成的文件比较大,但在运行时也 就不再需要库文件了。其后缀名一般为“.a”
  • 动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时 链接文件加载库,这样可以节省系统的开销。动态库一般后缀名为“.so”,如前面所述的 libc.so.6 就是动态 库。gcc 在编译时默认使用动态库。完成了链接之后,gcc 就可以生成可执行文件,如下所示。 gcc hello.o –o hello
  • gcc默认生成的二进制程序,是动态链接的,这点可以通过 file 命令验证。

gcc选项

  • -E 只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面
  • -S  编译到汇编语言不进行汇编和链接
  • -c  编译到目标代码
  • -o 文件输出到 文件
  • -static 此选项对生成的文件采用静态链接
  • -g 生成调试信息。GNU 调试器可利用该信息。
  • -shared 此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.
  • -O0
  • -O1
  • -O2
  • -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高
  • -w  不生成任何警告信息。
  • -Wall 生成所有警告信息。

4 Linux调试器--gdb使用

4.1 背景

        程序的发布方式有两种,debug模式和release模式 Linux gcc/g++出来的二进制程序,默认是release模式 要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项

4.2 gdb的使用

  • list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行。
  • list/l 函数名:列出某个函数的源代码。
  • r或run:运行程序。
  • n 或 next:单条执行。
  • s或step:进入函数调用
  • break(b) 行号:在某一行设置断点 break 函数名:在某个函数开头设置断点
  • info break :查看断点信息。
  • finish:执行到当前函数返回,然后挺下来等待命令
  • print(p):打印表达式的值,通过表达式可以修改变量的值或者调用函数
  • p 变量:打印变量值。
  • set var:修改变量的值
  • continue(或c):从当前位置开始连续而非单步执行程序
  • run(或r):从开始连续而非单步执行程序
  • delete breakpoints:删除所有断点
  • delete breakpoints n:删除序号为n的断点
  • disable breakpoints:禁用断点
  • enable breakpoints:启用断点
  • info(或i) breakpoints:参看当前设置了哪些断点
  • display 变量名:跟踪查看一个变量,每次停下来都显示它的值
  • undisplay:取消对先前设置的那些变量的跟踪
  • until X行号:跳至X行
  • breaktrace(或bt):查看各级函数调用及参数
  • info(i) locals:查看当前栈帧局部变量的值
  • quit:退出gdb

5 、Linux项目自动化构建工具--make/Mikefile

原理

make是如何工作的,在默认的方式下,也就是我们只输入make命令。那么,

        1. make会在当前目录下找名字叫“Makefile”或“makefile”的文件。

        2. 如果找到,它会找文件中的第一个目标文件(target),在上面的例子中,他会找到“hello”这个文件, 并把这个文件作为最终的目标文件。

        3. 如果hello文件不存在,或是hello所依赖的后面的hello.o文件的文件修改时间要比hello这个文件新(可 以用 touch 测试),那么,他就会执行后面所定义的命令来生成hello这个文件。

        4. 如果hello所依赖的hello.o文件不存在,那么make会在当前文件中找目标为hello.o文件的依赖性,如果 找到则再根据那一个规则生成hello.o文件。(这有点像一个堆栈的过程)         5. 当然,你的C文件和H文件是存在的啦,于是make会生成 hello.o 文件,然后再用 hello.o 文件声明 make的终极任务,也就是执行文件hello了。

        6. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文 件。

        7. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错, 而对于所定义的命令的错误,或是编译不成功,make根本不理。

        8. make只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,那么对不起, 我就不工作啦。

项目清理

  •         工程是需要被清理的
  •         像clean这种,没有被第一个目标文件直接或间接关联,那么它后面所定义的命令将不会被自动执行, 不过,我们可以显示要make执行。即命令——“make clean”,以此来清除所有的目标文件,以便重编 译。
  •         但是一般我们这种clean的目标文件,我们将它设置为伪目标,用 .PHONY 修饰,伪目标的特性是,总是被 执行的。

6、Linux系统下第一个小程序--进度条

//进度条
    #include<stdio.h>
    #include<unistd.h>
    #include<string.h>
    #define RED     "\x1b[31m"
    #define RESET   "\x1b[0m"
    #define M 101
    int main(){
      char MAX[M];
      char *x="-/\\|";                                                     
      memset(MAX ,0,sizeof(MAX));
      int cont=0;
      while(cont<100){
        MAX[cont++]='#';
        printf(RED"[%-100s]"RESET"[%d%%][%c]""\r",MAX,cont,x[cont%4]);
        fflush(stdout);
        usleep(100000);
      }
      printf("\n");
      return 0;
       

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

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

相关文章

每日面经分享(pytest测试案例,接口断言,多并发断言)

pytest对用户登录接口进行自动化脚本设计 a. 创建一个名为"test_login.py"的测试文件&#xff0c;编写以下测试脚本 import pytest import requests# 测试用例1&#xff1a;验证登录成功的情况 # 第一个测试用例验证登录成功的情况&#xff0c;发送有效的用户名和密…

【Linux】ubuntu安装google gtest框架

本文首发于 ❄️慕雪的寒舍 ubuntu 22.04.03 LTS 安装 google gtest 框架 1.依赖项 首先在ubuntu中安装如下包 sudo apt install -y unzip g gcc cmake make automake2.下载软件包 进入google gtest的github页面&#xff0c;下载源码包 Releases google/googletest https…

云数据中心传输的出路

研发端到端协议不是出路&#xff0c;研发更智能调度流量的交换机不是出路&#xff0c;将流量按长短突发模式分流到不同链路(逻辑的或物理的)才是出路。所有高速传输的前提是标准化&#xff0c;统一简单的操作。多么简单的领悟。 数据中心网络具有范围小&#xff0c;带宽大&…

C语言 输入输出语句讲解 标识符概念讲解

上文 C语言 预处理器 注释 基本案例讲解 我们讲了一些 预处理器等逻辑 那么 本文继续 C语言由一个或多个函数组成&#xff0c;每个程序都必须有一个main() 函数 因为每个程序总是从这个函数开始执行 main() 函数可以返回一个值&#xff0c;返回值为0表示程序正常结束 如果有多…

38.基于SSM实现的传统文化网站系统(项目 + 论文)

项目介绍 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;作为一个一般的企业都开始注重与自己的信息展示平台&#xff0c;实现传统文化网站在技术上已成熟。本文介绍了传统文化网站的开发全过程。通过分析传统文化的需求&#xff0c;创建了一个计算机管理传统文化网站…

百廿荣光 逐梦远航——记黄城根小学120年校庆

逝者如斯&#xff0c;黄城根小学建校百二十年矣。回首往昔&#xff0c;峥嵘岁月&#xff0c;如画卷展开&#xff0c;历历在目&#xff0c;皆美景胜概。楼宇更迭&#xff0c;万象更新&#xff1b;历代师生&#xff0c;薪火相传。笃学笃行&#xff0c;育桃李于学堂&#xff1b;至…

Linux 内核优化简笔 - 高并发的系统

简介 Linux 服务器在高并发场景下&#xff0c;默认的内核参数无法利用现有硬件&#xff0c;造成软件崩溃、卡顿、性能瓶颈。 当然&#xff0c;修改参数只是让Linux更好软件的去利用已有的硬件资源&#xff0c;如果硬件资源不够也无法解决问题的。而且当硬件资源不足的时候&am…

低代码革新:软件开发的未来潜力与创新路径探索

过去的一年&#xff0c;挑战与机遇并存。人们一边忧虑市场经济下行所带来的新的增长难题、裁员危机&#xff0c;一边惊叹于AIGC、量子技术等领域不断涌现新的创新成果。 时代发生了改变&#xff0c;传统“互联网”的模式已走入尾声&#xff0c;新一轮的科技革命与产业变革正在到…

【VSCode+Keil5+STM32CubeMX】开发环境配置

一、软件下载 二、软件安装 三、配置环境 四、验证开发环境 五、Keil与VS Code的同步 从0到1搭建VS Code Keil5 STM32CubeMX开发环境 优点 支持标准库HAL库LL库代码编辑更“现代化”&#xff1a;代码提示、函数跳转、更高自由度的定制主题等优点多端同步&#xff0c;VS Code和…

深入了解C语言中的结构体类型与内存对齐

引言&#xff1a; 在C语言中&#xff0c;结构体是一种自定义的数据类型&#xff0c;它允许我们将不同类型的数据组合在一起&#xff0c;形成一个新的数据类型。结构体的使用为我们解决了一些复杂数据的表示和处理问题&#xff0c;不仅限于单单的整型或者字符。本文将深入探讨结…

金三银四上岸!2024最新Java高频面试题总结(附答案PDF)!

《Java面试全解析》1000道 面试题大全详解&#xff08;针对于应届生、三到五年经验、六到十年经验&#xff01;&#xff09; 本人是 2009 年参加编程工作的&#xff0c;一路上在技术公司摸爬滚打&#xff0c;前几年一直在上海&#xff0c;待过的公司有 360 和游久游戏&#xf…

Mysql数据库getshell方法

今天摸鱼时候&#xff0c;突然有人问我不同的数据库getshell的方式&#xff0c;一时间我想到了mysql还有redis未授权访问到getshell的方式&#xff0c;但是仅仅第一时间只想到了这两种&#xff0c;我有查了查资料&#xff0c;找到了上面两种数据库getshell的补充&#xff0c;以…

python实现泊松回归

1 什么是基于计数的数据&#xff1f; 基于计数的数据包含以特定速率发生的事件。发生率可能会随着时间的推移或从一次观察到下一次观察而发生变化。以下是基于计数的数据的一些示例&#xff1a; 每小时穿过十字路口的车辆数量每月去看医生的人数每月发现的类地行星数量 计数数…

Mysql 常用SQL语句

1、查看mysql中所有的数据库&#xff0c; show databases; 2、创建库 create database 库名;&#xff08;也可以用 create database if not exists 库名; 表示如果库不存在再创建&#xff09; 例&#xff1a;create database if not exists ecology; 3、删除库 …

Linux安全加固

账号和权限 系统用户 超级管理员&#xff1a;UID0 系统默认用户&#xff1a;系统程序使用&#xff0c;从不登录 新增普通用户&#xff1a;UID大于500 用户管理 添加用户&#xff1a;useradd <用户名> 删除用户&#xff1a;userdel [-r] [-f] <用户名> 锁定/解…

electron 打包生成的latest.yml文件名字变成xxx.yml文件名

正常情况是electron每次打包会生成一个latest.yml文件和一个xxx.exe文件&#xff0c;但是当version的名字修改成 这样 后面添加了-beta &#xff0c;然后生成的文件名字就变成了 beta.yml 更改方法&#xff1a; 在build配置底下添加 "detectUpdateChannel": false…

我的C++奇迹之旅:值和引用的本质效率与性能比较

文章目录 &#x1f4dd;引用&#x1f320;引用概念&#x1f309;引用特性 &#x1f320;使用场景&#x1f309;做参数&#xff08;传值与传地址&#xff09;&#x1f309;传值、传引用效率比较 &#x1f320;引用做返回值&#x1f309;引用和指针的区别 &#x1f320;常引用&am…

坚持刷题|分发饼干

文章目录 题目思路代码实现实现总结主要步骤时间复杂度 扩展问题 Hello&#xff0c;大家好&#xff0c;我是阿月。坚持刷题&#xff0c;老年痴呆追不上我&#xff0c;今天刷第一个贪心算法&#xff1a;分发饼干 题目 455.分发饼干 思路 要解决这个问题&#xff0c;可以使用…

深度学习实战73-基于多模态CLIP模型的实战项目,CLIP模型的架构介绍与代码实现

大家好,我是微学AI,今天给大家介绍一下深度学习实战73-基于多模态CLIP模型的实战项目,CLIP模型的架构介绍与代码实现。多模态CLIP(Contrastive Language-Image Pre-training)模型是一种深度学习模型,其核心设计理念是通过大规模的对比学习训练,实现图像与文本之间的跨模…

Linux——进程管理

目录 作业和进程的概念 程序与进程的关系 查看进程信息——ps&#xff0c;top ps命令 top命令 设置进程的优先级——nice&#xff0c;renice nice命令 renice命令 查看进程信息——pgrep&#xff0c;pstree pgrep命令 pstree命令 切换进程——jobs&#xff0c;bg&a…