Linux学习第二枪(yum,vim,g++/gcc,makefile的使用)

前言:在我的上一篇Linux博客我已经讲了基础指令和权限,现在我们来学习如何在Linux上运行和执行代码

目录

一,yum

二,vim

1)命令行模式

2)插入模式

3)底行模式

三,gcc/g++

四,makefile


一,yum

yum是Linux中的软件包管理器,软件包是有人一些人写好的代码和程序作出软件包放到服务器上,我们使用yum就能获取别人编译好的软件,相当于手机里面的应用商店,我们可以用这个去下载东西。

那我们怎么去去下载呢?

yum  install -y  lrzsz
##  install 代表安装   -y  代表自动安装   lrzsz是一个软件安装包

重要的软件包:lrzsz

这个软件包支持我们将Linux和window里面的文件进行互传,rz   支持我们通过拖拽的方式将window里面的文件传到Linux里面,sz   +文件  可以将Linux里面的文件传输到window里面

rz
#可以通过window图形化界面文件的方式传输,支持拖拽
sz  /home/test.c
#以为Linux一切皆文件,所以我们无法通过拖拽传输,必需加上路径

以后如果我们发现有无法发现此指令的错误提示,我们可以百度搜索出该指令的软件包,然后使用yum安装

二,vim

vim是Linux中打开文件的指令,在Linux中一切皆文件,我们无法不通过指令就直接进入文件的内部,而   vim  就是一个打开文件的指令

使用方法

vim  /root/test.c
#vim   文件路径

打开之后会是一个这样的样子,我们无法立马改动,只能查看,三大模式中的命令行模式

1)命令行模式

在这个模式下我们只能查看,但无法改动文件里面的内容,但这个模式是我们想要切换到其他模式的中介,也就是说,想要切换到其他模式我们首先要切换到这个模式

2)插入模式

插入模式顾名思义,就是能够进行编辑的模式,在这个模式下,有很多有用的快捷键助我们编辑

H:光标向左边移动一格

L:光标向右移动一格

J:光标向下移动一格

K:光标向上移动一格

之所以有上面几个快捷键是因为以前没有上下左右键,这个是当年老式键盘的上下左右

shift+G:直接到文本的末尾,想象一下如果文本有上万行,一行一行移动要多久,这个有多爽

数字+shift+G:移动到指定行

GG:回到文本的开头

shift+4:移动到当前行的末尾

shift+6:移动到当前行的首部

x:删除光标所在的字符

数字+x:删除光标后指定数目个字符

X:删除光标前的一个字符

数字+X:删除光标前的指定个字符

dd:删除当前行

数字+dd:删除光标后的指定行数

yw:复制光标所在位置的字符

数字+yw:复制光标后的指定数目字符

yy:复制当前行

数字+yy:复制光标及光标后的指定数目行

p:将复制的字符贴到光标所在位置

u:撤销上一步的操作

ctrl+r:恢复撤销的动作

3)底行模式

进入指令:shift+:

进入之后光标会移动到最下面那一行

这个时候我们就可以输入指令了

set  nu  :这个指令可以标注文件的行数

数字:直接移动到指定的行

?字符:即可查找指定的字符,但是是从当前行开始查找,如果有多个匹配目标,按n可查看下一个匹配目标

/  字符:也查找字符,但是是从文件第一行开始查找,如果有多个匹配目标,按n可查看下一个匹配目标

w:保存本次编辑

q:退出

补充:vim模式可以添加很多插件,向自动补充括号,高亮光标和所在行,这些插件大家可以百度搜索vim的配置,用起来很方便,助力敲代码!!!

wq!:强转保存退出,!代表强转,其他的指令也可使用

三,gcc/g++

gcc一般用于编译C代码

g++一般用于编译C++代码

使用方法

gcc -o test.o  test.c
#test.c是编译的目标文件,test.o是形成的可执行文件
./test.o
#这样就可以执行代码

接下来是一些你可能用到的操作

-E 只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面

-S  编译到汇编语言不进行汇编和链接

-c  编译到目标代码 -

o 文件输出到 文件 -static 此选项对生成的文件采用静态链接

-g 生成调试信息。GNU 调试器可利用该信息。

-shared 此选项将尽量使用动态库,所以生成文件比较小,但是需要系统由动态库.

-O0 -O1 -O2 -O3 编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最高

-w  不生成任何警告信息。 -Wall 生成所有警告信息

四,makefile

首先你想象一个场景,你需要多次编译很多的源代码,如果你手动的一个个编译,我们会累成狗一样,因此Linux给我们提供了一种方法,将我们要做的操作放在里面,我们只要输出一个指令,系统就重复里面的操作,我们就可以节省很多时间,没错那就是makefile

如何用呢?

首先我们要创建一个名字叫makefile的文件,Linux对大小写不敏感,我们可以自便。然后我们使用vim打开makefile,我们现在开始讲

test.o:test.c
#目标文件:原文件2     gcc -o test.o test.c
#具体操作,目标文件可以用@代替,原文件可以用^代替3     .PHONY:clean
#被.PHONY修饰的称为伪目标,伪目标总是默认被执行4 clean:       
#使用make clean指令可以清理形成的文件和清理工作,因为生成的文件如果没有改变是无法再次形成的                                                                                                                                                 5     rm -rf test.o

在使用make的时候我们要注意,make编译一次之后如果文件内容没有发生改变是需要clean一次也就是删除掉形成的可执行文件才能继续make,因为系统无法同时存在两个一样的文件,这里就引出了一个问题,系统是怎么判断文件有没有发生改变的呢?这是因为文件有三个时间属性,modify,access,change。

modify:是最近文件内容修改的时间

change:代表最近文件属性修改的时间,一般来说文件内容改变,文件属性就会改变

access:代表文件最近访问的时间

每次改动文件都可能会改变文件的这些属性,make通过比较时间来确定文件是不是被改动了,当然如果只是访问了文件,make是不会重新编译文件的。

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

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

相关文章

MATLAB的编程与应用,匿名函数、嵌套函数、蒙特卡洛法的掌握与使用

