Linux系统初步介绍(一)新手入门必看

UNIX系统介绍:

于1971~1973年在美国贝尔实验室由丹尼斯.里奇、肯.汤普逊合作开发而成,而且顺便升级BCPL语言为C语言。
特点:高安全性、高可靠性、高稳定性,既可以构建大型关键业务系统的商业级服务器,也可以构建面向移动终端、可穿戴设备的嵌入式应用。
Minix是一种基于微内核架构的类UNIX计算机操作系统,于1987年由Andrew S. Tanenbaum教授发布用于在大学中教学和学术研究,正是它的出现启发了Linux。

Linux系统介绍:

全称叫 GNU/Linux 免费且开源的类UNIX操作系统,由林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发。

基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Linux继承了UNIX以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

Linux有上百种不同的发行版,如基于社区开发的Debian、Arch、Deepin,和基于商业开发的RedHat、SUSE、Oracle等,还有基于嵌入式设备的Android。

Linux系统的图标是企鹅,(因为根据国际公约南极洲为全人类所有,不属于任何国家)它代表Linux系统的开源精神,任何公司或组织都无权将它私有。

Linux系统相关知识:

GNU工程:
由Richard Stallman于1984发起,由自由软件基金会提供支持。
其基本原则就是共享,其主旨是发展一个有别于一切商业UNIX的操作系统,也就是通用非商业的类UNIX系统,所以Linux也叫GNU Linux。
POSIX标准:
可移植操作系统接口(Portable Operating System Interface,缩写为POSIX),也就是统一的系统编程接口规范。
UNIX和Linux系统都遵循了该规范,所以它们系统接口基本一致,所以代码可以通用。
GPL通用公共许可证:
GPL,是GNU General Public License的缩写,GNU通用公共许可证试图保证你共享和修改软件的自由,遵循GPL的软件可以自由的共享、开源、免费,如果想使用具备GPL的代码也必须先遵循GPL,自然也就无法盈利了。

GNU编译工具:
1、早期是GNU组织为了编译Linux源码的而开发的一款C语言编译器,后期逐渐支持了各种平台的各种编程语言。

2、构建C/C++的过程
预处理->编译->汇编->链接
gcc -E code.c -o code.i
gcc -S code.i -> code.s
gcc -c code.s -> code.o
gcc code.o -> a.out

3、支持、产生的文件类型
.h 头文件
.h.gch 头文件的编译结果
.c 源文件
.i 预处理文件
.s 汇编文件
.o 目标文件
.a 静态库文件
.so 动态库文件

4、常用参数
-E 预处理
-S 编译
-c 汇编
-g 生成调试信息
-I 指定额外的头文件的路径
-l 指定额外的库文件名 例:-lm
-L 指定额外的库文件路径
-D 在编译时定义宏
-o 指定编译结果的文件名
-On 代码的优化级别
-Wall 以严格的语法来检查代码
-Werror 把警告当错误处理
-std 指定编译时的语法标准
-pedantic 对不符合ANSI标准的代码产生警告

5、所支持的预处理指令
#include 将指定的文件导入至当前文件
#define 定义宏或宏常量
## 与#define配合,连接两个标识符
# 与#define配合,把标识符转换成字符串字面值
#undef 删除宏
#if 判定
#else 判断条件为假,可以与#if#ifdef#ifndef配合使用。
#elif 分支判定
#endif 判定的结束标志
#ifdef 判定宏存在为真
#ifndef 判定宏不存在为真
#line n 指定该行的行号
#error 产生错误信息,并阻止产生编译结果。
#warning 产生警告信息
#pragma once 保证头文件只被包含一次,相当于#ifndef/#define/#endif,但并不是所有的编译器都支持
#pragma pack(1/2/4/8) 指定内存对齐补齐的最大字节数,只能从大往小改,且必须是2^n。
#pragma GCC poison <标识> 把某个标识符定义为病毒
#pragma GCC dependency <文件名> 如果文件的修改时间比当前文件晚,则产生警告

6、编译器预定义的宏
DATE 日期
TIME 时间
FILE 文件名
LINE 行号
func 函数名
cplusplus 是否被C++编译器编译

系统调用

什么是系统调用:操作系统以函数形式提供的一些功能,我们平时所使用的操作系统的功能绝大部分都是通过系统调用实现的。

