Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: Связь двух программ по файлу данных  (Прочитано 13526 раз)
0 Пользователей и 2 Гостей смотрят эту тему.
eugrita
Помогающий

ru
Offline Offline

« : 12-01-2010 10:35 » 

(среда С++ Builder). (Интеграция технологических процессов)

Как автоматизировать 2 приложения, связанные по файлу данных?
Пусть программа2 должна создать файл dat.txt необходимый программе1
Например есть возможность запуска программы2 из исходной
(хэдер process.h , функции execl и т.п.). Однако при этом встает проблема
отслеживания лмбо конца работы программы2, либо конца записи в файл.
Проблема осложняется еще тем что вроде бы в стандартных флагах
открытия файлов fopen не предусмотрен эксклюзивный доступ и либо тогда
надо переписывать процедуры работы с файлами с использованием функций
ниэнего уровня open (возможно еще различающихся для разных ОС и реализаций С)
либо пойти на обмен межпроцессными сообщениями, что тоже не очень приятно.
Простейший тест в С++ Builder показал что при открытии файла c незавершенным
 процессом записи  по fopen (fln,"w")
попытка чтения по f=fopen (fln,"r")  действительно открывает файл
т.е f<> NULL однако операторы чтения не проходят (или читается мусор).
Итак , как лучше поступить
а)использовать приемы обмена сообщениями между приложениями
  или
б)все-таки пойти на замену процедур работы с файлом чтобы обеспечить эксклюзивный доступ

и то и другое по-моему недостаточно освещено в стандартной тезнике программирования
« Последнее редактирование: 12-01-2010 10:44 от eugrita » Записан
Sla
Команда клуба

ua
Offline Offline
Пол: Мужской

WWW
« Ответ #1 : 12-01-2010 10:40 » 

можно работать на семафорах
П2 создает файл .lock
пишет в файл
удаляет .lock

П1 смотрит наличие .lock
Если есть - ждет, нет - читает.
Записан

Мы все учились понемногу... Чему-нибудь и как-нибудь.
lag
Участник

ru
Offline Offline

« Ответ #2 : 12-01-2010 10:47 » 

а с чем связан обмен данными между программами именно через файл? почему не сокеты например?
Записан
lapulya
Молодой специалист

ru
Offline Offline

« Ответ #3 : 12-01-2010 10:53 » 

eugrita, стандартом не предусмотрена ни синхронизация потоков, ни синхронизация процессов. Все способи синхронизации доступны только через API платформы, все остальное гарантии не дает.
Записан

С уважением Lapulya
eugrita
Помогающий

ru
Offline Offline

« Ответ #4 : 12-01-2010 11:06 » 

К сожалению (в моем случае и страны Россия) я нахожусь в ситуации
когда нет единой команды разработчиков и единого управления.
Есть некий полуразвалившийся программный монстр, с которым надо работать да еще и не всегда на хороших компах. Может через сокеты и правильнее бы, да только свою прогу могу переделать, а разработчики других не будут.

ответ " работать на семафорах" Sla по-видимому самый простой и конструктивный.
Спасибо
« Последнее редактирование: 12-01-2010 11:08 от eugrita » Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #5 : 12-01-2010 11:08 » 

посмотрите в сторону popen() - никакие дополнительные файлы не нужны, насколько я помню, она не совсем стандартна, но тем не менее есть практически везде.
Записан
RXL
Технический
Администратор

Offline Offline
Пол: Мужской

WWW
« Ответ #6 : 12-01-2010 12:00 » 

Попробуй flock().

fopen();
flock(); // Поставить с ожиданием
fwrite() или fread();
flock(); // Снять
fclose();

Порылся в BCB6: странно - нет flock(). Есть fcntl.h, но нет fcntl().
« Последнее редактирование: 12-01-2010 12:20 от RXL » Записан

... мы преодолеваем эту трудность без синтеза распределенных прототипов. (с) Жуков М.С.
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #7 : 12-01-2010 13:13 » 

Попробуй flock().

fopen();
flock(); // Поставить с ожиданием
fwrite() или fread();
flock(); // Снять
fclose();

Порылся в BCB6: странно - нет flock(). Есть fcntl.h, но нет fcntl().
В windows есть LockFile()/UnlockFile(), правда совсем не портабельно.
Записан
eugrita
Помогающий

ru
Offline Offline

« Ответ #8 : 12-01-2010 14:04 » 

в BCB6 действительно нет flock зато есть lock и unlock,
кроме того есть VCL-ные приемы работы с файлами FileOpen, FileClose,FileRead,FileWrite
в FileOpen есть mode fmShareExclusive = 0x10;
Пробую сделать блокировку  через lock так:
Код:
void __fastcall TForm1::b0Click(TObject *Sender)
{
  FILE * f1=fopen(fln,"w");
  int nf=_fileno(f1);
  lock(nf,0L,1000);
  for(int i=0;i<20;i++) {
     fprintf(f1,"%i ",i);
     Application->ProcessMessages();
     Sleep(500);
  }
  unlock(nf,0L,1000);
  fclose (f1);
  L1->Caption="Запись закончена";
}
данная функция доходит до конца
но когда запускается 2-й процесс (доступен запуск по кнопке в силу Application->ProcessMessages()Ага
эта же функция не доходит до конца и подвисает!!!
« Последнее редактирование: 12-01-2010 20:20 от Вад » Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #9 : 12-01-2010 14:51 » 

а второй процесс что, запускается 20-ть раз?
на чём именно подвисает?
Записан
eugrita
Помогающий

ru
Offline Offline

« Ответ #10 : 12-01-2010 15:16 » 

Нет. Запустил эту функцию (выполняется не менее 30 сек)
и сразу после запуска один раз нажав на кнопку запустил 2-ю функцию.
После чего все висит
Записан
darkelf
Молодой специалист

ua
Offline Offline

« Ответ #11 : 12-01-2010 15:32 » new

Посмотрите в отладчике/путём печати диагностических сообщений на какой именно функции внутри void __fastcall TForm1::b0Click(TObject *Sender) всё подвисает. Как выглядит функция  Application->ProcessMessages(), как выглядит читающая задача, если это отдельная задача?
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines