sudo+vim+g++/gcc+makefile+进度条

目录

一、信任表中加入指定的普通用户(使其能使用sudo)

二、vim的使用

(一)基本概念

1. 正常/普通/命令模式(Normal mode) 

2. 插入模式(Insert mode)

3. 末行模式(last line mode)

(二)vim正常模式命令集

1. 移动光标

2. 翻页

3. 删除文字

4. 复制

5. 剪切

6. 大小写转换

7. 替换

8. 更改

9. 撤销

10. 注释

(三)vim末行模式命令集

1. 行号设置

2. 保存和退出

3. 分屏

4. 不退出vim执行

三、gcc/g++的使用

(一)预处理(进行宏替换)

(二)编译(生成汇编)

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

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

(五)动态库和静态库

1. 库的命名

2. 动态库和静态库

3. 动态链接和静态链接的优缺点

4. 安装c和c++静态库

5. 动态链接和静态链接分别生成的文件

四、自动化构建工具-make/Makefile

(一)依赖关系和依赖方法

(二)make原理

(三)项目清理

(四)make,makefile是具有依赖性的推导能力的

(五)一些小技巧

1. @符号

2. $(变量名)

(六)Makefile中一些常用变量的简写方式

五、文件或者目录的时间属性

六、实现进度条

(一)行缓冲区

(二)进度条


一、信任表中加入指定的普通用户(使其能使用sudo)

  • 允许普通用户以超级用户(或系统管理员)的身份执行命令
  • sudo ls 的意思是以超级用户的权限来执行 ls 命令,这样即使普通用户没有权限访问某些文件或目录,也可以列出它们的信息
vim /etc/sudoers//在root账号下打开信任表

二、vim的使用

(一)基本概念

  • vim最常用的三种模式:命令模式、插入模式、底行模式

1. 正常/普通/命令模式(Normal mode) 

  • 控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode

2. 插入模式(Insert mode)

  • 只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。该模式是我们后面用的最频繁的编辑模式。

3. 末行模式(last line mode)

  • 文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下,shift+: 即可进入该模式。要查看你的所有模式:打开vim,底行模式直接输入

 

(二)vim正常模式命令集

1. 移动光标

  • vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母「h」、「j」、「k」、「l」,分别控制光标左、下、上、右移一格
  • 按「G」:移动到文章的最后
  • 按「Shift+$ 」:移动到光标所在行的“行尾”
  • 按「Shift+^」:移动到光标所在行的“行首”
  • 按「w」:光标跳到下个字的开头
  • 按「e」:光标跳到下个字的字尾
  • 按「b」:光标回到上个字的开头
  • 按「#l」:光标移到该行的第#个位置,如:5l,56l
  • 按[gg]:进入到文本开始
  • 按「Shift+g」:移动到文本末尾
  • 按「n+Shift+g」:移动到第n行行首
  • 按「n+Shift+g」:移动到第n行行首

2. 翻页

  • 按[shift+g]:进入文本末端
  • 按「ctrl」+「b」:向上翻一页
  • 按「ctrl」+「f」:向下翻一页
  • 按「ctrl」+「u」:向上翻半页
  • 按「ctrl」+「d」:向下翻半页

3. 删除文字

  • 按「x」:删除光标所在位置的字符
  • 按「nx」:删除光标所在位置开始往后的n个字符
  • 按「X」:删除光标所在位置的前一个字符
  • 按「nX」:删除光标所在位置的前n个字符
  • 按「dd」:删除光标所在行
  • 按「ndd」:删除光标所在行开始往下的n行

4. 复制

  • 按「yy」:复制光标所在行到缓冲区
  • 按「nyy」:复制光标所在行开始往下的n行到缓冲区。
  • 按「yw」:将光标所在位置开始到字尾的字符复制到缓冲区
  • 按「nyw」:将光标所在位置开始往后的n个字复制到缓冲区

  • 按「p」:将已复制的内容在光标的下一行粘贴上
  • 按「np」:将已复制的内容在光标的下一行粘贴n次

5. 剪切

  • 按「dd」:剪切光标所在行
  • 按「ndd」:剪切光标所在行开始往下的n行
  • 按「p」:将已剪切的内容在光标的下一行粘贴上
  • 按「np」:将已剪切的内容在光标的下一行粘贴n次

6. 大小写转换

  • 按「Shift+~」:完成光标所在位置字符的大小写切换

7. 替换

  • 按「r」:替换光标所在位置的字符。

注意:先切换到命令模式,然后按r,然后再按任意字符即可替换成 字符

  • 按「R」:替换光标所到位置的字符,直到按下「Esc」键为止

