powered by simpleCommunicator - 2.0.51     © 2025 Programmizd 02
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / C# 8 preview: Nullable reference types
38 сообщений из 38, показаны все 2 страниц
C# 8 preview: Nullable reference types
    #39819995
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Либо я чего-то еще не понимаю, либо следует списать на возможную сырость превьюхи компилятора.
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
public class Foo
{
    public void Bar(string s)
    {
        Check<ArgumentNullException>(s != null);
        Baz(s); // CS8604 "Possible null reference argument bla-bla-bla"
    }

    public void Baz(string s)
    {
        Console.WriteLine(s);
    }

    private void Check<TException>(bool condition)
        where TException : Exception, new()
    {
        if (!condition)
        {
            throw new TException();
        }
    }
}


В таком случае получаю ворнинг, как в комменте написано.
Ворнинг уходит, если закомментить строку с вызовом
Код: c#
1.
// Check<ArgumentNullException>(s != null);


Уважаемые зрители, кто-нибудь уже втыкает в C# 8 настолько, чтобы объяснить мне чтоэтозанах?
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820045
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Немного поэкспериментировал, и такое впечатление, что после любого сравнения на null - не-null переменная начинает почему-то рассматриваться как nullable. Похоже, что это и вправду какой-то косяк компилятора.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820098
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Пройдись отладчиком по компилятору!
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820100
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatУважаемые зрители, кто-нибудь уже втыкает в C# 8 настолько, чтобы объяснить мне чтоэтозанах?

Тут же всё очевидно до безобразия.

Так как ты определил тип аргумента как string , а не string? , значит сравнение на null -- бессмысленно, и вызывает абсолютно закономерный warning.

Смысл от использования фичи Nullable reference types может быть достигнут только в одном единственном случае. Нужно переключить режим компилятора CS8604 с Warning на Error.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820101
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatНемного поэкспериментировал, и такое впечатление, что после любого сравнения на null - не-null переменная начинает почему-то рассматриваться как nullable. Похоже, что это и вправду какой-то косяк компилятора.

Может быть и косяк, но сравнение с null заведомо не-null аргумента должен вызывать вопросы.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820105
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttТак как ты определил тип аргумента как string , а не string? , значит сравнение на null -- бессмысленно, и вызывает абсолютно закономерный warning.
Позвольте заметить, неправда ваша. В-первых ворнинг вызывает не сравнение с null (я же специально в коде пометил, где именно ворнинг). Во-вторых, даже в доках указано, что использование nonnullable references не отменяет необходимости проверок на null во многих случаях. Компилятор осуществляет только статический анализ nonnullable, он никак не гарантирует, что метод не сможет быть вызван с null параметром и не вставляет никаких проверок на это. Например, метод может быть вызван вообще из другой сборки, которую собрали с опцией nullable disable, или вообще из какой-нибудь легаси сборки. Даже в случае если все и везде включено, то комилятор все равно всего лишь выдает ворнинг, который легко можно игнорировать. Т.е. по-любому для public методов доступных извне проверки делать надо.

Вот, в этом коде, например, все с т.з. компилятора будет ок:

Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
#nullable disable
Foo(null);
#nullable restore

public void Foo(string s)
{
    // ....
}
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820110
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatПозвольте заметить, неправда ваша. В-первых ворнинг вызывает не сравнение с null (я же специально в коде пометил, где именно ворнинг). Во-вторых, даже в доках указано, что использование nonnullable references не отменяет необходимости проверок на null во многих случаях. Компилятор осуществляет только статический анализ nonnullable, он никак не гарантирует, что метод не сможет быть вызван с null параметром и не вставляет никаких проверок на это.

Причина этому -- поддержка существующего кода. Верно. Вставлять проверки можно с помощью аннотаций и Fody, но в идеале писать весь проект по новым правилам полностью, а внешние библиотеки, которые еще не перешли на эти правила, использовать кастинг и проверки.


fkthatДаже в случае если все и везде включено, то комилятор все равно всего лишь выдает ворнинг, который легко можно игнорировать. Т.е. по-любому для public методов доступных извне проверки делать надо.

Именно, что основная цель -- отсутствие проверок, иначе ценности в этом нет. Кому нужны ворнинги? Нужны ошибки, которые требуется исправить, а не жалкие предупреждения, на которым всем плевать :)


fkthatВот, в этом коде, например, все с т.з. компилятора будет ок:

Это костыли :) Просто слишком поздно подсуетились. Но можно выиграть на новом проекте. Правда ещё сыровато.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820115
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttЭто костыли :) Просто слишком поздно подсуетились. Но можно выиграть на новом проекте. Правда ещё сыровато.

Можно проще, без прагмовских извратов:

Код: c#
1.
2.
3.
4.
5.
6.
Foo(null!); // <== "null-forgiven" operator "!"

public Foo(string s)
{
// ...
}



На самом деле, лучше бы они возродили свой "Code Contracts" . Статический анализ там, конечно, тормозил безбожно и работал очень далеко не всегда, но в остальном была шикарная штука.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820117
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatМожно проще, без прагмовских извратов:

Это противоречит концепции nullable-типов, которые уже есть. Вообще принят либеральный подход, основанный на предупреждениях компилятора. Хотя я считаю надо было поступать жёстче.


fkthatНа самом деле, лучше бы они возродили свой "Code Contracts" . Статический анализ там, конечно, тормозил безбожно и работал очень далеко не всегда, но в остальном была шикарная штука.

Да чёт как-то не взлетело. Я уже много лет пользую и насаждаю JetBrains.Annotations в проектах, от чего ошибок типа Null referenced exception мы получаем намного реже, чем с попытками огородиться проверками. Проверки максимум дают информацию, но не предупреждают проблемы.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820118
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthat,

Вот несколько самых примитивных примеров

Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
        [ContractAnnotation("s:null => true")]
        public static bool IsNullOrEmpty([CanBeNull] this string s)
        {
            return string.IsNullOrEmpty(s);
        }

        [ContractAnnotation("s:null => null; s:notnull => notnull")]
        public static string Limit([CanBeNull] this string s, int maxLength)
        {
            if (maxLength <= 0) throw new ArgumentOutOfRangeException(nameof(maxLength), ErrorMessages.TooLargeString);
            if (s == null) return null;
            return s.Length > maxLength ? s.Substring(0, maxLength) : s;
        }

        public static <#= type #> SumOrDefault([NotNull] this IEnumerable<<#= type #>> source, <#= type #> defaultValue = default)
        {
            return source.DefaultIfEmpty(defaultValue).Sum();
        }
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820139
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatНа самом деле, лучше бы они возродили свой "Code Contracts" . Статический анализ там, конечно, тормозил безбожно и работал очень далеко не всегда, но в остальном была шикарная штука.
Ну, судя по референссоурсу , у себя внутри фреймворка они его и сейчас вполне используют - видимо, особо никакого возрождения и не требуется.
А вообще, по моему скромному, сабж - странная штука. Какая-то неуклюжая попытка что-то сделать так, как надо было делать ровно наоборот: non-nullable reference types с синтаксисом типа
Код: c#
1.
void Foo(string! s) {...}


(условно)
и соответствующей реакцией компилятора при попытке передать null-значение - аналогичное попытке передать null в
Код: c#
1.
void Foo(int n) {...}


А так - какая-то попытка размазать масло масляное (nullable reference types).
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820144
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сон Веры Павловны,

Под .NET Framework Code Contracts вроде бы до сих пор работает, но он уже прикрыт и не развивается. Для Core уже не работает. Тема там еще в том, что сам класс "System.Diagnostics.Contracts.Contract" везде есть, но без утилиты "CCRewrite" он бесполезен, т.к. это просто класс-заглушка - его вызовы служат только маркерами для инструментирования сборки после компиляции.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820216
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820261
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВ https://praeclarum.org/2018/12/17/nullable-reference-types.html
Да... Что-то мне все больше кажется, что вся эта шляпа с nullable-ами, что автары в МС затеяли, на самом деле, бесполезна чуть более, чем совсем.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820266
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Без существенного улучшения системы типов и введения монад c# обречен.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820312
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
В общем-то, ожидается, что в финальной версии компилятора эта фича все равно будет по-умолчанию отключена ("nullable disabled") и её можно будет только руками включить в свойствах проекта или внеся изменения в csproj файл. М.б. будет включена в шаблоны проектов для C#.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820313
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВБез существенного улучшения системы типов и введения монад c# обречен.

F#? Там вроде бы null-ов нет вообще.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820319
Siemargl
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttfkthatУважаемые зрители, кто-нибудь уже втыкает в C# 8 настолько, чтобы объяснить мне чтоэтозанах?

Тут же всё очевидно до безобразия.

Так как ты определил тип аргумента как string , а не string? , значит сравнение на null -- бессмысленно, и вызывает абсолютно закономерный warning..
...
Безотносительно C#8, вместо string отлично передается null, как объектный тип )

Попытка подстелить соломку ?
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820322
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVostt
Может быть и косяк, но сравнение с null заведомо не-null аргумента должен вызывать вопросы.
Ни каких вопросов :)
Код: c#
1.
2.
DateTime dateTime = default;
            var b = dateTime == null;
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820324
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatНемного поэкспериментировал, и такое впечатление, что после любого сравнения на null - не-null переменная начинает почему-то рассматриваться как nullable. Похоже, что это и вправду какой-то косяк компилятора.
Компилятор прошелся вверх и обнаружил, что переменной нигде не мог присвоиться null, а тут ты вруХ и сравниваешь. Он начинает считать, а вдруг ты прав....
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820325
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthat
F#? Там вроде бы null-ов нет вообще.
Немного есть.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820354
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВ,

Да, но они там вроде бы, типа как, "unsafe" контекст в C#. Я, впрочем, F# вообще не знаю - слышал просто краем уха.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820366
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
На то пошло, там нет циклов и переменных и вообще никаких рудиментов вроде классов, соответственно solid и всякие IoC в топку.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820376
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВНа то пошло, там нет циклов и переменных и вообще никаких рудиментов вроде классов, соответственно solid и всякие IoC в топку.

