rtsIDr (1158390), страница 21

Файл №1158390 rtsIDr (Раздаточные материалы) 21 страницаrtsIDr (1158390) страница 212019-09-18СтудИзба
Просмтор этого файла доступен только зарегистрированным пользователям. Но у нас супер быстрая регистрация: достаточно только электронной почты!

Текст из файла (страница 21)

Замечание 2. Функции dvm_fread и dvm_fwrite могут быть использованы для чтения и записи распределённых массивов. Для этого BufferPtr должен указывать на заголовок распределённого массива. В этом случае размер элемента массива полагается равным не Size, а *TypeSizePtr (тому значению, которое было задано при создании массива с помощью функции crtda_). Число читаемых или записываемых элементов полагается равным минимуму между Count*Size/(*TypeSizePtr) и числом элементов распределённого массива (см. также описание функций dvm_dfread и dvm_dfwrite в п.п.16.2 и 16.3).

Распределённый массив, задаваемый при обращении к функциям dvm_fread и dvm_fwrite, должен быть отображён в процессорную систему, каждый элемент которой обязан принадлежать текущей процессорной системе.

Замечание 3. Доступ к стандартному потоку stdaux (stdprn) через указатель DVMSTDAUX (DVMSTDPRN) возможен лишь при компиляции системы поддержки с определённой переменной компиляции _DVM_STDAUX_ (_DVM_STDPRN_).

16.1.2Функции ввода/вывода нижнего уровня

BORLAND-C & MICROSOFT-C & PORTLAND GROUP-C:

int

dvm_close

(DVMHANDLE *HandlePtr);

int

dvm_fstat

(DVMHANDLE *HandlePtr, struct stat *BufferPtr);

long

dvm_lseek

(DVMHANDLE *HandlePtr, long Offset,int Origin);

DVMHANDLE

*dvm_open

(const char *FileNamePtr, int OFlag, int PMode);

int

dvm_read

(DVMHANDLE *HandlePtr, char *BufferPtr,
unsigned int Count);

int

dvm_write

(DVMHANDLE *HandlePtr, const void *BufferPtr,
unsigned int Count);

Для доступа к стандартным потокам ввода/вывода в функциях ввода/вывода нижнего уровня могут использоваться следующие указатели:

DVMSTREAM0

стандартный ввод;

DVMSTREAM1

стандартный вывод;

DVMSTREAM2

стандартный вывод сообщений об ошибках;

DVMSTREAM3

стандартный последовательный порт;

DVMSTREAM4

стандартное устройство печати.

16.1.3Операции над каталогами и файлами

ANSI:

int

dvm_remove

(const char *FileNamePtr);

int

dvm_rename

(const char *OldNamePtr, const char *NewNamePtr);

char

*dvm_tmpnam

(char *FileNamePtr);

BORLAND-C & MICROSOFT-C & PORTLAND GROUP-C:

int

dvm_access

(const char *FileNamePtr, int Mode);

int

dvm_stat

(const char *FileName, struct stat *BufferPtr);

int

dvm_unlink

(const char *FileNamePtr);

Замечание. Функции ввода/вывода нижнего уровня, а также функции dvm_access и dvm_stat доступны пользовательской программе лишь в том случае, если библиотека используемого компилятора языка C содержит соответствующие им функции. Для использования функций ввода/вывода нижнего уровня система поддержки и программа пользователя должны быть скомпилированы с определённой переменной компиляции _LLIO_ . Подключение функции dvm_access (dvm_stat) достигается компиляцией с определённой переменной _ACCESS_FUN_ (_STRUCT_STAT_).

При работе в среде WINDOWS+MPI+MICROSOFT_C (WINDOWS+MICROSOFT_C) подключение всех перечисленных выше функций осуществляется компиляцией системы поддержки и программы пользователя с определённой переменной компиляции _WIN_MPI_ (_DVM_MSC_).

16.2Чтение файла в подмассив распределенного массива

long DisArrRead (

DVMFILE
long
long
long
long

*StreamPtr,
ArrayHeader[],
InitIndexArray[],
LastIndexArray[],
StepArray[] );

*StreamPtr

дескриптор файла ввода.

ArrayHeader

заголовок распределённого массива.

InitIndexArray

массив, в i-м элементе которого задается начальное значение индексной переменной (i+1)-го измерения распределённого массива.

LastIndexArray

массив, в i-м элементе которого задается конечное значение индексной переменной (i+1)-го измерения распределённого массива.

