linux基础指令2.0

目录

可视模式:

zip/unzip

tar

压缩文件传递

查询日志

bc计算器

ll

[r w x权限](#r w x权限)

权限管理

chmod (change mode"模式 权限")

chown (change owner)

chgrp (change group)

umask

gcc/g++的链接

Makefile

makefile/Makefile调用

Ⅰ.make

句前"@"

[\^与@与\<的含义](#^与@与<的含义)

Ⅱ.执行与清理


可视模式:

可视模式:默认模式下Ctrl+v

批量注释/取消注释

zip/unzip

zip 压缩文件名.zip 压缩目录/文件

-r 递归处理

解压:

unzip 解压文件名.zip -d [解压到的目标位置]

tar

tar czf 【压缩包名字】.tgz 【压缩目标】 #tar压缩

tar xzf 【压缩包名字】.tgz 无/【-C 【指定路径】】 #tar解压 默认解压到当前位置/解压到指定位置

显示压包/解包过程"cvzf/xvzf" 加以"v"

压缩文件传递

sz [压缩包] #Linux传递到Win

rz #选中Win下传递到Linux #也可以直接拖拽

查询日志

less /var/log/messages #支持上下键翻动查看 使用"/"查询日志中包含的信息

例如:使用 /remove

bc计算器

bc #进入计算器

ll

显示当前目录下文件与目录 及其详细内容

复制代码
d  rwx  rwx  r-x
│  └┬┘  └┬┘  └┬┘
│   │    │    └── 其他用户权限(读+执行)
│   │    └─────── 组权限(读+写+执行)
│   └──────────── 所有者权限(读+执行)
└──────────────── 文件类型(d=目录,-=文件)
字段 说明
文件类型和权限 drwxrwxr-x d=目录,后面9位是权限
硬链接数 4 该目录有4个子目录/链接
所有者 wzb 文件属于用户 wzb
所属组 wzb 文件属于组 wzb
大小 4096 目录大小 4KB(目录默认大小)
修改时间 May 4 21:21 最后修改时间
文件名 giths 目录名称

r w x权限

r:决定了能否查看内容

w:决定了能否修改(增删)内容。

x:决定能否运行脚本、可执行文件/进入目录。

冲突:

复制代码
# 有执行权限:可以进入目录
cd directory/      # ✅ 成功进入
ls -l directory/   # ✅ 可以访问目录内文件(需结合读权限)

# 无执行权限:无法进入目录
cd directory/      # ❌ bash: cd: directory: Permission denied
ls directory/      # ❌ 也无法访问(即使有读权限也不行)

权限管理

复制代码
-rw-rw-r-- 1 wzb jack  316 May  5 19:32 txt.c

R -> 递归修改⽬录文件的权限

chmod (change mode"模式 权限")

修改文件权限 root、文件所有者(wzb)

chmod [u/g/o]+/-[一个或多个权限] 文件名 #多个权限间无需加空格

u->拥有者

g->所属组

o->其他用户

也可以使用三位8进制数字 //较麻烦
chmod 764 txt.c #设置rwx rw- -w-权限

chown (change owner)

修改文件的拥有者
chown user1 f1
chown -R user1 filegroup1

chgrp (change group)

修改文件/目录的所属组

chgrp [-R/无] 用户组名 文件名
chgrp nwgrp /abc/f2

umask

查看/修改文件掩码


实际创建出的文件的权限值 = 新建文件默认权限(不是创建出来后的权限) & ~umask值(图示0002)
超级⽤⼾默认掩码值为0022,普通⽤⼾默认为0002。

gcc/g++的链接

.i 预处理-E形成的临时文件

.s 编译-S形成的汇编文件 //我们可读

.o 汇编-c形成的目标文件 //二进制机器语言
"链接"选项-o输出可执行文件:
gcc f1.c f2.i f3.s f4.o ...... -o program #链接生成可执行文件

Makefile

简介:简洁批量处理所拥有文件,是一个自动化编译配置文件,告诉make命令如何编译与链接。

1.变量定义

x=y #意味着定义变量x,代表y例如:

CC = gcc #"CC"就代表gcc编译器

1.1变量的使用

|-------------|-----------------------|--------------|
| $(TARGET) | 引用变量,获取变量的值 | 替换为 hello |
| TARGET | ++普通文本++,就是这个单词本身 | 保持为 TARGET |

$(x)就代表获取变量的值y

$(CC) #替换为gcc 用于"依赖"关系的确认

1.2为什么使用"定义变量"?

就像你在写代码时的定义变量一样,便于统一更改与替换。

2."依赖"的理解

2.1"依赖"的解释

"依赖"指一个对象依赖于另一个对象产生,依赖发生时不一定要求另一个对象已经存在。

已经存在:直接根据代码实现目的。

不存在:先将此依赖关系存入"特殊空间",再向下执行。

特殊空间,完全类似于"数据结构"中的**"栈"形结构**,先入后出。等到栈顶可执行直接出栈。

2.2"依赖"的语法逻辑

目标:依赖对象(可什么都不写 像clean:也可仅指定一个/多个(以空格隔开) )

形成"目标"的原则

css 复制代码
# 这是一个简单的 Makefile 示例
CC = gcc
CFLAGS = -Wall -g
TARGET = hello
SOURCES = main.c
OBJECTS = main.o

all: $(TARGET) //all仅仅是一个名字无其他含义,此句表示all依赖TARGET

$(TARGET): $(OBJECTS)
	$(CC) $(OBJECTS) -o $(TARGET)

%.o: %.c
	$(CC) $(CFLAGS) -c $< -o $@ //$@与$<稍后解释 

clean:
	rm -f $(OBJECTS) $(TARGET)

3.".PHONY"的理解

css 复制代码
.PHONY: all clean

前言:phony/phoney .adj /ˈfoʊni/("佛尼")假的,虚伪的 ;

性质:解决外部使用makefile的指令冲突

设计目的:解决外部"make"或"make clean"时,出现"文件名为all 、clean"而导致无法正常make 、clean的问题。

所以我们在设计makefile时在最后常加.PHONY来消弭冲突问题。

为什么外部使用"make"就会找到文件makefile去调用内部的指令?

make 命令被设计为自动查找 名为 makefileMakefile 的文件,这是它的内置默认行为,不需要你额外指定。

makefile/Makefile调用

css 复制代码
  1 BIN=proc.exe #最终形成的可执行文件名
  2 CC=gcc
  3 #SRC=$(shell ls *.c) #以shell命令列出所有.c文件
  4 SRC=$(wildcard *.c)#自动匹配当前目录下所有.c文件
  5 OBJ=$(SRC:.c=.o) #将所有.c后缀改为.o后缀
  6 LFLAGS=-o
  7 FLAGS=-c
  8 RM=rm -f
  9 
 10 $(BIN):$(OBJ)
 11     @$(CC) $^ $(LFLAGS) $@  #这啥呀?
 12     @echo "compling ...... $< to $@" #编译                                                                      
 13 .PHONY: clean
 14 clean:
 15     $(RM) $(OBJ) $(BIN)
 16 .PHONY:test
 17 test:
 18     @echo $(SRC) #输出当前识别到的所有.c文件
 19     @echo $(OBJ) #输出所有.o文件
//   make 编译全部  make test 调试查看  ./proc.exe运行程序  make clean 清理
Ⅰ.make

特定定义:

句前"@"

@(CC) ^ (LFLAGS) @ 需要加@

(RM) (OBJ) $(BIN) 为什么这个语句不需要加@?

@ 是可选的 ,加不加取决于你是否想让用户看到这条命令

  • @:静默执行,不显示命令本身

  • 不加 @:显示命令,然后再执行

\^与@与$<的含义

$@是proc.exe的原因:

$^是当前规则的依赖列表

$<是当前依赖规则的第一个

css 复制代码
%.o: %.c

当前规则的目标 = "proc.exe"
当前规则的依赖列表 = ["txt.o", ......]

$@ = 当前规则的目标       // "$@" = "proc.exe"
$^ = 当前规则的依赖列表   // "$^" = ""txt.o", ......"
$< = 依赖列表的第一个     // "$<" = "txt.o"
Ⅱ.执行与清理

新增gdb

相关推荐
代码中介商1 小时前
Linux TCP/UDP 网络编程完全指南:从基础到实践
linux·网络·tcp/ip
嵌入式×边缘AI:打怪升级日志1 小时前
嵌入式 Linux V4L2 摄像头采集编程(五):MMAP + 亮度实时控制(附完整代码与面试题)
linux·运维·服务器
2301_789015622 小时前
Linux基础指令(一)
linux·运维·服务器·c语言·开发语言·c++·linux指令
晚风予卿云月2 小时前
【linux】进程优先级
linux·运维·服务器
一拳一个娘娘腔2 小时前
从sudo配置到Root Shell:Linux Sudo提权全景深度解析与防御指南
linux·网络·安全
万法若空3 小时前
Cortex-A7的运行模式
linux·arm开发
YJlio3 小时前
用女娲蒸馏 Mark Russinovich 排障思维:打造 Windows 桌面运维专家 Skill
运维·windows·飞书·ai办公·多维表格·飞书v7.63·飞书问卷
yyuuuzz3 小时前
aws注册过程中的常见问题梳理
运维·服务器·网络·云计算·github·aws
德迅云安全-小潘3 小时前
手游架设全攻略:服务器选型、配置与部署一站式指南
运维·服务器