Linux基础第一回 概述,linux第一回概述

第一章 概述

Linux基础第一章 概述,linux第一节概述

1.1 前言

本章讨论系统的概念,从硬件、操作系统角度更是深厚的亮计算机体系,并迅速浏览Linux系统提供的劳务。

第一章 概述

1.2 系统做

 图片 1

 

1.1 前言

本章讨论系统的概念,从硬件、操作系统角度更是深切的了解计算机体系,并火速浏览Linux系统提供的劳务。

1.3 操作系统和应用程序

操作系统是词语来二意性,有时候指内核,有时候指内核和网工具软件的结合。

 

 图片 2

 

 

操作系统是管制网硬件的软件。操作系统是直运行在裸机之上。其他使用软件运行在操作系统之上。

操作系统本身提供操作接口,支持用户通过该接口来操作
系统,但是系统自提供的机能,不足为得用户要求时,则用开应用程序来展开系统功能。

发行版:
不等之商家利用Linux内核,加上自己开发的体系工具软件,一起发布之Linux操作系统版本。

1.2 系统做

1.4 启动同登陆

图片 3

布文件:
/etc/profile:系统启动时为实施
~/.bashrc:用户登陆时会调用

 图片 4  

1.5 文件

文本是一个至关重要的定义,一般定义也信之集合。计算机做吗信息处理的机器,文件是电脑处理的靶子。

每当Unix和Linux系统中,泛化了文件的定义,设备为受架空成文件对象来进展操作。

数码的集叫做文件。
IT行业处理信息:转换,传输,存储

1.3 操作系统及应用程序

操作系统这个词语有二意性,有时候指内核,有时候指内核和系统工具软件的组合。

   图片 5    

操作系统是管制体系硬件的软件。操作系统是直运行在裸机之上。其他使用软件运行于操作系统之上。

操作系统本身提供操作接口,支持用户通过该接口来操作
系统,但是系统自提供的法力,不足于完成用户要求时,则用开发应用程序来进行系统功能。

发行版:
不等之店堂下Linux内核,加上自己出的体系工具软件,一起发布之Linux操作系统版本。

1.6 程序、进程

图片 6

1.4 启动和登陆

图片 7

布局文件:
/etc/profile:系统启动时让实践
~/.bashrc:用户登陆时见面调用

1.7 错误处理

系调用在相似情形下归来整数,并且0表示成功,小于0代表失败。当系统调用返回失败时,可以由此errno获得错误嘛,通过strerror获取错误解说,或者直接通过perror在正儿八经错误文件中,输出错误信息。

 

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

int main()
{
// 通过open返回的平头,在linux中起只特别的讳
// 叫文件讲述符 file description 简称fd

int fd = open(“a.txt”, O_WRONLY|O_CREAT|O_EXCL, 0777);
if(fd < 0)//表示文件打开失败
{
perror(“open”);
return 0;
}

// 把指针放到文件开始
lseek(fd, 0, SEEK_SET);

// 对文本进行操作
write(fd, “hello”, 5);

// 关闭文件,如果非停歇,内存会泄漏
// 当进程退出时,未关的公文会自行关闭
close(fd);

}

1.5 文件

文本是一个首要的定义,一般定义为信之集合。计算机做啊信息处理的机,文件是电脑处理的靶子。

于Unix和Linux系统中,泛化了文件的概念,设备呢受架空成文件对象来拓展操作。

数量的汇叫做文件。
IT行业处理信息:转换,传输,存储

1.8 用户、组、文件权限

Linux是多用户系统,支持多只用户同时登陆系统。
为了安全起见,需要对系的权能加于规范。

1.6 程序、进程

1.9 信号

信号是过程通信的均等栽手段,某个进程收到信号,该信号也许来内核、来自其它进程要来用户操作。例如:当用户仍下ctrl+c时,其实是受前台进程发送了一个信号。

图片 8

1.10 系统调用和库函数

习Linux系统开发接口时,程序员也欲学习一般常用之老三方库,来展开程序员的编程能力。

 

图片 9

User Space和Kernel
Space是操作系统编程中常用的定义,表示目前的代码在用户空间还是水源空间运行,对于不同之运行空间,CPU对内存的处理方式稍有两样,在说话进程虚拟地址空间时更干拖欠概念。

系调用指操作系统内核提供的效力,它提供了接口给用户空间代码调用。比如open/read/write/close等,都是属Linux系统操作接口,而fopen/fread/fwrite/fclose是属于C标准提供的接口,在Linux下,fopen其实底层调用了open。

部署文件:
/etc/profile:系统启动时于实践
~/.bashrc:用户登陆时会见调用

1.7 错误处理

系调用在相似景象下回到整数,并且0表示成功,小于0代表失败。当系统调用返回失败时,可以由此errno获得错误嘛,通过strerror获取错误解说,或者直接通过perror在专业错误文件中,输出错误信息。

 

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

int main()
{
// 通过open返回的平头,在linux中出只特别的名字
// 叫文件讲述符 file description 简称fd

int fd = open(“a.txt”, O_WRONLY|O_CREAT|O_EXCL, 0777);
if(fd < 0)//表示文件打开失败
{
perror(“open”);
return 0;
}

// 把指针放到文件开始
lseek(fd, 0, SEEK_SET);

// 对文本进行操作
write(fd, “hello”, 5);

// 关闭文件,如果非关门,内存会泄漏
// 当进程退出时,未关的公文会自动关闭
close(fd);

}

文件操作

头文件:sys/types.h  sys/stat.h
 fcntl.h  例:int fd=open(“文件路径”,mode);
 mode决定了针对文本之操作方法
  第三独参数可出可不论是,对文本权限进行处理,   因umask存在,创建文件权限要同上000 000 010之反倒,导致用户权限开始不可知起描绘的权杖

mode选项

解释

O_RDONLY

读方式打开(与后面俩个互斥)

O_WRONLY

写方式打开

O_RDWR

读写方式打开

O_CREAT

创建文件,如果文件存在,直接打开

O_TRUNC

截断

O_APPEND

追加

O_EXCL

和O_CREAT一起用,如果文件存在则失败

1.8 用户、组、文件权限

Linux是基本上用户系统,支持多只用户同时登陆系统。
为了安全起见,需要对网的权限加于规范。

函数:

perror:对某种错误信息进行打印

open/creat:打开文件/创建文件
read:读文件
write:写文件
close:关闭文件
lseek:定位文件读写位置
fcntl:修改文件属性
sysconf:读取系统安排
dup/dup2:复制文件讲述称
sync/fsync/fsyncdata:同步文件数量
mmap/munmap:文件映射
mkstemp:得到临时文件路径

1.9 信号

信号是过程通信的平栽手段,某个进程收到信号,该信号可能源于内核、来自其它进程或来用户操作。例如:当用户仍下ctrl+c时,其实是给前台进程发送了一个信号。

命令

touch:修改文件之顾时,创建文件
cat:访问文件内容
vim:编辑
ulimit:显示有范围信息(文件讲述吻合最酷价值、栈的半空中尺寸)
umask:文件创建的权柄掩码
getconf:对应sysconf

dd:可以拷贝块设备,但是若sudo权限  例  dd if=位置 of=文件名  bs=一破稍k cout=拷贝次数

Wc:计算文件之行数  单词个数
字节数

unlink:删除软链接

 

1.10 系统调用和库函数

学学Linux系统开发接口时,程序员也得上一般常用的老三方库,来进行程序员的编程能力。

  图片 10

User Space和Kernel
Space是操作系统编程中常用的概念,表示手上底代码在用户空间还是根本空间运行,对于不同之运行空间,CPU对内存的处理方式稍有例外,在谈话进程虚拟地址空间时再也涉及该概念。

系统调用指操作系统内核提供的法力,它提供了接口给用户空间代码调用。比如open/read/write/close等,都是属Linux系统操作接口,而fopen/fread/fwrite/fclose是属于C标准供的接口,在Linux下,fopen其实底层调用了open。

布局文件:
/etc/profile:系统启动时叫实践
~/.bashrc:用户登陆时见面调用

信号

是决定过程通信的如出一辙栽办法,效率高,成本低

信号处理方式:掩盖、忽略、默认处理

掩码:延迟信号的拍卖  运用信号集合   

盖不可因信号,多次殡葬,只处理同软
  掩盖:可靠信号  处理多次

进程

fork()创建

文件操作