系统调用的运行机制:
普通函数:函数调用时是生成一条跳转语句,跳转到函数所在的代码段位置执行,执行完成后再返回。

系统调用:为了系统的安全不能让应用程序跳转到内核所在的位置执行,而先开辟一块内核与应用 程序共享的区域用于存放系统调用所需要的参数,然后应用程序再给内核发送信号告诉内核要执行的系统调用,然后内核从共享区域获取参数,执行完成后再把返回值放到共享区域。

用户态与内存态:
应用程序执行的时间段叫用户态,把系统调用执行的时间段叫内核态。
使用time可以获取程序的执行时间,以及用户态和内核态分别的执行时间。
注意:当调用标准库的函数时,可能工作在用户态也可以工作内核态,因为标准库函数中可能使用到的系统调用,如:malloc/free。
time ./a.out
real 0m0.002s 应用程序的总用时
user 0m0.000s 用户态执行时间
sys 0m0.000s 内核态执行时间
strace ./a.out 跟踪系统调用

一切皆文件:
在UNIX/Linux系统中把一些复杂的设备、服务抽象出一个统一的操作接口,这种接口就是文件操作,也就把这些设备和服务封装成了文件,这样应用程序可以像访问文件一样去访问串号、网络、打印机等设备。

文件分类:
普通文件 -
目录文件 d
链接文件 l
设备文件 c|b|n
管道文件 p
socket文件 s

文件相关的系统调用:

int open(const char *pathname, int flags, mode_t mode);
功能:打开或创建文件
pathname:文件路径
flags:打开文件时的权限
O_RDONLY 只读
O_WRONLY 只写
O_RDWR 读写
O_CREAT 文件不存在时创建
O_EXCL 配合创建使用,文件存在时出错
O_TRUNC 清空
O_APPEND 追加
作业:使用strace测试出fopen的 w,r,a,w+,r+,a+对应的flags
mode:创建文件时的权限mmm,与chmod的权限设置方式一致。
返回值:
成功 文件描述符
失败 返回-1

ssize_t write(int fd, const void *buf, size_t count);
功能:写入数据
fd:文件描述符,open函数的返回值
buf:待写入的内存首地址
count:要写入的字节数
返回值:
成功 写入的字节数
失败 返回-1

ssize_t read(int fd, void *buf, size_t count);
功能:读取数据
fd:文件描述符,open函数的返回值
buf:存储读取到数据的内存首地址
count: buf的大小
返回值:
成功 读取到的字节数
失败 -1

int close(int fd);
功能:关闭文件描述符
返回值:成功返回0,失败返回-1。

文件描述符:

是一个非负整数,代表一个打开的文件,每个打开的文件内核中就会有一个结构体(相当于标准C中的FILE),该结构中记录着文件相关的详细信息,为了内核的安全,内核中的所有数据都不能暴露,因此只能给应用层返回一个整数,该整数对应着内核中的文件结构体,也叫句柄。

有默认打开的三个文件描述符:
0 标准输入 STDIN_FILENO stdin
1 标准输出 STDOUT_FILENO stdout
2 标准错误 STDERR_FILENO stderr

int fileno(FILE *stream);
功能:获取文件结构中描述符

FILE *fdopen(int fd, const char *mode);
功能:把文件描述符转换成文件结构指针

## 标准IO与系统IO

1、当使用系统调用时,需要从用户态切换到内核态,当系统调用执行完成后再从内核态切换到用户态,如果频繁切换会浪费很多时间。

2、而标准IO使用的缓冲区机制,数据并不会立即写入文件,而是先暂存到缓冲区中,当缓冲区满时再一次写入文件中,从面大大降低了用户态与内核态的切换次数,因此节约了大量时间,所以标准IO要比直接使用系统IO快。

3、如果系统IO也使用缓冲区机制它的速度将比标准IO更快。

随机读写:

  1. int fseek(FILE *stream, long offset, int whence);
    功能:设置在这里插入代码片文件位置指针 标准IO
    返回值:成功返回0,失败返回-1。

  2. long ftell(FILE *stream);
    功能:获取文件位置指针

  3. off_t lseek(int fd, off_t offset, int whence);
    功能:设置文件位置指针 系统IO
    返回值:调整后的文件位置指针

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值