Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Методичка для КР по ООП.doc
Скачиваний:
8
Добавлен:
18.04.2019
Размер:
2.47 Mб
Скачать

Рекомендации по недопущению блокировок потоков

  • Соблюдать определённый порядок при выделении ресурсов.

  • При освобождении выделенных ресурсов придерживаться обратного (reverse) порядка.

  • Минимизировать время неопределённого ожидания выделяемого ресурса.

  • Не захватывать ресурсы без необходимости и при первой возможности освобождать захваченные ресурсы.

  • Захватывать ресурс только в случае крайней необходимости.

  • В случае если ресурс не удаётся захватить, повторную попытку его захвата производить только после освобождения ранее захваченных ресурсов.

  • Максимально упрощать структуру задачи, решение которой требует захвата ресурсов. Чем проще задача – тем на меньший период времени захватывается ресурс.

Форма Класс Form

Форма является представлением окна, которое появляется в Windows приложении. Это класс, который можно использовать как основу для создания различных вариантов окошек: стандартных, инструментальных, всплывающих, borderless, диалоговых, and floating windows.

Создаётся “окно”, а класс называется формой – поскольку в окошке можно разместить элементы управления, обеспечивающие интерактивное взаимодействие приложения и пользователя (заполните форму, please).

Известна особая категория форм – формы (MDI) – формы с многодокументным интерфейсом (the multiple document interface).

Эти формы могут содержать другие формы, которые в этом случае называются MDI child forms. MDI форма создаётся после установки в true свойства IsMdiContainer.

Форма это класс, включающий свойства, методы и события.

Используя доступные в классе Формы свойства, можно определять внешний вид, размер, цвет, и особенности управления создаваемого окна или диалога.

Свойство Text позволяет специфицировать надпись of the window in the title bar.

Свойства Size и DesktopLocation позволяют определять размеры и положение окна в момент его появления на экране монитора.

Свойство ForeColor позволяет изменить предопределённый foreground color всех элементов управления, placed on the form.

Свойства FormBorderStyle, MinimizeBox, and MaximizeBox позволяют to control whether the form can be minimized, maximized, or resized во время выполнения приложения.

Методы класса обеспечивают управление формой.

Например, метод ShowDialog обеспечивает представление формы как модального dialog box.

Метод Show показывает форму как немодальный dialog box.

Метод SetDesktopLocation используется для позиционирования формы на поверхности desktop.

Форма предназначена для реализации интерфейса пользователя приложения. Содержит большой набор свойств, методов, событий для реализации различных вариантов пользовательского интерфейса. Является окном и наследует классу Control.

Это означает, что объект-представитель класса Form поддерживает механизмы управления, реализованные на основе обмена сообщениями Windows.

Структура сообщений и стандартные механизмы управления здесь не рассматриваются. Достаточно знать, что класс формы содержит объявление множества событий, для которых на основе стандартного интерфейса (сигнатуры) могут быть реализованы и легко подключены функции обработки событий.

Форма может использоваться как the starting class в приложении. При этом класс формы должен содержать точку входа – статический метод Main. В теле этого метода обычно размещается код, обеспечивающий создание и формирование внешнего вида формы.

Обычно заготовка формы “пишется” мастером. Пример кода простой заготовки окна прилагается. Форма настолько, что после некоторой медитации может быть воспроизведена вручную.

using System;

using System.Drawing;

using System.Collections;

using System.ComponentModel;

using System.Windows.Forms;

using System.Data;

namespace FormByWizard

{

/// <summary>

/// Summary description for Form1.

/// </summary>

public class Form1 : System.Windows.Forms.Form

{

/// <summary>

/// Required designer variable.

/// </summary>

private System.ComponentModel.Container components = null;

public Form1()

{

//

// Required for Windows Form Designer support

//

InitializeComponent();

//

// TODO: Add any constructor code after InitializeComponent call

//

}

/// <summary>

/// Clean up any resources being used.

/// </summary>

protected override void Dispose( bool disposing )

{

if( disposing )

{

if (components != null)

{

components.Dispose();

}

}

base.Dispose( disposing );

}

#region Windows Form Designer generated code

/// <summary>

/// Required method for Designer support - do not modify

/// the contents of this method with the code editor.

/// </summary>

private void InitializeComponent()

{

this.components = new System.ComponentModel.Container();

this.Size = new System.Drawing.Size(300,300);

this.Text = “Form1”;

}

#endregion

/// <summary>

/// The main entry Point for the application.

/// </summary>

[STAThread]

static void Main()

{

Application.Run(new Form1());

}

}

}

Главная проблема – метод InitializeComponent(). Это зона ответственности мастера приложений и не рекомендуется в этом методе делать что-либо самостоятельно. Во избежание потери всего того, что там может быть построено, поскольку мастер приложения может изменить содержимое тела метода в соответствии с изменениями внешнего вида приложения.

В этом классе куча всяких методов. Интересно посмотреть на внушительный список обработчиков событий.

Важна строчка в теле функции Main

Application.Run(new Form1());

В принципе эта строчка и отвечает за создание, “запуск” в потоке приложения и возможное появление на экране дисплея формы.