您当前的位置:首页 > 问答 > 内容

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

关于【工作交接是什么意思】,交接工作内容包括什么,今天犇涌小编给您分享一下,如果对您有所帮助别忘了关注本站哦。

内容导航:1、原来“进程间通信”是这么回事!2、工作交接是什么意思:交接工作内容包括什么

1、原来“进程间通信”是这么回事!

【进程间通信】常用方式汇总

在系统中,随着我们的进程越来越多,难免不同进程之间要互相传输一些数据,那么这个时候该怎么办呢?

下面,我们一起来简单了解一下进程间通信(InterProcess Communication,IPC)的几种实现方式!

1、管道模型

管道模型与软件生命周期模型——瀑布模型(Waterfall Model)很相似。

所谓的瀑布模型,其实就是将整个软件开发过程分成多个阶段,往往是上一个阶段完全做完,才将输出结果交给下一个阶段。

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

还记得咱们最初学 Linux 命令的时候,有下面这样一行命令:

ps -ef | grep 关键字 | awk '{print $2}' | xargs kill -9

这里面的竖线“|”就是一个管道。它会将前一个命令的输出,作为后一个命令的输入。

从管道的这个名称可以看出来,管道是一种单向传输数据的机制,它其实是一段缓存,里面的数据只能从一端写入,从另一端读出。如果想互相通信,我们需要创建两个管道才行。

管道又可以分为:匿名管道和命名管道。

1.1 匿名管道

如上命令:

ps -ef | grep 关键字 | awk '{print $2}' | xargs kill -9

匿名管道:用"|” 表示的管道,意思就是这个类型的管道没有名字,用完了就销毁了。竖线代表的管道随着命令的执行自动创建、自动销毁。用户甚至都不知道自己在用管道这种技术,就已经解决了问题。

1.2 命名管道

命名管道,这个类型的管道需要通过mkfifo命令显式地创建。

mkfifo donge#建立一个管道

donge就是这个管道的名称。管道以文件的形式存在,这也符合 Linux 里面一切皆文件的原则。

下面,我们看一下文件类型。

ls -lprw-rw-r-- 1 dong dong 0 Sep 28 17:09 donge

可以看到,这个文件的类型是p,就是pipe的意思。

往管道中写入数据:

echo "hello world" > donge

这个时候,管道里面的内容没有被读出,这个命令就是停在这里的,即进程被堵塞。

这说明当一个项目组要把它的输出交接给另一个项目组做输入,当没有交接完毕的时候,前一个项目组是不能撒手不管的。

嵌入式物联网需要学的东西真的非常多,千万不要学错了路线和内容,导致工资要不上去!

无偿分享大家一个资料包,差不多150多G。里面学习内容、面经、项目都比较新也比较全!某鱼上买估计至少要好几十。

点击这里找小助理0元领取:加微信领取资料

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

重新打开一个终端,读出管道数据。

cat < hello hello world

一方面,我们能够看到,管道里面的内容被读取出来,打印到了终端上;

另一方面,echo 那个命令正常退出了,也即交接完毕,前一个项目组就完成了使命,可以解散了。

管道通信,我们可以看出,瀑布模型的开发流程效率比较低下,因为团队之间无法频繁地沟通。而且,管道的使用模式,也不适合进程间频繁的交换数据

2、消息队列

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

消息队列可以理解为发邮件,每一封邮件都视为一个独立的数据单元,也就是消息体,每个消息体都是固定大小的存储块,在字节流上不连续

这个消息结构的定义我写在下面了。这里面的类型 type 和正文 text 没有强制规定,只要消息的发送方和接收方约定好即可。

struct msg_buffer { long mtype; char mtext[1024];};

2.1 创建消息队列

消息队列的创建,需要用到msgget函数。

int msgget(key_t key, int msgflg);key:该参数是消息队列的唯一标识,由ftok生成。msgflg:取值有以下几个选择:IPC_CREATIPC_EXCL,这两个参数详细的作用可以man msgflg看详细介绍。返回值:返回一个近乎唯一的Message queue id

那么,key是如何由ftok生成的呢?

我们可以指定一个文件,调用ftok,它会根据这个文件的inode,生成一个近乎唯一的key

