Функции - Is functions
Название функции | VB 6[1][2] | VBA[3] | VBScript[4] | VB .NET | T-SQL |
---|---|---|---|---|---|
IsArray | да | да | да | да | Нет |
IsDate | да | да | да | да | да |
IsDBNull | Нет | Нет | Нет | да | Нет |
Пусто | да | да | да | Нет | Нет |
IsError | да | да | Нет | да | Нет |
Пропал, отсутствует | да | да | Нет | Нет | Нет |
Нет ничего | Нет | Нет | Нет | да | Нет |
Нулевой | да | да | да | Нет | да |
IsNumeric | да | да | да | да | да |
IsObject | да | да | да | Нет | Нет |
IsReference | Нет | Нет | Нет | да | Нет |
В Является
функции (также известен как данные информационные функции,[5] функции проверки данных,[6] или же функции тестирования данных[6]) - это набор функций в Microsoft Visual Basic 6, Visual Basic для приложений, VBScript, и Visual Basic .NET. Некоторые из них также представлены в Transact-SQL посредством .NET Framework Поставщик данных для Microsoft SQL Server.
Что делают функции
Это простые функции проверки данных и проверки типов данных. Функции проверки данных определяют, возможно ли преобразовать или принудительно преобразовать значение данных, указанное в качестве аргумента функции, к типу, подразумеваемому именем функции, и вернуть Булево
запись стоимости независимо от того, возможно это или нет. (Обратите внимание, что фактические функции преобразования данных, такие как Октябрь ()
выбрасывать исключения, если преобразование невозможно. Функции проверки позволяют проверить, бы сбой, и изменить поток управления программой в если заявление.) Истинный
указывает, что преобразование возможно, Ложь
указывает, что этого не будет. Аналогично функции проверки типов возвращают Булево
запись того, относится ли выражение аргумента к определенному типу.
В Transact-SQL функции возвращают ноль или единицу, а не Булево
значения Истинный
и Ложь
.
IsArray (имя)
- Эта функция определяет, является ли имя переменной, переданное в качестве аргумента, массивом. Обратите внимание, что неинициализированные массивы возвращают
Ложь
из этой функции в Visual Basic .NET.[7] В Visual Basic 6 массивы не являются ссылочными типами, и неинициализированный массив вернетИстинный
из этой функции, как из инициализированного массива.[8] IsDate (выражение)
- Эта функция определяет, можно ли преобразовать выражение, переданное в качестве аргумента, в переменную типа
Дата
, или уже имеет типДата
. Неинициализированные переменные которые относятся к типуДата
конечно, можно преобразовать, несмотря на то, что он не инициализирован, поэтому всегда будет возвращатьсяИстинный
для таких переменных.[9] Обратите внимание, что строки, которые помимо даты содержат день недели (например,«Сб, 12 октября 2010 г.»
) вернет результат ошибки.[10] В VBScript и Visual Basic .NET в процессе преобразования используются настройки языкового стандарта Microsoft Windows, что означает, что то, что может анализировать как дату в одной системе, настроенной на использование одного языкового стандарта, может не распознаваться как дата в другой системе, настроенной на используйте другую локаль.[11][12] IsDBNull (выражение)
- Эта функция определяет, оценивается ли выражение, переданное в качестве аргумента, как
System.DBNull.Value
.[9] Это эквивалентно Visual Basic 6Нулевой()
функция.[10] Обратите внимание, что невозможно напрямую сравнить выражение на равенство сSystem.DBNull
, потому что любое выражение формыx = DbNull
будет оцениватьDbNull
просто потому, что он содержит нуль.IsDBNull ()
единственный способ проверить равенствоSystem.DBNull
.[12] Пусто(выражение)
- Эта функция определяет, является ли выражение, переданное в качестве аргумента, неинициализированным вариантом. Обратите внимание, что неинициализированный вариант отличается от варианта, который был инициализирован для хранения
Ноль
.[13] Хотя функция принимает выражение, а не просто имя переменной, считается любое выражение, не являющееся просто именем переменной. нет быть неинициализированным вариантом.[11] Эта функция была доступна в Visual Basic 6, но была заменена в Visual Basic .NET наНет ничего ()
функция.[14] В VBScript, если назначен вариантНичего
, эта функция по-прежнему возвращаетЛожь
.[15] IsError (выражение)
- Эта функция в Visual Basic .NET определяет, является ли выражение, переданное в качестве аргумента, объектом исключения, то есть объектом
System.Exception
класс или один из его подклассов.[7] В Visual Basic 6 функция проверяет, является ли выражение вариантом со специальнымvbError
подтип.[16] Пропал, отсутствует(имя)
- Эта функция определяет, является ли имя переменной, переданное в качестве аргумента, необязательным аргументом, который не был передан функции ее вызывающей стороной. Он возвращается
Истинный
только переменной является вариант, который не был инициализирован. Эта функция существует только в Visual Basic 6. В Visual Basic .NET необязательные параметры должны иметь инициализаторы по умолчанию, и функция больше не существует.[17] Нет ничего (выражение)
- Эта функция определяет, оценивается ли выражение, переданное в качестве аргумента, как
Ничего
.[9] Это простая библиотечная функция (состоящая всего из 4 CIL инструкции), которые могут быть записаны на Visual Basic как:[18][19]Эффект от этого - вернутьсяОбщественные Общий Функция Нет ничего(ByVal Выражение В качестве Объект) В качестве Булево Возвращаться (Выражение Является Ничего)Конец Функция
Ложь
для всех выражений значений (не ссылочных), потому что они будут заключены, как часть вызова функции, в объекты, которые по самой своей природе не будут нулевыми объектами.[18][19] Чтобы избежать такого поведения, можно использоватьЯВЛЯЕТСЯ
оператор для сравнения объекта напрямую сНичего
, письмовыражение
ЯВЛЯЕТСЯ Ничего
скорее, чемНет ничего (выражение)
. Компилятор вызовет ошибку времени компиляции, если сравниваемое выражение является значением, а не ссылочным типом, улавливая несоответствие типов во время компиляции, а не просто возвращаяЛожь
во время выполнения.[20] Строки - это ссылочные типы в Visual Basic .NET, поэтому они могут иметь значение NULL (в отличие от простых пустых строк нулевой длины). Для таких строк эта функция возвращаетИстинный
. (Для пустых строк возвращаетсяЛожь
.)[21][18] Нулевой(выражение)
- Эта функция определяет, оценивается ли выражение, переданное в качестве аргумента, как
Ноль
. Нулевое значение в любом подвыражении выражения приводит к тому, что все выражение считается нулевым.[15] Нулевой(выражение1,выражение2)
- Эта функция, принимающая два аргумента, специфична для Transact-SQL. В отличие от функции Visual Basic с таким именем, она не возвращает
Булево
, но вместо этого возвращает первое выражение, если оно неНОЛЬ
, иначе второе выражение.[22] Назначение функции - заменить любыеНОЛЬ
значения с другим, предположительно (но не обязательно) не-НОЛЬ
, ценить.[23] Это версия с двумя аргументамиКОЛЕСЦЕ ()
. IsNumeric (выражение)
- Эта функция определяет, можно ли преобразовать выражение, переданное в качестве аргумента, в число (будь то
короткий
,Целое число
,Длинный
,Одинокий
,Двойной
, или жеДесятичный
) из символа или строки или уже является числом.[24][25] В Transact-SQL строки можно преобразовать в числа, даже если они содержат символы, которых нельзя было ожидать в числах. Это потому, что Transact-SQL позволяет преобразование изДеньги
иsmallmoney
в числа, а денежные данные в строковой форме могут содержать символы индикатора валюты, такие как '£
' или же '$
символы.[26] То же самое верно и для VBScript, где любая строка, которая может быть преобразована в значение валюты в текущем языковом стандарте, считается числовой. Однако VBScript не считает дату и время числовыми.[27] IsObject (выражение)
- Эта функция определяет, является ли выражение, переданное в качестве аргумента, объектом, а не значением.[4] Это эквивалентно Visual Basic .NET.
IsReference ()
функция.[10] IsReference (выражение)
- Эта функция определяет, является ли выражение, переданное в качестве аргумента, ссылкой, а не значением.[24] Это эквивалентно Visual Basic 6
IsObject ()
функция.[10]
Рекомендации
Что поддерживает что
- ^ Маркус и Леви 2002, п. 750–751.
- ^ Роман, Петруша и Ломакс 2002b, pp. 394 et seq ..
- ^ Харрис 1999, п. 402–403.
- ^ а б Knittel 2002, п. 609.
- ^ Харрис 1999, п. 402.
- ^ а б Перри и Хеттихева 1998, п. 237.
- ^ а б Роман, Петруша и Ломакс 2002a, п. 69.
- ^ Роман, Петруша и Ломакс 2002b С. 394–395.
- ^ а б c Роман, Петруша и Ломакс 2002a, п. 86.
- ^ а б c d Петроутсос 2002, п. 115.
- ^ а б Ломакс, Чайлдс и Петруша 2003, п. 341.
- ^ а б Роман, Петруша и Ломакс 2002b, стр.395.
- ^ Харрис 1999, п. 416.
- ^ Уэйкфилд и Сондер 2001, п. 690.
- ^ а б Ломакс, Чайлдс и Петруша 2003, п. 342.
- ^ Роман, Петруша и Ломакс 2002b, стр.397.
- ^ Петруша 2006, п. 367 528 637.
- ^ а б c Петруша 2006, п. 438.
- ^ а б Стил 2005a.
- ^ Стил 2005b.
- ^ Роман, Петруша и Ломакс 2002b, стр.394.
- ^ Израиль и Джонс 2001, п. 476.
- ^ Цена 2003 г., п. 119.
- ^ а б Роман, Петруша и Ломакс 2002a, п. 87.
- ^ Петроутсос 2002, п. 114.
- ^ MSDN и 1.
- ^ Ломакс, Чайлдс и Петруша 2003, п. 343.
Используемые источники
- Харрис, Мэтью (1999). Самс научится программировать в Microsoft Excel 2000 за 21 день. Серия Sams Teach Yourself. Sams. ISBN 978-0-672-31543-5.CS1 maint: ref = harv (связь)
- Израиль, Марк; Джонс, Дж. Стивен (2001). MCSE: руководство по проектированию SQL Server 2000. Серия руководств по сертификации. Джон Уайли и сыновья. ISBN 978-0-7821-2942-7.CS1 maint: ref = harv (связь)
- Книттель, Брайан (2002). «Справочник по VBScript». Windows XP под капотом. Que Publishing. ISBN 978-0-7897-2733-6.CS1 maint: ref = harv (связь)
- Ломакс, Пол; Чайлдс, Мэтт; Петруша, Рональд (2003). Вкратце о VBScript. В двух словах (2-е изд.). O'Reilly Media, Inc. ISBN 978-0-596-00488-0.CS1 maint: ref = harv (связь)
- Маркус, Уильям; Леви, Алекс (2002). Программирование на Visual Basic 6. Тата МакГроу-Хилл. ISBN 978-0-07-040290-4.CS1 maint: ref = harv (связь)
- Перри, Грег М .; Хеттихева, Санджая (1998). Самс научится Visual Basic 6 за 24 часа. Научитесь за 24 часа (2-е изд.). Самс Паблишинг. ISBN 978-0-672-31533-6.CS1 maint: ref = harv (связь)
- Петроутсос, Евангелос (2002). Освоение Visual Basic.NET. Освоение серии. Джон Уайли и сыновья. ISBN 978-0-7821-2877-2.CS1 maint: ref = harv (связь)
- Петруша, Рональд (2006). Visual Basic 2005: полный справочник. McGraw-Hill Professional. ISBN 978-0-07-226033-5.CS1 maint: ref = harv (связь)
- Цена, Джейсон (2003). Освоение программирования баз данных на C #. Джон Уайли и сыновья. ISBN 978-0-7821-4183-2.CS1 maint: ref = harv (связь)
- Роман, Стивен; Петруша, Рон; Ломакс, Пол (2002a). Карманный справочник по языку VB.NET. O'Reilly Media, Inc. ISBN 978-0-596-00428-6.CS1 maint: ref = harv (связь)
- Роман, Стивен; Петруша, Рон; Ломакс, Пол (2002b). В двух словах о языке VB.NET. В двух словах (2-е изд.). O'Reilly Media, Inc. ISBN 978-0-596-00308-1.CS1 maint: ref = harv (связь)
- Стил, Патрик (31 мая 2005 г.). "Нет ничего? Определенно!". Блог Патрика Стила по .NET.CS1 maint: ref = harv (связь)
- Стил, Патрик (2005-06-03). "Избегать ничего ()". Блог Патрика Стила по .NET.CS1 maint: ref = harv (связь)
- Уэйкфилд, Кэмерон; Сондер, Хенк-Эверт (2001). Ли, Вэй Мэн (ред.). Руководство веб-разработчика VB.net. Syngress. ISBN 978-1-928994-48-0.CS1 maint: ref = harv (связь)
- "ISNUMERIC (Transact-SQL)". MSDN: SQL Server 2008: Справочник по Transact-SQL. Microsoft.
дальнейшее чтение
Электронная документация Microsoft
- "
IsArray
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
IsDate
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
IsDBNull
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
IsError
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
Нет ничего
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
IsNumeric
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft. - "
IsReference
метод ". MSDN: Библиотека классов .NET Framework:Microsoft.VisualBasic
пространство имен. Microsoft.