目录 1.匿名函数 1.1.匿名函数的定义与分类 1.2.匿名函数在积分和优化中应用 2.嵌套函数 2.1.嵌套函数的定义与分类 2.2.嵌套函数彼此调用关系 2.3.嵌套函数在积分和微分中应用 3.微分和积分 4.蒙特卡洛法 4.1.圆周率的模拟 4.2.计算N重积分(均匀分布&am…

PHP·解决http_build_query模拟浏览器请求多选参数加下标索引的BUG| 无法模拟浏览器多选参数问题

$form_params array(id > 1,ids > [1,2,3], ); $form_params http_build_query($form_params); $form_params preg_replace(/%5B[0-9]%5D/simU, %5B%5D, $form_params);参考 http_build_query — 生成 URL-encode 之后的请求字符串

计算机提示找不到xinput1_3.dll怎么办?6个xinput1_3.dll丢失完美解决方案分享

xinput1_3.dll是Windows操作系统中的一个重要动态链接库文件,它负责处理游戏控制器和其他输入设备的相关功能。当计算机出现xinput1_3.dll缺失的问题时,可能会导致无法正常使用游戏控制器或其他输入设备。下面是针对这个问题的6个解决方法: 方…

基于html+jquery开发的科学计算器(课程作业)

基于html和jquery开发的科学计算器,该科学计算器可进行乘方、开方、指数、对数、三角函数、统计等方面的运算,又称函数计算器。 科学型带有所有普通的函数,所有的函数都分布在键盘上以致于你可以不用通过菜单列表来使用它们。 科学计算器支持…

微服务-我对Spring Clound的理解

官网:https://spring.io/projects/spring-cloud 官方说法:Spring Cloud 为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理、服务发现、熔断器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话…

常用布局以及其优缺点

当涉及到设计和排版时,有许多不同的布局方式可供选择。以下是几种常见的布局方式以及它们的优缺点: 流式布局(Fluid Layout): 优点:能够根据屏幕大小自动调整内容,适应不同设备。灵活性高&#…

android:scaleType属性

1. matrix : 不改变原图大小,在ImageView左上角开始显示,超出部分剪裁。 2. center : 不改变原图大小,在ImageView中央显示,超出部分剪裁。 3. centerCrop(剪裁) : 原图按等比例缩放,直至填满整个ImageView&#xff…

分布式搜索引擎ES

文章目录 初识elasticsearch了解ES倒排索引正向索引倒排索引正向和倒排 es的一些概念文档和字段索引和映射mysql与elasticsearch 安装ES部署kibana安装IK分词器扩展词词典停用词词典 索引库操作mapping映射属性索引库的CRUD创建索引库和映射查询索引库修改索引库删除索引库 文档…

微机原理5

一、单项选择题(本大题共15小题,每小题3分,共45分。在每小题给出的四个备选项中,选出一个正确的答案。) 下列数中最小的数是() A. (10111) B. (30) C. (100010) BCD D. 17H 2,下面四个寄存器中,不能作为间接寻址的寄存器是() A. BX B. DX C.…

ChatGPT 如何改变科研之路

《Nature》全球博士后调查[1]中约有三分之一的受访者正在使用人工智能聊天机器人来帮助完善文本、生成或编辑代码、整理其领域的文献等等。 来自巴西的 Rafael Bretas 在日本生活了十多年,日语说得很好。书面日语的各个方面,例如严格的礼貌等级制度&…

【Linux基础IO篇】用户缓冲区、文件系统、以及软硬链接

【Linux基础IO篇】用户缓冲区、文件系统、以及软硬链接 目录 【Linux基础IO篇】用户缓冲区、文件系统、以及软硬链接深入理解用户缓冲区缓冲区刷新问题缓冲区存在的意义 File模拟实现C语言中文件标准库 文件系统认识磁盘对目录的理解 软硬链接软硬链接的删除文件的三个时间 作者…

2023.11.11 hive中的内外部表的区别

一.内部表操作 ------------------------------1内部---------------------------- --建库 create database hive2; --用库 use hive2; --删表 drop table t1; --建表 create table if not exists t1(id int,name string,gender string ); --复制内部表 --复制表结构:CREATE T…

计算机视觉中目标检测的数据预处理

本文涵盖了在解决计算机视觉中的目标检测问题时,对图像数据执行的预处理步骤。 首先,让我们从计算机视觉中为目标检测选择正确的数据开始。在选择计算机视觉中的目标检测最佳图像时,您需要选择那些在训练强大且准确的模型方面提供最大价值的图…

SpringCloud微服务:Eureka

目录 提供者与消费者 服务调用关系 eureka的作用 在Eureka架构中,微服务角色有两类 Eureka服务 提供者与消费者 服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)服务消费者:一次业务中,调用其它微服务的服务。(调…

C++:容器list的介绍及使用

目录 1.list的介绍及使用 1.1 list的介绍 1.2 list的使用 1.2.1 list的构造 1.2.2 list iterator 的使用 1.2.3 list capacity 容量 1.2.4 list element access 访问list元素 1.2.5 list modifiers 修改 1.2.6 迭代器失效 1.list的介绍及使用 1.1 list的介绍 C官网 …

基于ubuntu 22, jdk 8x64搭建图数据库环境 hugegraph--google镜像chatgpt

基于ubuntu 22, jdk 8x64搭建图数据库环境 hugegraph download 环境 uname -a #Linux whiltez 5.15.0-46-generic #49-Ubuntu SMP Thu Aug 4 18:03:25 UTC 2022 x86_64 x86_64 x86_64 GNU/Linuxwhich javac #/adoptopen-jdk8u332-b09/bin/javac which java #/adoptopen-jdk8u33…

acwing算法基础之搜索与图论--floyd算法

目录 1 基础知识2 模板3 工程化 1 基础知识 floyd算法的时间复杂度为O(n^3),它用来解决多源最短路问题。它的原理是基于动态规划。 floyd算法的关键步骤: k从1到n。i从1到n。j从1到n,d[i][j] min(d[i][j], d[i][k] d[k][j])。经过上述三…

2023年05月 Python(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

Python等级考试(1~6级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 下列程序段的运行结果是?( ) def s(n):if n==0:return 1else:

畅通工程之局部最小花费问题 (C++)

目录 题目&#xff1a; 思路&#xff1a; 代码&#xff1a; 结果 题目&#xff1a; 思路&#xff1a; 详细思路都在代码注释里 。 代码&#xff1a; #include<iostream>//无向图邻接矩阵 #include<map> #include<algorithm> #define mvnum 1005 using …

【多媒体技术与实践】学习路线

1&#xff1a;绪论&#xff08;多媒体技术概述&#xff09; ppt1&#xff1a;多媒体概述 &#xff08;chap1 overview of multimedia&#xff09; 2&#xff1a;多媒体计算机系统&#xff08;多媒体计算软件系统和硬件系统&#xff09; ppt1&#xff1a;多媒体个人计算机系统 …