69293

Командний інтерфейс користувача

Лекция

Информатика, кибернетика и программирование

Командний інтерпретатор запускають щоразу, коли користувач реєструється у системі із термінала, при цьому стандартним вхідним і вихідним пристроєм для інтерпретатора і запущених за його допомогою програм є цей термінал.

Украинкский

2014-10-02

33 KB

1 чел.

Лекція № 20

Тема: Командний інтерфейс користувача

План

  1.  Принципи роботи командного інтерпретатора
  2.  Переспрямування потоків введення-виведення
  3.  Використання каналів

Принципи роботи командного інтерпретатора

Основним завданням командного інтерпретатора є підтримка  інтерактивної роботи користувача, що взаємодіє із системою через термінал.

В UNIX-системах командний інтерпретатор називають оболонкою (shell). Розроблено багато версій інтерпретаторів, серед них sh (вихідний варіант), csh (C-shell) і bash. Інтерпретатор bash входить у стандартну поставку більшості дистрибутивів Linux. Системи лінії Windows XP включають спеціалізований інтерпретатор cmd, який використовують під час роботи в режимі консолі. Роботу інтерпретатора буде розглянуто на прикладі bash [26].

Командний інтерпретатор запускають щоразу, коли користувач реєструється у системі із термінала, при цьому стандартним вхідним і вихідним пристроєм для інтерпретатора і запущених за його допомогою програм є цей термінал. Під час запуску зчитують конфігураційні файли і виконують визначені в них дії із підготовки середовища для цього користувача.

Під час роботи інтерпретатор очікує на введення даних користувача, відображаючи підказку (наприклад, знак долара). Після отримання даних користувача (які формують командний рядок) він інтерпретує їх і виконує деякі дії. Найчастіше вони зводяться до виконання програми, для чого інтерпретатор створює процес, завантажує в нього програмний код і очікує його завершення (відповідно до технології fork+exec). Наведемо приклад.

$ cat myfile.txt вміст файла myfile.txt $    ... очікування введення

Унаслідок виконання цього командного рядка буде створено новий процес, куди буде завантажено код утиліти cat, параметром якої є ім'я файла. Утиліта зчитує цей файл і відображає його на стандартний вивід. Після завершення виконання утиліти інтерпретатор подає підказку і очікує введення наступного командного рядка.

Процес може бути запущений асинхронно, для чого наприкінці командного рядка потрібно задати символ &. Після цього підказка видається негайно, а процес продовжує своє виконання у фоновому режимі.

$ updatedb &

$ ... очікування введення, updatedb продовжує виконання

Тут утиліта updatedb обновлює базу, що містить імена всіх файлів на файловій системі (для наступного пошуку потрібних імен за допомогою утиліти locate), що є тривалою операцією, яка не потребує втручання користувача. Внаслідок запуску ця утиліта починає виконання у фоновому режимі, а користувач може відразу вводити нові команди.

Набори команд інтерпретатора можуть зберігатися в командних файлах (такі інтерпретатори, як bash, дають можливість використати в них досить потужну мову програмування). Цей командний файл може бути виконаний за тими самими правилами, що і будь-який файл скрипта.

Переспрямування потоків введення-виведення

Важливою технологією, яку реалізують командні інтерпретатори, є переспрямування потоків введення-виведення. При цьому програма замість використання термінала для стандартного потоку введення і стандартного потоку виведення працює із файлом.

$ sort > out.txt $ sort < in.txt

Під час виконання таких команд результат виведення опиниться не на екрані, а у файлі out.txt, а введення буде виконано не з клавіатури, а з файла in.txt При цьому очікування введення із клавіатури не буде.

Можна переспрямовувати одночасно і потік введення, і потік виведення:

$ sort < in.txt > out.txt

У даному випадку програма зчитує дані з одного файла, обробляє їх і записує в інший файл.

Стандартний дескриптор, що відповідає файлу повідомлень про помилки stderr, при цьому не переспрямовують. Для його переспрямування використовують такий синтаксис:

$ sort 2> err.txt

Використання каналів

Кілька фільтрів можна об'єднувати для обробки даних за допомогою каналів, при цьому стандартний вивід одного процесу переспрямовують на стандартний ввід іншого:

$ grep linux * | sort