8. 更改

  • 按「cw」:将光标所在位置开始到字尾的字符删除,并进入插入模式
  • 按「cnw」:将光标所在位置开始往后的n个字删除,并进入插入模式

 

9. 撤销

  • 按「u」:撤销。
  • 按「Ctrl+r」:撤销刚才的撤销

10. 注释

  • 批量化注释:
  • ctrl+v  --->j/k两个按键上下选中区域---> shift+i(I)---> // --->Esc
  • 批量化删除注释:
  • ctrl+v ---> hjkl选中区域 --->d即可

(三)vim末行模式命令集

1. 行号设置

  • 「set nu」:列出行号
  • 「set nonu」:取消行号

2. 保存和退出

  • 「w」:保存文件。
  • 「q」:退出vim
  • 「wq」:保存退出
  • 「wq!」:强制保存并退出

3. 分屏

  • 「vs 文件名」:实现多文件的编辑
  • 「Ctrl+ww」:光标在多屏幕下进行切换

4. 不退出vim执行

「!+指令」:在不退出vim的情况下,执行Linux的指令

三、gcc/g++的使用

  • c++中对应的文件后缀有cpp,cc和cxx

(一)预处理(进行宏替换)

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

 

(二)编译(生成汇编)

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

  • 编译过程为 扫描程序-->语法分析-->语义分析-->源代码优化-->代码生成器-->目标代码优化
  1. 扫描程序进行词法分析,从左向右,从上往下扫描源程序字符,识别出各个单词,确定单词类型
  2. 语法分析是根据语法规则,将输入的语句构建出分析树,或者语法树,也就是我们答案中提到的分析树parse tree或者语法树syntax tree
  3. 语义分析是根据上下文分析函数返回值类型是否对应这种语义检测,可以理解语法分析就是描述一个句子主宾谓是否符合规则,而语义用于检测句子的意思是否是正确的
  4. 目标代码生成指的是,把中间代码变换成为特定机器上的低级语言代码。
gcc -S test1.i -o test1.s

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

  • 汇编阶段是把编译阶段生成的“.s”文件转成目标文件
  • 在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码
  • 此时的test1.o虽然的二进制文件但是不能执行
gcc -c test1.s -o test1.o

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

gcc test1.o -o mybin//将目标文件 test1.o 链接成一个可执行文件,并将可执行文件命名为mybin

(五)动态库和静态库

1. 库的命名

2. 动态库和静态库

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

3. 动态链接和静态链接的优缺点

动态链接:
 优点:形成的可执行程序提交比较小,比较节省资源
 缺点:稍慢一些,依赖动态库,程序可移植性较差
静态链接:
 优点:无视库,可以独立运行
 缺点:体积太大,浪费资源

4. 安装c和c++静态库

sudo yum install glibc-static//c静态库
 sudo yum install -y libstdc++-static//c++静态库

5. 动态链接和静态链接分别生成的文件

gcc test1.c -o test1_move//默认动态链接生成
gcc test1.c -o test1_quiet -static//静态链接生成

四、自动化构建工具-make/Makefile

  • make:是一个命令
  • makefile:是一个在当前目录下存在的一个具有特定格式的文本文件  

(一)依赖关系和依赖方法

 依赖关系:

  • 上面的文件 mybin ,它依赖 test1.o
  • test1.o , 它依赖 test1.s
  • test1.s , 它依赖 test1.i
  • test1.i , 它依赖 test1.c

(二)make原理

  1. make会在当前目录下找名字叫“Makefile”或“makefile”的文件。
  2. 如果找到,它会找文件中的第一个目标文件,在下面的例子中,他会找到mybin这个文件,并把这个文件作为最终的目标文件。
  3. 如果mybin文件不存在,或是mybin所依赖的后面的test1.o文件的文件修改时间要比mybin这个文件新,那么,他就会执行后面所定义的命令来生成mybin这个文件。
  4. 如果mybin所依赖的test1.o文件不存在,那么make会在当前文件中找目标为test1.o文件的依赖性,如果找到则再根据那一个规则生成test1.o文件。(这有点像一个堆栈的过程)
  5. 当然,test1.c是存在的,于是make会生成test1.o文件,然后再用test1.o文件声明make的终极任务,也就是执行文件mybin了。
  6. 这就是整个make的依赖性,make会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
  7. 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么make就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make根本不理。

(三)项目清理

(四)make,makefile是具有依赖性的推导能力的

(五)一些小技巧

1. @符号

  • 用于抑制命令的输出,使得在执行该命令时不会在终端上显示具体的命令内容

2. $(变量名)

cc=gcc
src=test1.c
target=mybin$(target):$(src)$(cc) $(src) -o $(target)
.PHONY:clean
clean:rm -f $(target)

(六)Makefile中一些常用变量的简写方式

  • $@:表示目标文件(冒号左侧的文件名)
  • $^:表示所有的依赖文件列表(冒号右侧的文件列表)
  • $<:表示依赖关系中的第一个依赖文件

 

五、文件或者目录的时间属性

  • Access Time (atime):指的是文件或目录最后一次被访问的时间。例如,当你打开一个文件或者读取它时,它的访问时间就会被更新。
  • Modify Time (mtime):指的是文件或目录的内容最后一次被修改的时间。当你编辑或者写入文件时,它的修改时间就会被更新。
  • Change Time (ctime):指的是文件或目录的状态最后一次被修改的时间。这包括文件或目录的内容、权限、所有者等信息的变更。
stat mybin//获取关于文件或目录的详细信息,包括访问时间、修改时间、状态改变时间等

 

六、实现进度条

(一)行缓冲区

  • 行缓冲(line buffering)是一种I/O缓冲策略,这意味着在遇到换行符(\n)或者缓冲区满之前,输出的文本都会被暂时存储在缓冲区中,而不会立即显示在屏幕上
  • 没有换行

 

  • 利用fflush

 

(二)进度条

\r:是回车

\n:是换行 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ts 泛型基础介绍

泛型&#xff1a;指的是&#xff0c;在定义函数/接口/类型...时&#xff0c;不预先指定具体的类型&#xff0c;而是在使用的时候再指定类型限制的一种特性 当我们定义一个变量&#xff0c;但不确定其类型的时候&#xff0c;有两种解决方式&#xff1a; 方式1&#xff1a;使用a…

2、ARM处理器概论

一、ARM处理器概述 1、ARM的含义 ARM&#xff08;Advanced RISC Machines&#xff09;有三种含义&#xff0c;一个公司的名称、一类处理器的通称、一种技术 ARM公司&#xff1a; 成立于1990年11月&#xff0c;前身为Acorn计算机公司主要设计ARM系列RISC处理器内核授权ARM内…

调整参数提高mysql读写速度

要提升MySQL的写入速度,您可以采取一些参数调整和优化措施,这些措施可以根据您的具体应用和环境进行调整。以下是一些常见的参数和优化建议: InnoDB存储引擎: 如果您使用的是InnoDB存储引擎,确保以下参数被设置得合理: innodb_buffer_pool_size:增加内存池大小,以便更多…

idea设置项目启动的JVM运行内存大小

idea设置项目启动的JVM运行内存大小 场景 在开发当中&#xff0c;idea默认服务启动要占用1G内存。其实每个项目本地开发和调试的时候&#xff0c;根本不需要1G内存&#xff0c;200M左右足以 如果在微服务体系下&#xff0c;那效果更明显&#xff0c;相同的内存可以启动更多的…

一代人有一代人的使命

一、前言 今天是9.18,对于全体中国人民来说是一个不应该被遗忘的日子,1931年9月18日,日本发动了9.18事变。 前辈们后来经过了艰苦卓绝的抵抗,经过12年的抗战,最后才取的抗日战争的胜利,可以说,今天的日子来之不易。 博主想说的是一代人有一代人的使命。100年前,先辈们…

人脸修复祛马赛克算法CodeFormer——C++与Python模型部署

一、人脸修复算法 1.算法简介 CodeFormer是一种基于AI技术深度学习的人脸复原模型&#xff0c;由南洋理工大学和商汤科技联合研究中心联合开发&#xff0c;它能够接收模糊或马赛克图像作为输入&#xff0c;并生成更清晰的原始图像。算法源码地址&#xff1a;https://github.c…

Java增强for循环(学习笔记)

Java增强for循环 主要用于数组或者集合的增强型for循环。 格式&#xff1a; for(声明语句&#xff1a;表达式){ 代码句子 } 声明语句&#xff1a;声明新的局部变量&#xff0c;该变量的类型必须和数组元素的类型匹配。其作用域限定在循环语句块&#xff0c;其值与此时数组元…

java使用selenium自动化WebDriver等待

显式等待和隐式等待是WebDriver中两种常用的等待方式&#xff0c;它们都可以用来等待特定的条件满足后再继续执行代码。 显式等待&#xff08;Explicit Wait&#xff09;&#xff1a;使用WebDriverWait类来实现&#xff0c;可以根据特定条件等待元素出现、可见、可点击等。 示例…

使用Node构建私人代理池

在进行大规模数据采集时&#xff0c;经常会遇到网站反爬虫机制导致爬虫被封的问题。为了解决这个困扰&#xff0c;本文将向大家介绍如何利用Node.js构建私人代理池&#xff0c;提供稳定的代理&#xff0c;实现高效、可靠的爬虫操作。跟随本文一起学习&#xff0c;拥有解封爬虫的…

sentry安装self-hosted版,前端监控平台

一、下载self-hosted-23.7.2.tar.gz 二、解压 三、cd self-hosted-23.7.2然后执行./install.sh 四、查找python whereis python修改yum配置文件&#xff1a;vim /usr/bin/yum五、修改RUN apt-get update && apt-get install -y --no-install-recommends cron &…

9月15日上课内容 Zookeeper集群 + Kafka集群

Zookeeper 本章结构 Zookeeper 概述 Zookeeper 定义 *&#xff08;了解&#xff09; Zookeeper是一个开源的分布式的&#xff0c;为分布式框架提供协调服务的Apache项目。 Zookeeper 工作机制 *****&#xff08;非常重要&#xff0c;需要掌握&#xff09; Zookeeper从设计模式…

检索技术核心学习总结

一、学习检索技术的必要性分析 &#xff08;一&#xff09;关键原因分析 学习检索技术&#xff08;Information Retrieval&#xff0c;IR&#xff09;具有多种重要的原因&#xff0c;特别是在今天信息爆炸的数字化时代。 总的来说&#xff0c;学习检索技术有助于提高信息处理…

x86平台运行arm64平台docker 镜像

本文介绍在x86服务器上安装qemu-aarch64-statick仿真器&#xff0c;以实现x86服务器可以运行docker或docker-compose镜像。 报错信息&#xff1a; x86服务器默认不能运行ARM平台镜像&#xff0c;会提示如下错误&#xff1a; WARNING: The requested images platform (linux/ar…

1400*C. No Prime Differences(找规律数学)

解析&#xff1a; 由于 1 不是质数&#xff0c;所以我们令每一行的数都相差 1 对于行间&#xff0c;分为 n、m之中有存在偶数和都为奇数两种情况。 如果n、m存在偶数&#xff0c;假设m为偶数。 如果都为奇数&#xff0c;则&#xff1a; #include<bits/stdc.h> using name…

(压缩PDF)Adobe Acrobat DC

需求 压缩PDF大小到2MB以下 方法 工具&#xff1a;Adobe Acrobat DC 1、简单方法&#xff1a;压缩 PDF&#xff0c;缩小 PDF 大小&#xff0c;使用 Adobe Acrobat DC 压缩 PDF。 - 卖五金的小贩的文章 - 知乎 意外的好用&#xff0c;不会压缩到太狠&#xff08;选了兼容Ac…

【Qt】QGroundControl入门2:下载、编译、错误处理、运行

1、源码下载 git clone https://github.com/mavlink/qgroundcontrol.git 2、下载依赖库 2.1 查看依赖库的github路径 cat .gitmodules[submodule "src/GPS/Drivers"]path = src/GPS/Driversurl = https://github.com/PX4/GpsDrivers.git [submodule "libs/m…

Google Guava精讲(一)-Guava是什么?能做什么?

https://mvnrepository.com/artifact/com.google.guava/guava 作为Java栈的测试工程师&#xff0c;在写代码时候会频繁遇到字符串处理、缓存、反射等问题&#xff0c;我们最常规的做法就是&#xff0c;为了使原生的JDK方法好用&#xff0c;通常是做了一层又一层封装&#xff0…

RK3588修改eth0和eth1,对调这两个网卡设备的名称

1、以太网卡的名称一般是ethX&#xff08;X可以是0&#xff0c;1&#xff0c;2&#xff0c;3…&#xff09;&#xff0c;一般我们的设备只有一个网卡&#xff0c;并且一般也不会改变它的网卡名称&#xff0c;所以不需要关注此问题&#xff0c;但是有一些设备有两三个网卡&#…

new/delete, malloc/free 内存泄漏如何检测

区别&#xff1a; 首先new/delete是运算符&#xff0c;malloc/free是库函数。malloc/free只开辟内存不初始化&#xff1b;new/delete及开辟内存也初始化。抛出异常的方式&#xff1a;new/delete开辟失败使用抛出bad_alloc&#xff1b;malloc/free通过返回值判断。malloc和new区…

el-table 翻页记住上页选项,包含回显选中的数据

需求为翻页记住上页选项,包含回显选中的数据,然后还能进行新增和取消勾选 首先element管网有提供及住翻页功能 所以可以根据官网提供的方法来改造 一定要做的操作就是清空一下选中的数据,否则不生效,this.$refs.selectTable.clearSelection(); 然后就是处理选中的数据,和原…