Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
11 / 10 / 7
Регистрация: 07.05.2013
Сообщений: 248

Очистка памяти после работы с Excel и Word

21.07.2018, 16:30. Показов 3879. Ответов 2

Студворк — интернет-сервис помощи студентам
Добрый день. Подскажите, пожалуйста, как решить проблему:

есть программа на C#, заполняет Excel и Word документы и открывает папку explorer'ом, после завершения работы алгоритма

проблема:
заметил, что очень много процессов остается после работы программы и сжирается много оперативки.
после нескольких десятков запусков из 3,5 гб доступных, остается около 1.5-2 гб
в рез-те периодически приходиться лезть в ДЗ и убивать процессы вручную (ошибка: невозможно открыть файл, т.к он занят другой программой)

вопрос:
как отследить все открытые процессы и убить их после выполнения?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.07.2018, 16:30
Ответы с готовыми решениями:

Очистка памяти после использования web browser
Здравствуйте, посоветуйте как сделать очистку памяти после загрузки сайта и закрытии webbrowser. И можно ли после dispose восстановить...

C# Исходник программы для работы с шаблонами Word/Excel
В приложении реализована работа с шаблонами Word и Excel, запись данных производится по средствам *.ini файла.

Нужны бесплатные библиотечки для работы с ms word and excel
Здравствуйте друзья! Прошу помочь подсказать библиотечки бесплатные (не Interop) для работы с офисом. У меня есть пару задач в которых...

2
 Аватар для Toros1992
899 / 554 / 275
Регистрация: 26.11.2015
Сообщений: 1,758
Записей в блоге: 2
21.07.2018, 16:57
Надо не процессы убивать, а память освобождать.скорее всего вы работаете с Interop.Office.
То есть вы в своей программе используете COM объекты. Для того, чтобы освободить память, нужно все ссылки, которые ссылаются на эти COM объекты сделать null. То есть перестали работать с workbook - обнулите ссылку на этот workbook. В самом конце надо закрыть excelapp и принудительно запустить сборку мусора
0
7 / 5 / 2
Регистрация: 06.10.2018
Сообщений: 183
09.10.2021, 07:07
здрасте а можно по подробнее про очистку памяти
я вот создаю документ так
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
 //Создаю новый Word.Application
            Microsoft.Office.Interop.Word.Application app = new Microsoft.Office.Interop.Word.Application();
 
            //Загружаю документ
            Microsoft.Office.Interop.Word.Document doc = null;
 
            object fileName = "C:\\MAMP\\db\\Forma\\PrikazForma.docx";
            object falseValue = false;
            object trueValue = true;
            object missing = Type.Missing;
 
            doc = app.Documents.Open(ref fileName, ref missing, ref trueValue,
            ref missing, ref missing, ref missing, ref missing, ref missing,
            ref missing, ref missing, ref missing, ref missing, ref missing,
            ref missing, ref missing, ref missing);
 
            //Очищаю параметры поиска
            app.Selection.Find.ClearFormatting();
            app.Selection.Find.Replacement.ClearFormatting();
 
            //Задаю параметры замены и выполняю замену.
            object Text = "Текст";
            object replaceWith = textBox7.Text;            
            object replace = 2;           
 
            app.Selection.Find.Execute(ref Text, ref missing, ref missing, ref missing,
            ref missing, ref missing, ref missing, ref missing, ref missing, ref replaceWith,
            ref replace, ref missing, ref missing, ref missing, ref missing);
 
            app.Selection.Find.ClearFormatting();
            app.Selection.Find.Replacement.ClearFormatting();
 
            //Открываю документ для просмотра.
            app.Visible = true;
как после этого очистить память ?
Спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.10.2021, 07:07
Помогаю со студенческими работами здесь

очистка памяти после использования calloc
мне нужна функция возвращающая массив символов(строку). написал функцию: char* return_string(int num) { char* str = (char*)...

Очистка памяти при завершении работы функции, как правильно возвращать значения?
Я вывел для себя 2 способа возвращать значения работы функции string Add(string a1, string a2) { string returnStr; returnStr +=...

Очистка базы данных после работы с программой
Добрый день! Столкнулся с проблемой при разработке программы и прошу Вас о помощи. Моя программа создает отчет об ошибках, после...

Программа для работы с Excel и Word документами
Подскажите, пожалуйста, какими инструментами лучше воспользоваться. Требуется написать программу, которая будет извлекать данные из excel и...

Посоветуйте тип проекта для работы с Word и Excel
Привет. Мне нужно написать следующую прогу: в экселе хранятся данные объектов - 1 строка - 1 объект. И в столбцах поля этого объекта. Ну...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru