1 поколение: Создание програмируемых компьютеров на электронных лампах. 2 поколение: В разы уменьшены габариты ЭВМ, в основе конструкции лежат транзисторы 3 поколение: Создание ЭВМ на миниатюрных интегральных схемах, которые находяться на кристале кремния. Опять невероятно изменились габариты. Один такой кристал мог заменить 30-тонный компьютер на эл. лампах 4 поколение: Создание ЭВМ на больших интегральных схемах. Таким образом достигнута максимальная из поколений производительность, и самые маленькие габариты
Совершенно нет, рассмотрим такую вот программу:К примеру программа должна определять, является ли число положительным, предположим что имеется такая функция:
boolian isNumberMoreThenZero(integer num) //функция булевая, т.е. //возращает одно из значений - true/false, принемает на вход число { boolian result; //есть переменная хранящая результат, //или ответ если пожелаете
result = false; //по умолчанию он равен false
if (num <= 0) //тут к примеру ОШИБКА, //проверяем является ли число больше либо равно 0 //(мы допустили ошибку и указали меньше)
{ result = true; //если да, то число положительное и ответ true } return result; //вернуть значение }
Если на входных данных будет 0 - он является положительным числом, программа выведет true - что является правильным ответом.Но если мы введем любое отрицательное число, то ответ так же будет true - что является ошибкой.Подай на вход мы положительное число, то программа выведет false - и это ошибка. Вывод такой:Функция функционирует правильно в часных случаях, к примеру как с 0, однако в других случаях она не вывести правельный ответ.Проще говоря, просто подтверждаем ответ на ваш вопрос - "НЕТ, программа не будет правильно функционировать в целом, а лишь в частных случаях".Производный вопрос - а как этого избежать? ответ: покрыть код программы и все её логические блоки - тестами.
2 поколение: В разы уменьшены габариты ЭВМ, в основе конструкции лежат транзисторы
3 поколение: Создание ЭВМ на миниатюрных интегральных схемах, которые находяться на кристале кремния. Опять невероятно изменились габариты. Один такой кристал мог заменить 30-тонный компьютер на эл. лампах
4 поколение: Создание ЭВМ на больших интегральных схемах. Таким образом достигнута максимальная из поколений производительность, и самые маленькие габариты
boolian isNumberMoreThenZero(integer num) //функция булевая, т.е.
//возращает одно из значений - true/false, принемает на вход число
{
boolian result; //есть переменная хранящая результат,
//или ответ если пожелаете
result = false; //по умолчанию он равен false
if (num <= 0) //тут к примеру ОШИБКА,
//проверяем является ли число больше либо равно 0
//(мы допустили ошибку и указали меньше)
{
result = true; //если да, то число положительное и ответ true
}
return result; //вернуть значение
}
Если на входных данных будет 0 - он является положительным числом, программа выведет true - что является правильным ответом.Но если мы введем любое отрицательное число, то ответ так же будет true - что является ошибкой.Подай на вход мы положительное число, то программа выведет false - и это ошибка.
Вывод такой:Функция функционирует правильно в часных случаях, к примеру как с 0, однако в других случаях она не вывести правельный ответ.Проще говоря, просто подтверждаем ответ на ваш вопрос - "НЕТ, программа не будет правильно функционировать в целом, а лишь в частных случаях".Производный вопрос - а как этого избежать? ответ: покрыть код программы и все её логические блоки - тестами.