赞
踩
/bin | 存储一些二进制可执行命令文件 |
/boot | 存放系统启动时要用到的程序 |
/dev | 包含Linux系统中使用的外部设备 |
/etc | 存放了系统管理时要用到的各种配置文件和子目录 |
/lib | 存放系统动态连接共享库 |
/home | 普通用户主目录 |
/root | 根用户(超级用户)的主目录 |
命令 | 含义 |
---|---|
ls | 查看当前目录下的所有目录和文件(不包括隐含文件) |
ls -a | 查看当前目录下的所有目录和文件(包括隐藏的文件) |
ls -l | 列出当前目录下文件的详细信息(不包括隐含文件) |
ls -R | 递归显示当前目录中的所有文件和子目录 |
cd | 切换文件夹路径 |
cat | 查看文件内容 |
cat -s | 多个空行合并成一个空行显示 |
cat -b | 加行号显示 |
head -n | 显示前n行,默认10行 |
tail -n | 显示后n行,默认10行 |
cp | 复制文件或者目录。如果第二个参数不是路径,则cp是备份的意思(例如:cp test1.c test2.c,表示将test1.c复制一份并改名为test2.c)。如果第二个参数是路径,则cp表示将文件或目录复制到路径意思(例如:cp test.c ../) |
mv | 移动文件或者目录/文件或者目录重命名。如果第二个参数不是路径,则mv是重命名的意思(例如:mv test1.c test2.c,表示将test1.c的文件重命名为test2.c)。如果第二个参数是路径,则mv表示将文件或目录移动到路径意思(例如:mv test.c ../) |
pwd | 显示当前位置路径 |
touch | 创建文件。如果有这个文件,则更改时间戳 |
mkdir | 创建文件夹 |
mkdir -p | 创建多级文件夹 |
rm | 无提示的删除当前目录下的文件 |
rm -i | 有提示的删除当前目录下的文件 |
rm -r | 删除文件夹 |
1)vi模式切换命令
命令 | 含义 |
---|---|
a | 当前光标位置之后插入输入的字符 |
i | 当前光标位置开始插入输入的字符 |
o | 光标下一行插入输入的字符 |
A | 将光标移动到当前行的最后面 |
I | 将光标移动到当前行的最前面 |
O | 光标上一行插入输入的字符 |
:! | 在vi当中执行命令 |
2)vi复制、粘贴与剪切命令
命令 | 含义 |
---|---|
[n]dd | 删除有光标位置的行,可以连续删除多行(例如:2d。表示从光标开始连续删除2行) |
[n]yy | 复制有光标位置的行,可以连续复制多行(例如:2yy。表示从光标开始连续复制2行) |
p或P | 当前光标位置之后插入输入的字符(p:从光标下一行粘贴;P:从光标上一行粘贴) |
y0 | 将光标到行首的字符串复制 |
y$ | 将光标到行尾的字符串复制 |
d0 | 将光标到行首的字符串剪切 |
d$ | 将光标到行尾的字符串剪切 |
:1,10y | 将1到10行内容复制 |
:1,10d | 将1到10行内容剪切 |
u | 撤销上次操作 |
3)vi保存和退出命令
命令 | 含义 |
---|---|
:q | 退出没有修改的文件,若文件被修改了而没有保存,则此命令无效 |
:q! | 强制退出,且不保存修改过的部分 |
:w | 保存文件,但不退出 |
:x | 保存文件并退出 |
:w File | 另存为File给出的文件名,不退出 |
:r File | 读入File指定的文件内容到光标下一行 |
4)光标命令
命令 | 含义 |
---|---|
h | 方向键,向左移动光标一个字符的位置,相当于键"←" |
j | 方向键,向下移动光标到下一行的位置,相当于键"↓" |
k | 方向键,向上移动光标到上一行的位置,相当于键"↑" |
l | 方向键,向右移动光标一个字符的位置,相当于键"→" |
:N | 移动光标到第N行 |
1G | 移动光标到文件的第一行 |
G | 移动光标到文件的最后一行 |
:set nu | 加行号 |
:set nonu | 不加行号 |
5)vi查找命令
命令 | 含义 |
---|---|
/string | 查找字符串。按n继续查找,按N反向继续查找 |
6)vi替换命令
命令 | 含义 |
---|---|
:s/str1/str2 | 实现字符串替换,只替换与之匹配的第一个字符串 |
:s/str1/str2/g | 实现当前行全文替换,g为全文替换的意思 |
:.,$s/str1/str2/g | 实现当前行到最后的全文替换 |
:1,10s/str1/str2/g | 实现第一行到第10行全文替换 |
:%s/str1/str2/g | 实现全文字符串替换 |
GCC编译过程
linux操作系统的组件
1.linux内核:
提供了系统的核心功能并且允许进程以有序的顺序访问硬件;
管理进程、输入、输出设备、文件系统和内存管理;
支持 "多用户 、 多任务";
2.shell(命令行解释器):
用于用户和操作系统交互
类型:bash
3.文件系统
4.实用程序:
图形界面:浏览器 office...
命令行应用程序:ls gcc gdb
1.两种软件包管理机制
Deb包:
Rpm包:主要用于RedHat
2.软件包管理工具
apt:
能够检查和修复软件包依赖;
能够通过网络直接获取软件包;
dpkg:
不能检查依赖
也不能在线通过网络获取软件包
3.ubuntu的软件包
二进制的deb包
源码包:.dsc
4.apt工作原理
1)软件源
vi /etc/apt/sources.list //得到软件源地址 但不知道软件源中有哪些软件
2)索引文件(sudo apt-get update)
/var/lib/apt/lists
3)下载的软件包文件位置(/var/cache/apt/archives)
5 .apt命令
apt-get update //更新软件包索引列表
apt-get install xchat //下载安装软件包(自动检查索引并下载安装)
apt-get remove --purge 软件包 //完全卸载软件包
dpkg工具使用
sudo dpkg -i xchat_2.8.8-20_amd64.deb //安装软件
sudo dpkg -L xchat //列出安装的软件包清单
sudo dpkg -P xchat //完全卸载软件
1.shell
命令行解释器
bash:
2.关机/重启命令
sudo shutdown -h now //马上关机
sudo shutdown -r now //马上重启
3.shell命令提示符
hqyj@ubuntu:~/230701$
hqyj:用户名
ubuntu:主机名
~:用户的工作目录
$:一普通用户执行命令
4.shell命令的组成
命令名称 [options] [arguments]
eg:
ls
ls -l
la -l -a ./
5.shell命令
history
语法:
history [行号]
eg:
hsitory 10 //显示最新10行历史命令
HISTSIZE:环境变量 记录命令历史记录的容量
HISTSIZE=2000 //赋值
echo $HISTSIZE //打印变量的值
6.通配符
功能:批量操作文件
1)* 匹配任意长度的字符串
eg:
touch file1.txt file2.txt file3.txt
rm *.txt //将所有.txt文件删除
2)? 只匹配一个长度的字符
eg:
touch file_1.txt file_2.txt file_3.txt file_11.txt
rm file_?.txt //删除file_1.txt file_2.txt file_3.txt
3)[...] 匹配指定的一个字符
eg:
touch file1.txt file2.txt file3.txt file4.txt
rm file[124].txt //删除 file1.txt file2.txt file4.txt
4)[-] 匹配指定范围内的一个字符
eg:
touch file1.txt file2.txt file3.txt file4.txt file5.txt
rm file[1-4].txt //将file1.txt file2.txt file3.txt file4.txt 删除
5)[^...] 除了指定的字符,其他均可匹配
eg:
touch file1.txt file2.txt file3.txt file4.txt file5.txt
rm file[^12].txt //删除file3.txt file4.txt file5.txt
1.通配符
2.管道(|)
功能:
将第一个命令的结果作为第二个命令的输入,一次类推
语法:
cmd1 | cmd2 | cmd3 ....
eg:
pwd | ls //pwd的结果作为ls的输出
ls ./ | wc -w //统计 ls . 结果中的单词数
ps aux | grep a.out //从ps aux的结果中搜索a.out字符串
./a.out & //让程序在后台运行
3.输入/输出重定向
输入/输出重定向是改变Shell命令或程序默认的标准输入/输出目标,重新定向到新的目标。
>file 输出重定向,即将本来的标准输出输出到终端,重定向之后输出到file文件 file不存在则创建,存在则会清空 eg: ls > 1.txt ls的结果重定向到1.txt文件
>>file 输出重定向追加模式,即文件内容不会被清空,将新内容追加到源文件内容之后 eg: pwd >> 1.txt pwd的结果追加到1.txt原内容之后
<file 输入重定向,改变了输入的默认目标为file eg: wc -w < 1.txt //wc -w默认读标准输入,重定向之后输入目标为1.txt
&>file:将正确和错误的信息都会重定向到file eg: ls / test &> error.txt 正确和错误信息都重定向到error.txt
2>file:将错误信息和正确的信息分开处理 eg:ls / test 2>error.txt >right.txt 错误信息重定向到error.txt 正确的信息重定向到right.txt
&>> 和 2>> :追加模式
4.命令置换符
功能:得到命令的结果
语法:
cmd1 `cmd2` //将cmd2的结果作为cmd1的参数
eg:
ls `pwd` //将pwd的结果作为ls的参数
1.第一组
ls: 列出文件名
cat: 显示文本文件 eg:cat file.c 查看file.c文件的内容
less/more:分屏显示文件
rm: 删除文件
cp: 复制文件 eg:cp source.c dest.c
mv: 移动文件 eg:mv test.c test1.c eg1:mv test.c ./test
mkdir: 创建目录 eg:mkdir day4 eg1:mkdir -p day4/test
rmdir: 删除目录
2.第二组
cd: 转换目录
grep: 查找字符串 //eg: grep hqyj /etc/passwd 在passwd文件中查找hqyj用户 eg1:ps aux | grep a.out
head: 显示文件开头 //eg: head -10 file_name 显示前10行
tail: 显示文件结尾 //eg: tail -10 file_name 显示倒数10行
sort: 按次序显示文件
uniq: 去掉文件中相邻重复的行 eg:sort while.c | uniq 先将文件while.c排序,然后将结果中相邻重复的行去掉
diff: 比较两个文件 eg: diff while.c while1.c 得到两个文件不同的地方
file: 查看文件类型 eg:file a.out 查看文件类型
3.第三组
echo: 显示文本
eg:
echo "hello world" //原样输出 结果:打印"hello world"
echo $HISTSIZE 打印HISTSIZE变量的值
echo '$HISTSIZE' //严格的原样输出 结果:$HISTSIZE
echo hello world //结果:hello world 只保留一个空格
date: 显示时间和日期
eg:
date 显示时间
sudo date -s "2023/07/27 13:30"
gzip: 压缩文件
gunzip: 解压缩文件
bzip2: 压缩文件
tar: 归档和展开文件
whereis: 查找命令 eg:whereis ls 得到ls的位置
which: 查找实用程序 eg:which gcc 得到gcc的位置
4.第四组
passwd: 修改密码
passwd :修改当前用户的密码
sudo passwd root : 修改root用户的密码
sudo passwd other: 修改其他用户的密码
su:临时切换用户身份
eg:
su -c ls //临时切换身份为root,以root身份执行ls,执行完马上切换到当前用户(hqyj)
su -m //临时切换身份为root,但是环境变量还是之前用户的(hqyj) exit退出export:查看环境变量
su - //临时切换身份为root,环境变量也切换
ps: 列出进程 //ps -ef ps aux
df: 检查文件系统空间占用情况 //eg: df -T -h //查看文件系统空间占用清理
du: 显示磁盘空间的使用情况 //eg: du -h -s /etc 查看/etc目录空间使用情况
kill: 杀死进程 // kill -9 PID
chmod : 改变文件或目录的访问权限 //chmod 权限 file_name eg:sudo chmod 0777 a.out
chown: 改变文件或目录的属主 //chown root:root file_name eg:sudo chown zhangs:test 1.txt 修改1.txt的属主
chgrp: 改变文件或目录所属的组 // chgrp root file_name eg:sudo chgrp test a.out 修改a.out的所属组为test
info: 获得帮助
1./etc/passwd 用户的清单
hqyj:x:1000:1000:hqyj,,,:/home/hqyj:/bin/bash
用户名:密码:UID:GID:用户信息:用户工作目录:登录shell
2./etc/group组清单
hqyj:x:1000:
组名:密码:GID:
3.adduser/useradd命令
sudo adduser test //添加test用户
4.deluser
sudo deluser test //删除test用户
5.usermod 修改用户属性
usermod [-u uid [-o]] [-g group] [-G gropup,…]
[-d home [-m]] [-s shell] [-c comment]
[-l new_name] [-f inactive][-e expire]
[-p passwd] [-L|-U] name
修改用户名:
sudo usermod -d /home/zhangs -m -l zhangs test //将test改名为zhangs
1.进程命令
ps aux //显示所有进程的详细信息 eg: ps aux | grep a.out
top //动态显示进程信息
pstree
/proc //查看进程信息
kill -l //查看系统的信号列表
kill 信号 pid //给进程发送信号 eg:kill -9 5658
2.linux下的文件系统
1)磁盘文件系统:真实的文件系统,例如:磁盘 、DVD、USB存储器,类型:ext3 ext4 FAT16 FAT32....
2)网络文件系统:是可以远程访问的文件系统,这种文件系统在服务器端仍是本地的磁盘文件系统,客户机通过网络远程访问数据。类型:NFS Samba
3)专有/虚拟文件系统:不驻留在磁盘上的文件系统 常见格式有:TMPFS(临时文件系统)、PROCFS(Process File System,进程文件系统)和LOOPBACKFS(Loopback File System,回送文件系统)
3.linux链接类型
1)硬链接
是利用Linux中为每个文件分配的物理编号——inode建立链接。因此,硬链接不能跨越文件系统。
2)软链接(符号链接)
是利用文件的路径名建立链接。通常建立软链接使用绝对路径而不是相对路径,以最大限度增加可移植性。
注意:
1)如果是修改硬链接的目标文件名,链接依然有效;如果修改软链接的目标文件名,则链接将断开;
2)对一个已存在的链接文件执行移动或删除操作,有可能导致链接的断开。假如删除目标文件后,重新创建一个同名文件,软链接将恢复,硬链接不再有效,因为文件的inode已经改变。
3)ln命令
功能:创建文件的链接文件
语法:ln [-s] target link_name
eg:
ln -s /home/hqyj/230701/day4/while.c mylink //创建软链接
4.文件的归档和压缩
1)压缩工具
gzip:gunzip .gz
eg:
gzip hello.c //hello.c.gz
gunzip hello.c.gz
bzip2:bunzip2 .bz2
zip:unzip .zip
2)归档工具
tar [ -t | -x | -u | -c | -v | -f | -j | -z ] tarfile filelist
eg:
tar -cf mytar.tar a.out mylink while.c //将a.out mylink while.c进行归档成mytar.tar
tar -tf mytar.tar //显示归档文件中的内容
gzip mytar.tar //mytar.tar.gz
tar -czf mytar.tar.gz a.out mylink test while.c //先归档,然后使用gzip压缩
tar -xvf mytar.tar.gz //解压
zip -r test.zip test //zip压缩
unzip test.zip //解压
5.ifconfig
查看系统的ip地址
ifconfig ens33 192.168.2.180 //配置系统的ip地址
6.DHCP:动态主机配置协议
动态分配ip地址
1)ip获取过程
第一步:linux主机寻找网络中的DHCP服务器
第二步:DHCP服务器提供可用的ip
第三步:linux主机接收租借
第四步:DHCP服务器确认租约ip
7.ping
检测网络中的两台主机是否联通
eg:
ping www.baidu.com
1.本质(重点)
shell命令的有序集合
2.编译型语言和解释性语言
1)编译型语言:
a.需要先编译再执行
b.对编译器有要求,不同平台需要不同的编译器进行编译;
c.若程序编译出现错误,则不会生成可执行文件
d.运行速度比较快
2)解释型语言
a.程序不需要编译器编译,直接解释
b.若程序出现错误,会接着继续向下解释
c.运算速度慢
3.编程
1)创建shell脚本文件
touch test.sh
2)修改权限
sudo chmod 777 test.sh
3)执行
./test.sh
4.shell变量
Shell中无数据类型,将任何赋给变量的值都解释为一串字符;
1)语法形式:
Variable=value
eg:
count=1
DATE=`date`
2)四种变量
a.用户自定义变量
注意: =左右两边不能有空格
b.位置变量,即命令行参数 (见示例:test2.sh)
$0 与键入的命令行一样,包含脚本文件名
$1,$2,……$9 分别包含第一个到第九个命令行参数
$# 包含命令行参数的个数
$@ 包含所有命令行参数:“$1,$2,……$9”
$? 包含前一个命令的退出状态
$* 包含所有命令行参数:“$1,$2,……$9”
$$ 包含正在执行进程的ID号
c.预定义变量
d.环境变量(系统已经定义好的一些变量)
HOME:用户的主目录
PATH:shell的搜索路径
5.shell语句
1)说明性语句(注释)
以#开头,不会被解释执行
#!/bin/bash 特殊,指定shell类型
2)功能性语句
read var var1 var2
eg:
read a b c
1.read
2.expr 算数运算命令
SUM=`expr 12 + 4 \* 5`
echo $SUM
3.test 测试语句
测试对象:字符出啊 整数 文件属性
1.条件语句
1)if_then_fi语句
语法结构:
if 表达式
then 命令表(可以是一条 也可以是多条)
fi
eg:
A=10
B=20
if test $A -lt $B
then
echo "A<B"
fi
2)if_then_else_fi语句
语法结构:
if 表达式
then 命令表1
else 命令表2
fi
执行过程:
if后表达式为真,则执行命令表1,否则,执行命令表2
eg:
A=10
B=20
if test $A -lt $B
then
echo "A < B"
else
echo "A >= B"
fi
3)case_esac语句
语法结构:
case 字符串变量 in
模式1)
命令1
;;
模式2|模式3)
命令2
;;
....
模式n)
命令n
;;
esac
执行过程:
比较 字符串变量的值与哪个模式相等就执行哪个模式对应的命令,否则执行*对应的命令
2.循环语句
1)for_do_done语句
形式:
for 变量 in 单词表
do
命令表
done
eg:
for I 1 2 3 4 5 6 7 8 9 10
do
echo $I
done
2)while_do_done语句
形式:
while 表达式
do
命令表
done
eg:
SUM=0
I=0
while [ $I -le 100 ]
do
SUM=`expr $SUM + $I`
I=`expr $I + 1`
done
echo $SUM
1.函数定义
funtion_name() //方式一
{
}
function funtion_name() //方式二
{
}
2.函数调用
方式一:
value_name=`function_name [arg1 arg2 … ]` #所有标准输入都传递给主程序的变量
方式二:
function_name [arg1 arg2 … ] #获取函数的返回状态
echo $?
3.全局变量
SUM=0 #全局变量
local SUM=0 #局部变量
4.数组
a=(1 2 3 4 5 6 7 8 9 10)
echo ${a[0]}
echo ${a[*]}
echo ${a[@]}
echo ${#a[@]}
1.
fun1.c fun1.h
fun2.c fun2.h
pro
fun3.c fun3.h
main.c
gcc *.c //编译
./a.out //运行
2.头文件编程
vi fun.h
#ifndef FUN_H //作用:防止头文件重复包含造成重定义
#define FUN_H
#include <stdio.h>//头文件
typedef struct{
}s_t;
void fun();//函数声明
//不推荐: 变量的定义和函数的定义
#endif
1.编译程序(-g)
gcc -g hello.c
2.进入gdb调试
gdb a.out
3.调试
(gdb)b 50 在程序的50行打断点
(gdb)r 程序开始运行,运行到50行停止运行,然后就继续单步调试
(gdb)n/s(进入到函数内部) 单步调试
(gdb)p n 查看变量n的值
(gdb)q 退出
1.特点
Make工程管理器也就是个“自动编译管理器”,这里的“自动”是指它能够根据文件时间戳自动发现更新过的文件而减少编译的工作量,同时,它通过读入Makefile文件的内容来执行大量的编译工作。
make只编译更新过的文件,不会完全编译。
2.makefile(Makefile)文件
目标(二进制文件/目标文件*.o):依赖(源文件/目标文件)
命令(例如:gcc 源文件/目标文件)
eg:
hello:hello.o
<TAB> gcc hello.o -o hello
hello.o:hello.c
<TAB> gcc -c hello.c -o hello.o
eg1:vi Makefile
a.out:fun1.o fun2.o main.o
gcc fun1.o fun2.o main.o
fun1.o:fun1.c
gcc -c fun1.c -o fun1.o
fun2.o:fun2.c
gcc -c fun2.c -o fun2.o
main.o:main.c
gcc -c main.c -o main.o
3.变量
1)作用:
代替一个字符串
2)定义形式
递归: VAR=val
简单形式:VAR := val
3)变量值的获取
$(VAR)
eg2:
#定义变量
OBJS = fun1.o fun2.o main.o
CC = gcc
CFLAGS = -c -o
a.out:$(OBJS)
$(CC) fun1.o fun2.o main.o
fun1.o:fun1.c
$(CC) $(CFLAGS) fun1.o fun1.c
fun2.o:fun2.c
$(CC) $(CFLAGS) fun2.o fun2.c
main.o:main.c
$(CC) $(CFLAGS) main.o main.c
clean: #伪目标
rm *.o a.out
4)给变量添加值(+=)
eg:
OBJS = main.c fun1.o
OBJS += fun2.o #将fun2.o给)OBJS变量
5)预定义变量
编译器定义的一些变量,并且有默认值
CC:默认值cc
CXX:默认值g++
RM:默认值rm -r
6)自动变量
$* 不包含扩展名的目标文件名称
$+ 所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件
$< 第一个依赖文件的名称
$? 所有时间戳比目标文件晚的的依赖文件,并以空格分开
$@ 目标文件的完整名称
$^ 所有不重复的目标依赖文件,以空格分开
$% 如果目标是归档成员,则该变量表示目标的归档成员名称
eg:
OBJS = fun1.o main.o
OBJS += fun2.o #变量添加值
CC = gcc
CFLAGS = -Wall -c -o
all:$(OBJS)
$(CC) $^ -o $@ # $^:所有依赖文件 $@:目标文件名
fun1.o:fun1.c
$(CC) $(CFLAGS) $@ $<
fun2.o:fun2.c
$(CC) $(CFLAGS) $@ $^
main.o:main.c
$(CC) $(CFLAGS) $@ $^
clean: #伪目标
$(RM) *.o a.out
3.make选项
-C dir读入指定目录下的Makefile eg: make -C dir 指定dir目录下的makefile
-f file读入当前目录下的file文件作为Makefile eg:make -f makefile_debug 指定makefile_debug为makefile文件
-i忽略所有的命令执行错误
-I dir指定被包含的Makefile所在目录
-n只打印要执行的命令,但不执行这些命令
-p显示make变量数据库和隐含规则
-s在执行命令时不显示命令
-w如果make在执行过程中改变目录,打印当前目录名
1.分类
类型 作用域 生命周期 链接性 声明方式
auto 模块内 定义开始,模块结束 空 模块内
register 模块内 定义开始,模块结束 空 模块内,使用register修饰
全局变量 文件 定义开始,程序结束 外部 全局位置
static全局变量 文件 定义开始,程序结束 内部 全局位置,static修饰
static局部变量 模块内 定义开始,程序结束 空 模块内,使用static修饰
2.static关键字
static修饰局部变量:延长局部变量的生命周期
static修饰全局变量:修改了全局变量的作用域,只能在本文件中使用
static修饰函数:限制了函数的作用域,只能在本文件中调用
3.extern关键字
修饰全局变量,表示变量是外部的全局变量
eg:
vi fun.c
int a = 123;
void fun()
{
}
vi main.c
extern int a; //a是fun.c中的全局变量
int main()
{
return 0;
}
gcc main.c fun.c
编译器根据条件是否为真决定是否编译对应的代码
一.根据宏是否定义,形式:
#ifdef 宏
...... //宏定义则执行
#else
..... //宏未定义则执行
#endif
eg:
int exc(int a, int b)
{
a = a ^ b ;
b = a ^ b;
a = a ^ b;
#ifdef DEBUG
printf("a=%d b=%d\n",a,b);
#endif
return 0;
}
void fun()
{
#ifdef DEBUG
printf("fun....\n");
#endif
}
int main()
{
int m = 10;
int n = 20;
exc(m,n);
fun();
return 0;
}
二.根据宏的值进行条件编译
1.形式
#if 值
.....
#else
....
#endif
eg:
int exc(int a, int b)
{
#if 1
a = a ^ b ;
b = a ^ b;
a = a ^ b;
#else
int tmp = a;
a = b;
b = tmp;
#endif
return 0;
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。