Відомостям, пора на Годіл 5
опрацювання текстових даних
ийняті, загальное
11. Текстові документ
1 fого обекти
и затора захиа
ъ матеріалам.
saxacus Herpas.
Фрава 1 Словничок
Заповни протушені слова в реченнях, використовуючи малюнок
СБ'ЄКТИ
TEKCTOBU POLE COP
ТЕкстовий РЕДАКТОР
ТЕКСТОВИЙ РЕДАКТОР
ТЕКСТОВИЙ ДОКУМЕНТ
ТЕКСТОВИЙ РЕДАКТОР
ТЕКСТОВИЙ ДОКУМЕНТ
ТЕКСТОВИЙ ДОКУМЕНТ
документ.
який складається з текстових об'єктів (символів, слів, абзаців)
та, можливо, інших об'єктів (графічних, мультимедійних тощо).
Для створення й опрацювання електронних текстових докумен-
тів використовують спеціальні програми (2)
а слово-розгадка
Для опрацювання документів, які міс-
тять лице звичайний текст, призначені (4)
Для роботи з документами, які містять,
крім тексту, й інші (5)
використовують (6)
25
Не совсем верно, но очень близко.
uses crt;
const nmax=100;
var a:array[1..nmax] of integer;
n,i,j,k:byte;
begin
clrscr;
repeat
write('Размер массива до ',nmax,' n=');
readln(n);
until n in [1..nmax];
writeln('Введите элементы массива:');
for i:=1 to n do
begin
write('a[',i,']=');
readln(a[i]);
end;
clrscr;
writeln('Массив:');
for i:=1 to n do
write(a[i]:4);
writeln;
writeln;
k:=0;
for i:=1 to n-1 do
for j:=i+1 to n do
if a[j]=a[i] then k:=k+1;
if k=1 then write('В массиве только 2 одинаковых элемента')
else write('В массиве не 2 одинаковых элемента');
readln
end.
Объяснение:
Объяснение:
Начну с того, что в программах на языке C# используются управляемые и неуправляемые объекты. Управляемые объекты без проблем удаляются сборщиком мусора. В то время, как неуправляемые объекты необходимо освобождать вручную.
В C# есть два освобождения ресурсов: через деструктор или через метод Dispose, который определен в интерфейсе IDisposable.
Деструктор вызывается автоматически во время удаления объекта сборщиком мусора, но момент его вызова определить невозможно, так как сборщик мусора запускается только при недостатке памяти. Таким образом, объекты могут находиться в памяти вплоть до завершения программы.
Метод Dispose вызывается программистом (использующим этот класс), когда объект больше не нужен. При этом подходе происходит немедленное освобождение ресурсов. Минус подхода - программист может попросту забыть вызвать метод Dispose.
В вашем коде приведен беспроигрышный вариант: в методе f происходит освобождение управляемых и неуправляемых ресурсов.
Код прокомментировал ниже. Параметр dd необходим, чтобы не освобождать управляемые ресурсы при вызове деструктора, так на момент его вызова мы не можем быть уверенными в их состоянии, что они до сих пор находятся в памяти.
namespace ConsoleApp17
{
public class A : IDisposable // Объявление класса, реализующего интерфейс IDisposable
{
private bool disposed = false; // Объект уничтожен?
public void Dispose()
{
GC.SuppressFinalize(this); // Запрещаем сборщику мусора вызывать деструктор при удалении объекта
f(true); // Вызываем метод освобождения неуправляемых и управляемых ресурсов
Console.WriteLine(" Call dispose ");
}
private void f(bool dd)
{
if (!this.disposed) // Если объект не уничтожен, то уничтожаем
{
if (dd) // Если true, то освобождаем также управляемые ресурсы
Console.WriteLine("Dispose managed resourse. GC.collect()");
// Освобождаем неуправляемые ресурсы
Console.WriteLine("Clean up unmanaged resources");
}
disposed = true; // Помечаем, что объект уничтожен
}
~A() // Деструктор
{
f(false); // Вызываем метод освобождения неуправляемых ресурсов
Console.WriteLine("Call destruktor");
}
}
class Program
{
static void Main(string[] args)
{
A ob = new A(); // Создание объекта
ob.Dispose(); // Уничтожение объекта
}
}
}