头文件:sys/types.h  sys/stat.h  fcntl.h  例:int
fd=open(“文件路径”,mode);  mode决定了对文本之操作方式
  第三只参数可来可无论,对文本权限进行处理,
  因umask存在,创建文件权限要和上000 000
010的反倒,导致用户权限开始免能够来描绘的权

mode选项

解释

O_RDONLY

读方式打开(与后面俩个互斥)

O_WRONLY

写方式打开

O_RDWR

读写方式打开

O_CREAT

创建文件,如果文件存在,直接打开

O_TRUNC

截断

O_APPEND

追加

O_EXCL

和O_CREAT一起用,如果文件存在则失败

线程

鼠标键盘都是单独念之字符文件夹设备,所以可以利用函数进行督查
 一般以/dev/input/mic 文件下面  注意权限问题
 鼠标键盘读取数据,是俩只经过,注意进程的围堵问题
 可以动用字进程与父进程进行处理

函数:

perror:对某种错误信息进行打印

open/creat:打开文件/创建文件
read:读文件
write:写文件
close:关闭文件
lseek:定位文件读写位置
fcntl:修改文件属性
sysconf:读取系统布局
dup/dup2:复制文件讲述吻合
sync/fsync/fsyncdata:同步文件数量
mmap/munmap:文件映射
mkstemp:得到临时文件路径

线程的创导 

 pthread_created(1,2,3,4)
//1:线程的id  2:线程的底特性  3:新线程的函数名字, 4:新线程的属性    要链接  -lpthread  库   

只顾子线程是专属主线程的,主线程结束,子线程无法运行    
这个 pthread_exit(0)主线程结束,子线程没有退出例外

 

运用pthread_equal  判断线程是否当,先等回到回0  不等于返回非零值

pthread_jion(1,&ret)  阻塞调用 1:线程id  ret:线程返回值

 

pthread_t tid = pthread_self()  得到时运行过程的id

命令

touch:修改文件的拜会时间,创建文件
cat:访问文件内容
vim:编辑
ulimit:显示有克信息(文件讲述吻合最特别价值、栈的空间尺寸)
umask:文件创建的权掩码
getconf:对应sysconf

dd:可以拷贝块设备,但是若sudo权限  例  dd if=位置 of=文件名
 bs=一次稍k cout=拷贝次数

Wc:计算文件的行数  单词个数 字节数

unlink:删除软链接

 

进程以及线程的界别:

过程:分配资源的单位  线程:调度的单位     多线程可以共享全局变量

信号

是控制过程通信的均等种植方法,效率高,成本没有

信号处理方式:掩盖、忽略、默认处理

掩码:延迟信号的处理  运用信号集合   

覆盖不可因信号,多次发送,只处理同不成   掩盖:可靠信号  处理多次

进程

fork()创建

避免二元单线程同时操作全局变量,第一只线程运用了锁,后面的线程在外侧当,等待解锁后,后面的线程在进

线程

鼠标键盘都是特念之字符文件夹设备,所以可以以函数进行监察
 一般在/dev/input/mic 文件下面  注意权限问题
 鼠标键盘读取数据,是俩独过程,注意进程的阻隔问题
 可以使用字进程和父进程进行拍卖

死锁

连年俩蹩脚加锁,加锁后,没有解锁,又持续加锁,会促成死锁。
运用循环锁,可以另行加锁   通过定义锁的性,变为循环锁
 例:pthread_mutexattr_t attr;  pthread_mutexattr_init(&attr);
 pthread_mutexattr_settype(&attr,
PTHREAD_MUTEX_RECURSIVE);pthread_mutex_init(&mutex,&attr)

加锁后,忘记解锁,也会见出现死锁
 C++中利用析构函数,可以避免忘记解锁,定义一个接近

 

线程的创办 

 pthread_created(1,2,3,4) //1:线程的id  2:线程的之习性
 3:新线程的函数名字, 4:新线程的属性    要链接  -lpthread  库   

留意子线程是专属主线程的,主线程结束,子线程无法运转    
这个 pthread_exit(0)主线程结束,子线程没有脱离例外

 

运用pthread_equal  判断线程是否当,先等回回0  不顶返回非零值

pthread_jion(1,&ret)  阻塞调用 1:线程id  ret:线程返回值

 

pthread_t tid = pthread_self()  得到时运行过程的id

读写锁

pthread_rwlock_t mutex;

pthread_rwlock_init(&mutex, NULL);

读/写锁定pthread_rwlock_rd/wrlock(&mutex);

解锁:pthread_rwlock_unlock(&mutex);

过程以及线程的分:

进程:分配资源的单位  线程:调度的单位     多线程可以共享全局变量

 

避二元单线程同时操作全局变量,第一单线程运用了锁,后面的线程在外边当,等待解锁后,后面的线程在入

医护进程

看护进程不跟极端关联,注意是过程只能发出一个,创建文件记录,判断这个程序是否被

死锁

连接俩次等加锁,加锁后,没有解锁,又持续加锁,会招死锁。
运用循环锁,可以重加锁   通过定义锁的属性,变为循环锁
 例:pthread_mutexattr_t attr;  pthread_mutexattr_init(&attr);
 pthread_mutexattr_settype(&attr,
PTHREAD_MUTEX_RECURSIVE);pthread_mutex_init(&mutex,&attr)

加锁后,忘记解锁,也会油然而生死锁
 C++中利用析构函数,可以避免忘记解锁,定义一个近乎

 

编程规则:

设umask=0;

调用fork,让爹爹进程退出。    让老爹进程变为init,  如果大进程不脱,用俩次fork()

调用setuid创建新会话  setsid

重设当前目录/根目录     chdir        

关闭不需之文书讲述符    运用循环关闭所有文件讲述称

读写锁

pthread_rwlock_t mutex;

pthread_rwlock_init(&mutex, NULL);

读/写锁定pthread_rwlock_rd/wrlock(&mutex);

解锁:pthread_rwlock_unlock(&mutex);

高级IO

一个历程就是一模一样截指令

 

IO复用技术

看护进程

守护进程不与终极关联,注意这个过程只能有一个,创建文件记录,判断是程序是否开启

select的运用

利用文件讲述符集合  运用fd_set创建文件讲述符集合
 文件接口相对较小,跨平台运用

FD_SET(1,2)
将文件讲述符放入文件讲述符集合  1:文件讲述符  2:集合名字

编程规则:

设umask=0;

调用fork,让爸爸进程退出。    让爹爹进程变为init,
 如果大进程不脱离,用俩次fork()

调用setuid创建新会话  setsid

重设当前目录/根目录     chdir        

闭馆不需要的文件讲述符    运用循环关闭所有文件讲述吻合

epoll的运用

epollfd  创建文件讲述符集合

epol_ctl将文件讲述加入集合中

高级IO

一个过程就是同等段指令

非阻塞IO

 

IO复用技术

管道

一边读,一边写

select的运用

用文件讲述符集合  运用fd_set创建文件讲述符集合
 文件接口相对较小,跨平台下

FD_SET(1,2) 将文件讲述符放入文件讲述符集合  1:文件讲述符
 2:集合名字

匿名管道  pipe()创建管道

 

 

mmap  可以兑现有亲子关系进程的文件共享
 效率不如,数据写入内存,在自外存中读取数据
 运用shm_open实现文件共享也足以

文本内存共享,无法展开通信

 

由此锁,让过程共享内存进行通信
 pthread_mutex_init  需要拿锁在共享内存中  

 

fork  +  exec 让过程有异的机能

 

epoll的运用

epollfd  创建文件讲述符集合

epol_ctl将文件讲述加入集合中

非阻塞IO

 

管道

一边读,一边写

匿名管道  pipe()创建管道

 

 

mmap  可以实现有亲子关系进程的文件共享
 效率不如,数据写入内存,在起内存中读取数据
 运用shm_open实现文件共享也堪

文件内存共享,无法进展通信

 

透过锁,让过程共享内存进行通信  pthread_mutex_init
 需要将锁在共享内存中  

 

fork  +  exec 让过程产生两样之效应

 

http://www.bkjia.com/Linuxjc/1209387.htmlwww.bkjia.comtruehttp://www.bkjia.com/Linuxjc/1209387.htmlTechArticleLinux基础第一章 概述,linux第一段概述 第一章节 概述
1.1 前言
本章讨论系统的概念,从硬件、操作系统角度更是深切的晓计算机体系,并快…

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图