WedX - журнал о программировании и компьютерных науках

Почему в С# нет соглашения о невиртуальных вызовах?

Вдохновленный этим вопросом SO:

Почему в С# нет ключевого слова для невиртуального соглашения о вызовах?

РЕДАКТИРОВАТЬ: я имею в виду «почему нет ключевого слова для невиртуальных вызовов IL, учитывая, что компилятор С# всегда использует виртуальные вызовы IL по умолчанию»?

31.07.2010

  • Ах, одна из ловушек основных языков ООП (даже C++, который позволяет это)... 31.07.2010

Ответы:


1

Это может объяснить это: https://blogs.msdn.com/b/ericgu/archive/2008/07/02/why-does-c-always-use-callvirt.aspx

Кратко: инструкция call может принимать null как указатель this (как в C++). Это ошибочно, и команда C# решила использовать callvirt везде, где это возможно, чтобы вызовы null указателей выдавали NullReferenceException

31.07.2010
  • Я думаю, что это решает другую проблему, чем та, о которой спрашивает ОП. 31.07.2010
  • @0xA3 @Hans Passant У меня возникло ощущение, что автор неправильно сформулировал вопрос. посмотри на редактирование, я угадал 31.07.2010
  • Жаль, был бы отличный вопрос. 02.08.2010
  • Авторам C#, возможно, не понравилась идея передачи нулевого указателя this, но в некоторых случаях это могло бы улучшить разборчивость [например, возможность сказать SomeString.IsNullOrEmpty вместо String.IsNullOrEmpty(SomeString)]. 27.10.2011
  • @supercat это улучшит несколько случаев и испортит многие другие. 27.10.2011
  • @Andrey: Я бы предпочел разрешить средства, с помощью которых методы расширения, работающие с объектами определенного класса, могли бы быть объявлены внутри этого класса и подчиняться правилам области видимости этого класса. Между прочим, если бы у меня были свои друтеры, членам структуры, кроме конструкторов, было бы запрещено изменять this, но структуры могли бы объявлять методы расширения, которые получают свой параметр this по ссылке. Такое изменение, конечно, нарушило бы существующий код .net, но можно было бы объявить его устаревшим, чтобы позволить коду перейти к более безопасному синтаксису. 27.10.2011

  • 2

    Взгляните на почему c# реализует методы как невиртуальные по умолчанию ?

    Цитирую Андерса Хейлсберга

    Есть несколько причин. Один из них — производительность. Мы можем заметить, что, когда люди пишут код на Java, они забывают помечать свои методы как final. Следовательно, эти методы являются виртуальными. Поскольку они виртуальные, они не так хорошо работают. Есть только накладные расходы на производительность, связанные с виртуальным методом. Это одна проблема.

    Более важным вопросом является версия. Есть две точки зрения на виртуальные методы. Академическая школа мысли говорит: «Все должно быть виртуальным, потому что когда-нибудь я, возможно, захочу переопределить это». Прагматичная школа мысли, которая исходит из создания реальных приложений, работающих в реальном мире, говорит: «Мы должны быть очень осторожны с тем, что мы делаем виртуальным».

    Когда мы делаем что-то виртуальным на платформе, мы даем очень много обещаний о том, как это будет развиваться в будущем. Для невиртуального метода мы обещаем, что при вызове этого метода произойдет x и y. Когда мы публикуем виртуальный метод в API, мы не только обещаем, что при вызове этого метода произойдет x и y. Также мы обещаем, что при переопределении этого метода мы будем вызывать его именно в этой последовательности относительно этих других и состояние будет в том или ином инварианте.

    Каждый раз, когда вы говорите виртуальный в API, вы создаете хук обратного вызова. Как разработчик фреймворка ОС или API, вы должны быть очень осторожны с этим. Вы не хотите, чтобы пользователи переопределяли и подключались в любой произвольной точке API, потому что вы не можете обязательно давать такие обещания. И люди могут не до конца понимать обещания, которые они дают, когда делают что-то виртуальным.

    Источник: https://www.artima.com/intv/nonvirtual.html

    31.07.2010
  • Это несколько не по теме. Вопрос в том, почему мы не можем вызвать метод через не виртуальный вызов IL. Вызовы невиртуальных методов в С# по-прежнему используют инструкцию виртуального вызова IL, как говорили другие. Интересно, люди просто голосуют за самый длинный пост или они действительно его читают? 31.07.2010
  • @ Мау, я бы не назвал это не по теме. Это отвечает на вопрос Почему в C# нет соглашения о невиртуальных вызовах? и это название вопроса, по крайней мере, до редактирования. 01.08.2010
  • Новые материалы

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

    Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
    Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

    Учебные заметки: создание моего первого пакета Node.js
    Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

    Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
    Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..


    Для любых предложений по сайту: [email protected]