У цьому разі результати виконання утиліти дгер передаватимуться на стандартний ввід утиліті sort. Канали можуть об'єднувати будь-яку кількість процесів.

Ще один спосіб використання каналів зводиться до обміну даними між процесом і командним інтерпретатором, під час якого результати виконання процесу будуть підставлені в командний рядок інтерпретатора. Таку технологію називають командною підстановкою (command substitution), для цього командний рядок виклику застосування, результати виконання якого потрібно використати, беруть у зворотні лапки: ~виконуваний_файл параметри4.

$ grep linux 'cat fi1elist.txt"

У даному випадку файл filelist.txt містить список імен файлів, у яких потрібно зробити пошук. Внаслідок виконання утиліти cat список має видаватись на стандартний вивід, але замість цього його підставляють у командний рядок виклику утиліти grep.

Питання для самоконтролю:

  1.  Поняття командного інтерпретатора
  2.  Принципи роботи командного інтерпретатора
  3.  Переспрямування потоків введення-виведення
  4.  Використання каналів


 

А также другие работы, которые могут Вас заинтересовать

16387. Статистические функции MS Excel 216.5 KB
  Статистические функции MS Excel С использованием электронной таблицы произвести обработку данных помощью статистических функций. Даны сведения об учащихся класса включающие средний балл за четверть возраст год рождения и пол. Определить средний балл мальчиков долю
16388. Функции в Ms Excel 49 KB
  Лабораторная работа №2 Функции в Ms Excel В целом Microsoft Excel содержит около 1000 функций рабочего листа встроенных функций обеспечивающих возможность выполнения самых разнообразных вычислений. Все они в соответствии с характером вычислений делятся на 12 групп: матема...
16389. MS Excel 2007. Использование функций 147.14 KB
  MS Excel 2007. Использование функций IФункции в MS Excel. Мастер функций IIЗадание для самостоятельной работы 2.1.Математические функции 2.2.Статистические функции Функции в MS Excel. Мастер функций При проведении расчетов в электронных таблицах часто необходимо использо...
16390. МАТЕМАТИЧЕСКИЕ ФУНКЦИИ 47.24 KB
  Математические функции Математические функции используют при выполнении арифметических и тригонометрических вычислений округлении чисел и в некоторых других случаях. 1. Курсивом оформлены необязательные аргументы функций. 2. Вместо списка чисел раздел...
16391. Использование формул и функций в MS Excel.Создание и применение шаблона 14.2 KB
  Практическая работа №5. Тема: Использование формул и функций в MS Excel.Создание и применение шаблона. Цель: Освоить технологию работы с функциями программы MS Excel.Научиться решать прикладные задачи в MS Excel. 1Функция ПРОСМОТР – возвращает значение из строки из столбца ил
16392. Microsoft Office Excel 2007. Вычисления в Excel. Формулы и функции 70.5 KB
  Практическая работа №10 Microsoft Office Excel 2007. Вычисления в Excel. Формулы и функции Практическая часть Задание 1. Переименование ячеек и создание ссылок Создайте лист Excel Правая кнопка/Создать/Лист Microsoft Office Excel и назовите его по своему усмотрению. В данном листе переимену
16393. Использование EXCEL для работы с финансовыми функциями накопления и дисконтирования 179.64 KB
  ЛАБОРАТОРНАЯ РАБОТА № 10 Использование EXCEL для работы с финансовыми функциями накопления и дисконтирования Цель работы: изучить финансовые функции ПС БС ПЛТ. Теоретическая часть При работе с финансовыми функциями используются специальные фи
16394. Microsoft Excel 2007. Форматы ячеек, функции, работа с блоками 47 KB
  Практическая работа № 12Microsoft Excel 2007. Форматы ячеек функции работа с блоками Задание 1. Число формат ячейки Создайте новый документ Microsoft Excel. Первый лист файла переименуйте в Формат. Для этого выполните двойной клик на Лист1 введите новое название листа и нажмите Enter. ...
16395. Microsoft Excel. Графики функций 78.97 KB
  Практическая работа № 21 Тема: Microsoft Excel. Графики функций Цель: научиться строить графики функций в MS Excel. Задание 1 1. Запустить Microsoft Excel.Создать новый файл и сохранить его в своей папке дискz: под именем Ex2_№группы_фамилия. 2. Составить таблицу для вычисления следу...