key_t ftok(const char *pathname, int proj_id);pathname:文件信息,必须指定在一个存在的,可访问的文件。proj_id8bit的数据,0-255随意设定。

这样就可以获得一个近乎唯一的key了!

只要在这个消息队列的生命周期内,这个文件不要被删除就可以了。只要不删除,无论什么时刻,再调用 ftok,也会得到同样的 key。

综上,创建一个消息队列只需两步:

①:ftok生成一个key

②:msgget生成一个消息队列的ID

如下:

#include <stdio.h>#include <stdlib.h>#include <sys/msg.h> int main() { int messagequeueid; key_t key; if((key = ftok("/root/messagequeue/messagequeuekey", 1)) < 0) { perror("ftok error"); exit(1); } printf("Message Queue key: %d.\n", key); if ((messagequeueid = msgget(key, IPC_CREAT|0777)) == -1) { perror("msgget error"); exit(1); } printf("Message queue id: %d.\n", messagequeueid);}

ftok要指定一个存在的文件,所以我们在执行之前,需要创建该文件。

查看消息队列:

System V IPC 体系有一个统一的命令行工具:ipcmkipcsipcrm用于创建、查看和删除IPC对象。

查看创建的IPC对象:ipcs -q

dong@ubuntu:~//Interprocess_Communication$ ipcs ------ Message Queues --------key msqid owner perms used-bytes messages 0x01110005 0 dong 777 0 0 ------ Shared Memory Segments --------key shmid owner perms bytes nattch status ------ Semaphore Arrays --------key semid owner perms nsems

2.2 发送消息

消息队列发送消息,主要调用msgsnd函数。

int msgsnd(int msqid, const void *msgp, size_t msgsz, int msgflg);msqid:该参数是msgget所得到的message queueidmsgp:消息结构体

struct msg_buffer { long mtype; char mtext[1024];};msgsz:表示消息结构体中,mtext最大长度。msgflg:一位掩码,可取值有:IPC_NOWAITMSG_COPYMSG_EXCEPTMSG_NOERROR,取值说明可见man msgsnd

2.3 接收消息

消息队列接收消息,主要调用msgrcv函数。

ssize_t msgrcv(int msqid, void *msgp, size_t msgsz, long msgtyp, int msgflg);msqid:该参数是msgget所得到的message queueidmsgp:消息结构体msgsz:可接收数据最大长度msgflg:一位掩码,可取值有:IPC_NOWAITMSG_COPYMSG_EXCEPTMSG_NOERROR,取值说明可见man msgsnd

有了消息这种模型,两个进程之间的通信就像咱们平时发邮件一样,你来一封,我回一封,可以频繁沟通了。

3、共享内存

工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)

怎么理解共享内存呢?

我们知道每个进程都有自己独立的虚拟内存空间不同的进程的虚拟内存空间映射到不同的物理内存中去。这个进程访问 A 地址和另一个进程访问 A 地址,其实访问的是不同的物理内存地址,对于数据的增删查改互不影响。

但是,咱们是不是可以变通一下,拿出一块虚拟地址空间来,映射到相同的物理内存中。这样这个进程写入的东西,另外一个进程马上就能看到了,都不需要拷贝来拷贝去,传来传去。

相比于消息队列,共享内存的优势在哪里呢?

大数据传输:如果批量的大数据进行传输,使用邮件的方式,来去发送不及时,并且大小也有限制。实时性:用共享内存,其可以大大节省通信时间。

3.1 创建共享内存

我们可以创建一个共享内存,调用shmget

int shmget(key_t key, size_t size, int shmflg);key:和msgget里面的key一样,都是唯一定位一个共享内存的对象size:共享内存的大小shmflg:其值可以取:IPC_CREATIPC_EXCLSHM_HUGETLBSHM_HUGE_2MB

返回值:共享内存的唯一ID

创建完毕之后,我们可以通过ipcs命令查看这个共享内存。

#ipcs --shmems ------ Shared Memory Segments ------ ­­­­­­­­key shmid owner perms bytes nattch status0x00000000 19398656 marc 600 1048576 2 dest

3.2 访问共享内存

接下来,如果一个进程想要访问这一段共享内存,需要将这个内存加载到自己的虚拟地址空间的某个位置,通过shmat函数,就是attach的意思。

void *shmat(int shmid, const void *shmaddr, int shmflg);shmid:标识一个共享内存段的唯一IDshmaddr:就是要指定attach到这个地方。但是这个地址的设定难度比较大,除非对于内存布局非常熟悉,否则可能会attach到一个非法地址。所以,通常的做法是将shmaddr设为NULL,让内核选一个合适的地址。shmflg:一位掩码,可取值:SHM_EXECSHM_RDONLYSHM_REMAP

返回值:为所连接的实际地址

3.3 关闭共享内存

如果共享内存使用完毕,可以通过shmdt解除绑定,然后通过shmctl,将cmd设置为IPC_RMID,从而删除这个共享内存对象。

int shmdt(void *addr); int shmctl(int shmid, int cmd, struct shmid_ds *buf);

shmdt的参数addr:为shmat的返回值,表示卸载一片共享内存。

shmctl的参数:

shm_idshmget的返回值,为共享内存的唯一IDcmd:取值有:IPC_STATIPC_RMID等,见:man shmctlbuf:共享内存管理结构体。

3.4 信号量

这里你是不是有一个疑问,如果两个进程attach同一个共享内存,大家都往里面写东西,很有可能就冲突了。例如两个进程都同时写一个地址,那先写的那个进程会发现内容被别人覆盖了。

所以,这里就需要一种保护机制,使得同一个共享的资源,同时只能被一个进程访问。在System V IPC进程间通信机制体系中,早就想好了应对办法,就是信号量(Semaphore。因此,信号量和共享内存往往要配合使用。

信号量和共享内存都比较复杂,两者还要结合起来用,就更加复杂,它们内核的机制就更加复杂。这一节我们先不讲。

4、信号

上面讲的进程间通信的方式,都是常规状态下的工作模式,对应到咱们平时的工作交接,收发邮件、联合开发等,其实还有一种异常情况下的工作模式

例如出现线上系统故障,这个时候,什么流程都来不及了,不可能发邮件,也来不及开会,所有的架构师、开发、运维都要被通知紧急出动。所以,7 乘 24 小时不间断执行的系统都需要有告警系统,一旦出事情,就要通知到人,哪怕是半夜,也要电话叫起来,处理故障。

信号可以在任何时候发送给某一进程,进程需要为这个信号配置信号处理函数。

Linux所支持的异常信号如下:

1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP 6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR111) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+338) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+843) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+1348) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-1253) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-758) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-263) SIGRTMAX-1 64) SIGRTMAX

当某个信号发生的时候,就默认执行这个函数就可以了。这就相当于咱们运维一个系统应急手册,当遇到什么情况,做什么事情,都事先准备好,出了事情照着做就可以了。

有点类似于异常中断……

OK,这一篇,我们整体讲解了一下进程间通信的几种方式,现在我们来回顾一下:

2、工作交接是什么意思:交接工作内容包括什么

交接工作内容包括什么

1、日常工作,即现有业务的覆盖面,每个业务的现状;也指常规要做的内容有哪些,也可以把他理解为绩效指标或关键任务项。

2、待办工作,现在手头上的工作开展的进度,接下来要做的工作现状、后续工作推进计划、正在推进中的工作事项,推进中存在的问题及后续注意事项。

3、工作资料,包括规章制度、条文,也包括历年原始文件资料等。另附相关资料、文档转交的介绍和说明;这里建议将所有资料做交接,不公限于相关资料,且copy或是传送给乙方工作接手人。

4、具体工作办理方法。相关工作的流程、时间节点、联系人,注意事项。建议理一份自己工作的作业指导书或操作手册。或者有一份工作推进中常见的FAQ。有了这些,工作交接非常全面、细致,有哪些工作及工作如何来做就有书面的依据了。

5、扶上马送一程,除了做好工作内容的交接之外,还应将接手人介绍给原相关的接口人;另外,针对一些敏感的信息,可以单独发邮件给接手人留存,如微信公众号、微博、公共邮箱、公共QQ等的账号密码等。在正式引荐完成后,则原来由交接人主要跟进的工作,均转交由接手人跟进执行,由交接人辅助即可。

