Лекции.Орг


Поиск:




Категории:

Астрономия
Биология
География
Другие языки
Интернет
Информатика
История
Культура
Литература
Логика
Математика
Медицина
Механика
Охрана труда
Педагогика
Политика
Право
Психология
Религия
Риторика
Социология
Спорт
Строительство
Технология
Транспорт
Физика
Философия
Финансы
Химия
Экология
Экономика
Электроника

 

 

 

 


Ошибки при написании программ




Создавая программу, даже опытный программист допускает ошибки. Все ошибки условно можно разделить на три группы: ошибки компиляции, выполнения и логики. Рассмотрим те ошибки, которые «ловит» Visual Basic.

Ошибки компиляции

Ошибки компиляции возникают тогда, когда Visual Basic не может интерпретировать введенный код. Это происходит, например, при неправильном вводе числа скобок, неправильном имени, неполной инструкции и т.д. Строка, в которой обнаружена ошибка (после того как нажата клавиша [Enter]), выделяется красным цветом, и на экране появляется диалоговое окно с сообщением о возможной ошибке (Рис. 2‑4).

Рис. 2‑4. Ошибка компиляции, обнаруженная при вводе:
не хватает круглой скобки

Другие ошибки компиляции выявляются сразу же после запуска программы. В этом случае предполагаемое местоположение ошибки выделяется синим цветом и на экране появляется диалоговое окно с сообщением об ошибке (Рис. 2‑5).

Рис. 2‑5. Ошибка компиляции, обнаруженная после запуска программы:
цикл For без своего завершения (Next)

Задание:

1. В файле Мои программы.xls в Модуле1 наберите программу СлучайныеЧисла, которая разыгрывает 10 случайных чисел и помещает их в первые 10 ячеек первого столбца:

Sub СлучайныеЧисла()

Dim СлучЧисло As Integer

For i = 1 To 10

СлучЧисло = Int (100 * Rnd())

Cells(i, 1).Value = СлучЧисло

Next i

MsgBox "Случайные числа разыграны!"

End Sub

2. Сгенерируйте описанные выше ошибки.

Ошибки выполнения

Возникают после успешной компиляции программы при её выполнении. Причинами таких ошибок могут быть:

§ несоответствие типов данных,

§ некорректность вычислений, например, деление на ноль или вычисление квадратного корня из отрицательного числа,

§ некорректность операций с файлами, например, удаление открытой рабочей книги, сохранение рабочей книги с именем открытого файла и т.д.

С ошибкой выполнения познакомимся на следующем примере. Для этого в Модуле2 наберите программу Обратное_число:

Sub ОбратноеЧисло()

Dim x As Double

Dim y As Double

x = CDbl (InputBox("Введите число:"))

y = 1/x

MsgBox "Обратное число:" & y

End Sub

и запустите её на выполнение (попутно обратите внимание на встроенную функцию InputBox). На экране появится диалоговое окно с запросом, – введите в него 0 и щелкните по кнопке ОК. Так как деление на ноль запрещено, VB отобразит окно с сообщением о номере ошибки и причине, её вызвавшей (Рис. 2‑6):

Рис. 2‑6. Ошибка выполнения: деление на ноль

Если щелкнуть по кнопке Debug (Отладка), то строка, в которой произошла ошибка, будет выделена желтым цветом и программа перейдет в режим прерывания. При наведении мышиного курсора на переменную х на экране появится всплывающая подсказка с текущим значением (Рис. 2‑7).

Щелкнув по кнопке Сброс на панели инструментов Стандарт (Рис. 2‑2), завершите выполнение программы.

Рис. 2‑7. Программа Обратное_число в режиме прерывания

Другим примером ошибки выполнения может служить программа УзнатьАвтора. Скопируйте её в книгу Мои программы.xls (в Модуль2), а книгу Мои таблицы.xls закройте. Теперь, при запуске этой программы, возникнет ошибка с кодом 9 – Индекс выходит за пределы допустимого диапазона (Рис. 2‑8). Эта ошибка возникает тогда, когда программа ссылается на несуществующий объект[3].

Рис. 2‑8. Ссылка на несуществующий объект Workbooks("Мои таблицы.xls")

Следующая программа работает корректно вне зависимости от того, открыта книга Мои таблицы.xls или нет:

Sub СсылкаНаКнигуПоИндексу()

'1. Объявляем переменные:

Dim Автор As String

Dim КолОткрытыхКниг As Integer

'2. Определяем количество открытых книг:

КолОткрытыхКниг = Workbooks.Count

'3. Ищем среди открытых книг книгу с именем Мои таблицы.xls:

For i = 1 To КолОткрытыхКниг

If Workbooks(i).Name = "Мои таблицы.xls" Then

Автор = Workbooks(i).Author

MsgBox "Автор этой книги: " & Автор

Exit Sub

End If

Next i

MsgBox "Книга Мои таблицы.xls среди открытых книг не найдена!"

End Sub

Задания:

1. В Модуле 2 введите программу СсылкаНаКнигуПоИндексу.

2. Протестируйте работу этой программы, когда книга Мои таблицы.xls открыта/закрыта.





Поделиться с друзьями:


Дата добавления: 2016-03-28; Мы поможем в написании ваших работ!; просмотров: 528 | Нарушение авторских прав


Поиск на сайте:

Лучшие изречения:

Надо любить жизнь больше, чем смысл жизни. © Федор Достоевский
==> читать все изречения...

2376 - | 2051 -


© 2015-2025 lektsii.org - Контакты - Последнее добавление

Ген: 0.01 с.