А это что?
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820388
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthat А это что?
Это аппендикс необходимый для совместимости с остальными .NET языками.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820397
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВНа то пошло, там нет циклов и переменных и вообще никаких рудиментов вроде классов, соответственно solid и всякие IoC в топку.
На то пошло, F# - это абсолютно совсем другая парадигма. Сравнивать его с C#.. ну, это примерно как C# сравнивать с SQL.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820488
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сон Веры ПавловныКакая-то неуклюжая попытка что-то сделать так, как надо было делать ровно наоборот: non-nullable reference types с синтаксисом типа
Код: c#
1.
void Foo(string! s) {...}



Это сильно противоречит имеющемся синтаксису nullable типов. Изначально мне тоже казалось, что non-nullable лучший вариант, и может уживаться с текущим кодом. Но нет. Библиотеки должны быть обратно совместимы.

А string! это совершенно новый тип, его протаскивать надо везде. В аргументах, в свойствах и локальных переменных. Поэтому не катит.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820490
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
SiemarglБезотносительно C#8, вместо string отлично передается null, как объектный тип )

Попытка подстелить соломку ?

Статическая проверка типов. Всё по феншую. Изначально ссылочные типы шли вразрез с этой идеей.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820491
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВНи каких вопросов :)
Код: c#
1.
2.
DateTime dateTime = default;
            var b = dateTime == null;



Это костыль )
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820494
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttА string! это совершенно новый тип, его протаскивать надо везде. В аргументах, в свойствах и локальных переменных. Поэтому не катит.
string? тоже надо, я выше давал ссылку, где чувак описывает случаи.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820496
Фотография ЕвгенийВ
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttЕвгенийВНи каких вопросов :)
Код: c#
1.
2.
DateTime dateTime = default;
            var b = dateTime == null;



Это костыль )
Не костыль. Сам недавно чудом узнал, что если у структуры переопределен == то на сравнение с null компилятор не ругается )
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820502
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВНе костыль. Сам недавно чудом узнал, что если у структуры переопределен == то на сравнение с null компилятор не ругается )

Там дело не в переопределении, по-моему. Просто структура отбоксится в object а потом сравнится с null.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820505
fkthat
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatЕвгенийВНе костыль. Сам недавно чудом узнал, что если у структуры переопределен == то на сравнение с null компилятор не ругается )

Там дело не в переопределении, по-моему. Просто структура отбоксится в object а потом сравнится с null.

Нет, я был не прав, там все еще хитрее. Ругаться компилятор не ругается, но все равно поступает умно и сравнение просто сразу же заменяет на false.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820516
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВstring? тоже надо, я выше давал ссылку, где чувак описывает случаи.

ну ок, смотрим:

Код: c#
1.
2.
3.
public SomeType! SomeMethod(int a, string b, ClassType! t1, StructType t2)
{
}



Если бы МС пошли на такое, это был бы знатный фейл. Хорошо, что не облажались )
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820517
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ЕвгенийВНе костыль. Сам недавно чудом узнал, что если у структуры переопределен == то на сравнение с null компилятор не ругается )

Собственно в этом и есть костыль, реализованный через переопределение )
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820526
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
hVosttА string! это совершенно новый тип
Ну да, аналогично было, когда вводились nullable value types.
hVosttего протаскивать надо везде. В аргументах, в свойствах и локальных переменных. Поэтому не катит.
Зачем? Когда вводились nullable value types, никто везде массово не менял int на int?, и не протаскивал Nullable<T> везде. Новая фича - для новых проектов, и рефакторинга старых по мере необходимости и наличия свободного времени. Старая остается на своем месте, и с ней работают по-старому.
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39820533
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
fkthatЕвгенийВНе костыль. Сам недавно чудом узнал, что если у структуры переопределен == то на сравнение с null компилятор не ругается )

Там дело не в переопределении, по-моему. Просто структура отбоксится в object а потом сравнится с null.
Ответ Липперта .
...
Рейтинг: 0 / 0
C# 8 preview: Nullable reference types
    #39821019
Фотография hVostt
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Сон Веры ПавловныhVosttА string! это совершенно новый тип
Ну да, аналогично было, когда вводились nullable value types.

Так это и были новые типы и соответствующая поддержка языка. Вводить обратное -- явное противоречие, с которым сложно будет работать.

Сон Веры ПавловныЗачем? Когда вводились nullable value types, никто везде массово не менял int на int?, и не протаскивал Nullable<T> везде.

Не скажи. Менял object на Nullable<T>. И протаскивал :)

Сон Веры ПавловныСтарая остается на своем месте, и с ней работают по-старому.

Обратная совместимость должна быть не только синтаксическая, но и семантическая.

int => int?
string => string?

логично? да.

int => int?
!string => string

херень какая-то. особенно для классов и структур.
...
Рейтинг: 0 / 0
38 сообщений из 38, показаны все 2 страниц
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / C# 8 preview: Nullable reference types
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]