linux shell編程多線程和wait命令學習

http://blog.csdn.net/shuanghujushi/article/details/38186303

最近在使用shell做一些部署工作,在使用過程中,效率一直不高。想提高效率,經過分析發現,并不是所有操作都是需要串行的,一些操作是可以進行并行操作的。經過學習,shell里面也是可以進行多線程編程的,而且十分方便,同時,wait命令可以進行shell的多線程同步控制。下面是shell多線程和wait命令的一些學習體會。錯誤之處,還請大家指正。

一、啟動后臺子任務

? ? ? ? 在執行命令后加&操作符,表示將命令放在子shell中異步執行。可以達到多線程效果。如下,

[plain]?view plain?copy
  1. sleep?10?#等待10秒,再繼續下一操作??
  2. sleep?10?&?#當前shell不等待,后臺子shell等待??

二、wait命令介紹

? ? ? ? wait? [作業指示或進程號]

? ? ? ? 1.等待作業號或者進程號制定的進程退出,返回最后一個作業或進程的退出狀態狀態。如果沒有制定參數,則等待所有子進程的退出,其退出狀態為0.

? ? ? ? 2.如果是shell中等待使用wait,則不會等待調用函數中子任務。在函數中使用wait,則只等待函數中啟動的后臺子任務。

? ? ? ? 3.在shell中使用wait命令,相當于高級語言里的多線程同步。


三、例子

1.使用wait等待所有子任務結束。

[plain]?view plain?copy
  1. #!/bin/bash??
  2. sleep?10?&??
  3. sleep?5&??
  4. wait?#等待10秒后,退出??

[plain]?view plain?copy
  1. #!/bin/bash??
  2. sleep?10?&??
  3. sleep?5&??
  4. wait?$!?#$!表示上個子進程的進程號,wait等待一個子進程,等待5秒后,退出??

2.在函數中使用wait

[plain]?view plain?copy
  1. #!/bin/bash??
  2. source?~/.bashrc??
  3. ??
  4. fun(){??
  5. ????echo?"fun?is?begin.timeNum:$timeNum"??
  6. ????local?timeNum=$1??
  7. ????sleep?$timeNum?&??
  8. ????wait?#這個只等待wait前面sleep??
  9. ??????
  10. ????echo?"fun?is?end.timeNum:$timeNum"??
  11. }??
  12. ??
  13. fun?10?&??
  14. fun?20?&??
  15. ??
  16. wait?#如果fun里面沒有wait,則整個腳本立刻退出,不會等待fun里面的sleep??
  17. echo?"all?is?ending"??

輸出結果為:

[plain]?view plain?copy
  1. fun?is?begin.timeNum:10??
  2. fun?is?begin.timeNum:20??
  3. fun?is?end.timeNum:10??
  4. fun?is?end.timeNum:20??
  5. all?is?ending??

從輸出結果,可以看到,整個腳本,等待了所有子任務的退出

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383854.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383854.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383854.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

#ifndef的作用

#ifndef是一條預編譯指令,就是說實在編譯的時候就會運行的指令。這個指令的作用很簡單,就是字面意思,如果沒有定義的話,但是卻經常使用。 因為使用這個可以避免一個源文件中兩次兩次包含同一個文件,或者一個工程文件中…

C++中結構體和類的區別和聯系

最主要的不同點就是結構體的訪問權限為public而且不能改變,而類的訪問權限可以改變,public的類和結構體基本一樣。 繼承上同樣表現出這樣的特點,struct是public繼承的,而class是private繼承的,繼承的子類的訪問權限取…

poll函數實現多路復用

http://blog.csdn.net/xluren/article/details/8206371 結構體pollfd struct pollfd { int fd; //file descriptor short event; //event of interest on fd short reven; //event that occurred on fd } 每一個pollfd結構體指定了一個被監視的文件描述符&…

抽象類(純虛函數、虛函數)和虛基類(虛繼承)

C多態 C的多態包括靜態多態和動態多態,靜態多態包括函數重載和泛型編程,動態多態包括虛函數。靜態多態實在編譯期間就能確定,動態多態實直在程序運行時才能確定。 抽象類 虛函數 在默認情況下對函數成員調用實施的是靜態連編,…

socket通信之最簡單的socket通信

http://blog.csdn.net/xluren/article/details/8043484#t15 套接字有三種類型 流式套接字(SOCK_STREAM),數據報套接字(SOCK_DGRAM)及原始套接字。 1.流式套接字提供面向連接、可靠的數據傳輸服務,數據按字節…

Java環境配置

自己安裝的時候按照一般的安裝方法先配置了JDK的環境,能夠成功顯示java版本后我在安裝eclipse的時候一直提示錯誤: Unfortunately the Java version needed to run Eclipse Installer couldn’t be found on your system. You need the following versio…

Linux I/O復用之select函數詳解

http://blog.csdn.net/y396397735/article/details/55004775 select函數的功能和調用順序 使用select函數時統一監視多個文件描述符的: 1、 是否存在套接字接收數據? 2、 無需阻塞傳輸數據的套接字有哪些? 3、 哪些套接字發生了異常? sel…