6、修订工作作业指书或操作手册及FAQ。接手人正式接手工作后,在执行过程中,根据自己对工作的理解,可以对交接人交接过来的文档、资料等内容进行修订,并标注好修订版本和修改的内容。

交接工作内容包括什么

1、日常工作,即现有业务的覆盖面,每个业务的现状;也指常规要做的内容有哪些,也可以把他理解为绩效指标或关键任务项。

2、待办工作,现在手头上的工作开展的进度,接下来要做的工作现状、后续工作推进计划、正在推进中的工作事项,推进中存在的问题及后续注意事项。

3、工作资料,包括规章制度、条文,也包括历年原始文件资料等。另附相关资料、文档转交的介绍和说明;这里建议将所有资料做交接,不公限于相关资料,且copy或是传送给乙方工作接手人。

4、具体工作办理方法。相关工作的流程、时间节点、联系人,注意事项。建议理一份自己工作的作业指导书或操作手册。或者有一份工作推进中常见的FAQ。有了这些,工作交接非常全面、细致,有哪些工作及工作如何来做就有书面的依据了。

5、扶上马送一程,除了做好工作内容的交接之外,还应将接手人介绍给原相关的接口人;另外,针对一些敏感的信息,可以单独发邮件给接手人留存,如微信公众号、微博、公共邮箱、公共QQ等的账号密码等。在正式引荐完成后,则原来由交接人主要跟进的工作,均转交由接手人跟进执行,由交接人辅助即可。

6、修订工作作业指书或操作手册及FAQ。接手人正式接手工作后,在执行过程中,根据自己对工作的理解,可以对交接人交接过来的文档、资料等内容进行修订,并标注好修订版本和修改的内容。

交接工作内容包括什么

工作交接注意事项

1、当面交接

交接工作最重要的一点就是“当面交接”,把贵重物品逐一列成清单,并告知存放的位置和状态,以便你接替工作后能顺利完成。

2、仔细检查

不管是文字性的工作还是操作性的`工作,交接工作时一定要仔仔细细核对以前的资料、仪器、设备、材料等有没有损坏和报废的,是否在有效期范围,生物材料注意状态是否正常。总之,有关的一切都要检查正常之后才能交接。如有异常,及时上报领导!

3、同事提前离开

如果你没有见到之前的同事,或者交接工作时他已离开,这时,你来工作岗位后要做的第一件事,就是检查物品,步骤二已经提到,不管有无前同事,你都要将报废的、过期的物品告知领导,否则日后吃亏的就是你!

4、咨询前同事

如果你来之后发现对有些仪器设备的操作不是很懂,一定要耐心咨询前同事的用法用量,哪怕他很冷淡,也要拜托人家,千万不要自作聪明,造成事故没人负责!

5、手把手操作

如果你的工作性质与仪器设备密切相关,再如果你的前同事还未离开岗位,你一定要让对方手把手给你演示一遍仪器设备的操作,或者文件的相关操作,这样你就能更快速的进入到工作状态!

6、谦虚谨慎

最后要注意的就是,一定要谦虚的询问前同事最近有没有未完成的项目、任务或者计划等,在此岗位工作有没有需注意的人和事。反正,关于此岗位的一切信息都要探查清楚!

交接工作一定要仔细谨慎,小编第一次交接工作就遇到了大麻烦,希望这篇文章能给自己警示,也能帮到广大网友!

本文关键词:工作交接的基本内容和交接手续,交接工作内容包括什么方面,交接工作内容有哪些,工作交接包含哪些内容,工作交接包括哪些。这就是关于《工作交接是什么意思,交接工作内容包括什么(原来“进程间通信”是这么回事)》的所有内容,希望对您能有所帮助!


声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,谢谢。

上一篇: 没有过不去的坎,没有过不去的坎的励志句子摘抄(没有过不去的坎的励志句子摘抄大全)

下一篇: 白羊女是哪个星座男最爱,白羊女最爱的星座男(天秤男迷恋白羊女的程度)



猜你感兴趣

推荐阅读

网站内容来自网络,如有侵权请联系我们,立即删除! | 软文发布 | 粤ICP备2021106084号