StepArray

массив, в i-м элементе которого задается значение шага для индексной переменной (i+1)-го измерения распределённого массива.

Функция DisArrRead осуществляет чтение подмассива распределённого массива, определяемого множеством индексных кортежей вида

{ I1  M1: I1 = InitIndexArray[0]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .

{ Ik  Mk: Ik = InitIndexArray[k-1]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
{ In  Mn: In = InitIndexArray[n-1]

+ StepArray[0] *P1 } 
. . . . . . . . . . . . . . . . . .
+ StepArray[k-1]*Pk } 
. . . . . . .. . . . . . . . . . . .
+ StepArray[n-1]*Pn }
,

где:

символ прямого произведения множеств;

n

размерность распределённого массива;

Ik

индексная переменная k-го измерения распределённого массива.

0 ≤ Pk ≤ (LastIndexArray[k-1]  InitIndexArray[k-1]  1) / StepArray[k-1].

Читаемый подмассив является блоком (разреженным, если хотя бы один StepArray[i] не равен единице).

Чтение происходит до исчерпания читаемых элементов по принятой в языке C дисциплине непрерывного размещения массивов в памяти: правый индекс меняется быстрее левого. Если начальное значение индекса для какого-либо измерения читаемого массива задано большим или равным его конечному значению, то индекс по этому измерению изменяться при копировании не будет. Отметим, что конечное значение индекса для любого измерения рассматривается системой поддержки как минимум между заданным в параметрах обращения к функции и размером массива по этому измерению минус 1.

Для полного охвата измерения читаемого массива без использования опроса размера объекта по заданному измерению (см.п.17.2) система поддержки предусматривает задание начального значения индекса равным -1. В этом случае начальное значение индекса будет считаться равным нулю, шаг  единице, а конечное значение  размеру массива по рассматриваемому измерению минус 1.

Функция возвращает число прочитанных элементов.

long dvm_dfread (

long
long
DVMFILE

ArrayHeader[],
Count,
*StreamPtr );

ArrayHeader

заголовок распределённого массива.

Count

число читаемых элементов.

*StreamPtr

дескриптор файла ввода.

Функция dvm_dfread осуществляет чтение первых по размещению в памяти Count элементов распределённого массива. При положительном Count число читаемых элементов полагается равным минимуму значения Count и числа элементов распределённого массива. При неположительном значении Count производится чтение всего распределённого массива.

Возвращается число прочитанных элементов.

16.3Запись подмассива распределенного массива в файл

long DisArrWrite (

DVMFILE
long
long
long
long

*StreamPtr,
ArrayHeader[],
InitIndexArray[],
LastIndexArray[],
StepArray[] );

*StreamPtr

дескриптор файла вывода.

ArrayHeader

заголовок распределённого массива.

InitIndexArray

массив, в i-м элементе которого задается начальное значение индексной переменной (i+1)-го измерения распределённого массива.

LastIndexArray

массив, в i-м элементе которого задается конечное значение индексной переменной (i+1)-го измерения распределённого массива.

StepArray

массив, в i-м элементе которого задается значение шага для индексной переменной (i+1)-го измерения распределённого массива.

Функция DisArrWrite осуществляет запись блока распределённого массива, определяемого множеством индексных кортежей вида

{ I1  M1: I1 = InitIndexArray[0]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
{ Ik  Mk: Ik = InitIndexArray[k-1]
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
{ In  Mn: In = InitIndexArray[n-1]

+ StepArray[0] *P1 } 
. . . . . . . . . . . . . . . . . .
+ StepArray[k-1]*Pk } 
. . . . . . . . . . . . . . . . . .

+ StepArray[n-1]*Pn } ,

где:

символ прямого произведения множеств;

n

размерность распределённого массива;

Ik

индексная переменная k-го измерения распределённого массива.

0 ≤ Pk ≤ (LastIndexArray[k-1]  InitIndexArray[k-1]  1) / StepArray[k-1].

Характеристики

Список файлов учебной работы

Свежие статьи
Популярно сейчас
Почему делать на заказ в разы дороже, чем купить готовую учебную работу на СтудИзбе? Наши учебные работы продаются каждый год, тогда как большинство заказов выполняются с нуля. Найдите подходящий учебный материал на СтудИзбе!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
7031
Авторов
на СтудИзбе
260
Средний доход
с одного платного файла
Обучение Подробнее