【Java學習筆記一】類和對象

面向對象程序設計的一個一個重要特點是:封裝性。 這里的封裝性有兩方面含義:一是將有關的數據和操作代碼封裝在一個對象中形成一個基本單位,各個對象之間相互獨立互不干擾,二是將對象中某些部分對外隱蔽,即隱蔽其內部細…

深入研究socket編程(3)——使用select函數編寫客戶端和服務器

http://blog.csdn.net/chenxun_2010/article/details/50488394 首先看原先《UNIX網絡編程——并發服務器&#xff08;TCP&#xff09;》的代碼&#xff0c;服務器代碼serv.c&#xff1a; [cpp] view plaincopy #include<stdio.h> #include<sys/types.h> #inclu…

Java簡單輸入輸出

不同于面向過程中有直接的輸入輸出函數&#xff0c;Java中的輸入輸出只能通過類來實現。 比較常見的一種是使用Scanner類 需要引入java.util包&#xff0c;即在文件開始加上語句import java.util.*;創建Scanner類對象&#xff0c;屬于標準輸入流。 例如Scanner snew Scanner(S…

Ubuntu安裝搭建Clion環境

嗚嗚嗚&#xff0c;太辛苦了&#xff0c;我終于安裝好這個了。 大概過程就是先在官網下載安裝包&#xff0c;然后解壓以后用終端移動到對應文件夾下運行clin.sh 運行完以后會有一些窗口&#xff0c;第一個選擇don’t~~&#xff0c;然后點擊ok 接受&#xff08;你可以不接受…

UNIX網絡編程——select函數的并發限制和 poll 函數應用舉例

http://blog.csdn.net/chenxun_2010/article/details/50489577 一、用select實現的并發服務器&#xff0c;能達到的并發數&#xff0c;受兩方面限制 1、一個進程能打開的最大文件描述符限制。這可以通過調整內核參數。可以通過ulimit -n來調整或者使用setrlimit函數設置&#x…

【Java學習筆記二】繼承和多態

與C不同的是&#xff0c;在Java中&#xff0c;一個類只能直接繼承另一個類&#xff0c;而不允許繼承多個類&#xff0c;這個新類稱為繼承類、派生類或者子類&#xff0c;而被繼承的類稱為基類或者父類。 繼承類能夠繼承基類的群不屬性和行為。 面向對象程序設計的三大特點為&…

使用poll實現的io多路復用服務端和客戶端

http://blog.csdn.net/robertkun/article/details/52269313 參考&#xff1a;http://www.cnblogs.com/Anker/p/3261006.html 使用poll實現的io多路復用服務端和客戶端。 客戶端通過子進程創建多個客戶端連接。 客戶端每隔1秒向服務端發送一個時間戳&#xff0c; 服務端接收到時…

【Java學習筆記三】抽象類與接口

對象的類型轉換分為自動轉換和強制轉換兩種 派生類向基類轉換是自動轉換&#xff0c;因為派生類中包含基類基類向派生類的轉換是強制轉換 強制類型轉換是通過在轉換對象前面使用圓括號運算符來實現&#xff0c;圓括號內為要轉換的目標類型&#xff0c;格式為&#xff1a; (&…

Epoll 的tcp通信代碼(服務器+客戶端)

http://blog.csdn.net/libinbin_1014/article/details/50096187 Epoll 的tcp通信代碼&#xff08;服務器客戶端&#xff09; /* gcc -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS64 -I${ORACLE_HOME}/rdbms/public -I${ORACLE_HOME}/rdbms/demo -L${ORACLE_HOME}/lib -lclntsh …

【Java學習筆記四】Java中的包

包的聲明和引入&#xff1a;在Java語言系統中&#xff0c;Java編譯器為每一個類生成一個字節碼文件&#xff08;.class&#xff09;&#xff0c;為了對類文件進行分層和按用途分類管理&#xff0c;同時也為了解決相同類名的文件沖突的問題&#xff0c;Java提供了包機制來管理類…

Linux系統編程——線程池

http://blog.csdn.net/tennysonsky/article/details/46490099# 線程池基本原理 在傳統服務器結構中&#xff0c;常是有一個總的監聽線程監聽有沒有新的用戶連接服務器&#xff0c;每當有一個新的用戶進入&#xff0c;服務器就開啟一個新的線程用戶處理這 個用戶的數據包。這個線…

【Java學習筆記五】Java異常處理

異常通常分為三類&#xff1a; 程序可控制的異常&#xff1a;一般是可預見的錯誤&#xff0c;不是致命的。例如&#xff1a;除數為0&#xff0c;數組下標越界。程序不可控制的的異常&#xff1a;這種異常往往是致命的&#xff0c;但是系統可以預見的。例如&#xff1a;系統棧溢…

【C++學習筆記一】C++類和對象詳解

類定義是以關鍵字class開頭&#xff0c;后面跟類的名稱。主體是包含在一對花括號中。類定義后必須跟著一個分號或一個聲明列表。 類的對象的公共數據成員可以使用直接成員訪問運算符.來訪問。需要注意的是&#xff0c;私有的成員和受保護的成員不能直接使用成員訪問運算符來訪…