Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
13 / 11 / 2
Регистрация: 07.05.2015
Сообщений: 418

Почему System.Type является ссылочным типом, а не типом значений?

26.05.2022, 09:01. Показов 1022. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Разве может отличаться тип String, например от типа String? Если вы возьмёте typeof(String), то вы получите объект Type. Мне кажется более, органичным, если бы сам по себе Type был бы структурой. Типы могут наследоваться друг от друга, но сущность, призванная служить описанием к типу, сама по себе ни от кого не наследуется. Есть ли какие-то неизвестные мне причины, почему Type был реализован классом?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.05.2022, 09:01
Ответы с готовыми решениями:

Каким образом тип значений взаимодействует с ссылочным типом
// Реализовать интерфейсы IEnumerable и IEnumerator. using System; using System.Collections; class MyClass : IEnumerator,...

Почему int является основным типом?
Читаю книгу Стивена Прата "Язык программирования С++" 6-е издание. Там есть фрагмент: "int имеет наиболее “естественный” размер целого...

Значение NULL не может быть присвоено члену, который является типом System.Int32
Всем привет! Пишу следующий код: int? emp = ctx.Employee.Max(em => em.EmployeeID); Когда таблица Employee пустая,...

4
Эксперт .NET
 Аватар для Usaga
14313 / 9393 / 1355
Регистрация: 21.01.2016
Сообщений: 35,425
26.05.2022, 09:06
Цитата Сообщение от Aycon Посмотреть сообщение
Мне кажется более, органичным, если бы сам по себе Type был бы структурой
Какие аргументы в пользу структуры вы можете привести? Просто отсутствие наследования, что ли?
0
13 / 11 / 2
Регистрация: 07.05.2015
Сообщений: 418
26.05.2022, 09:36  [ТС]
Usaga, ну вот смотрите - есть ссылочные типы, переменные, которые даже при равных полях сущностей, которые они хранят считаются эквивалентными только в том случае, если они имеют одинаковые ссылки. Например класс Human, имеющий для простоты только три поля:

C#
1
2
3
4
5
6
class Human
{
    public string Name { get; set;}
    public string SecondName { get; set;}
    public int Old { get; set;}
}
Бывает такое, что встречаются люди с одинаковыми именем, фамилией и возрастом. Чтобы не путать сущности между собой нужен некий идентификатор. В качестве такого идентификатора в базах данных используют искусственные первичные ключи. А в CLR используется адрес сущности в памяти. Ведь по одному и тому же адресу находится только одна сущность.
Другой пример, когда в моём понимании разумно использовать классы - когда сравнение на основе значений полей может оказаться весьма трудозатратным. Например, если мы сравниваем две саморекуррентные структуры, например два бинарных дерева. Если эти деревья - ссылочного типа, то их эквивалентность определяется за константное время путём сравнения ссылок. В случае же структуры, в худшем случае придётся проверить все листья обоих деревьев, чтобы убедиться, что они равны. Если только вы не перегрузите соответствующие операторы и функции, реализуя таким образом, собственные искуственные первичные ключи.

В остальных случаях, если вы не нуждаетесь в наследовании, по ряду причин проще использовать структуры. Я не вижу ни одной причины, почему System.Type - это ссылочный тип.

Добавлено через 12 минут
Usaga, в первую очередь - производительность. Все структуры хранятся в куче, не поддерживают наследование (нет upcast, downcast, ковариации, контрвариации типов), сами типы все определены на момент окончания компиляции, это значит, что на момент начала выполнения новые типы не появятся, а неиспользуемые уже отброшены. Можно реализовать кэширование экземпляров более эффективно, полагаясь на эту информацию (экземпляров Type, а не экземпляров конкретных типов). Нет давления на сборщик мусора и утечек. Если только, вы не используете Type в полях ссылочных типов, в замыкании, в анонимных методах или async/await контекстах (в этом предложении не уверен).
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18298 / 14222 / 5368
Регистрация: 17.03.2014
Сообщений: 28,900
Записей в блоге: 1
26.05.2022, 09:38
Лучший ответ Сообщение было отмечено Aycon как решение

Решение

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

Цитата Сообщение от Aycon Посмотреть сообщение
Разве может отличаться тип String, например от типа String?
Не может, да. MS об этом позаботилась. Экземпляры Type это синглтоны.

Цитата Сообщение от Aycon Посмотреть сообщение
сущность, призванная служить описанием к типу, сама по себе ни от кого не наследуется
В реальности же Type наследуется от MemberInfo.
1
13 / 11 / 2
Регистрация: 07.05.2015
Сообщений: 418
26.05.2022, 09:43  [ТС]
OwenGlendower,
В реальности же Type наследуется от MemberInfo.
Лол, спасибо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.05.2022, 09:43
Помогаю со студенческими работами здесь

Нарисуйте 5 треугольников с разным типом линий и типом и цветом заливки
Нарисуйте 5 треугольников с разным типом линий и типом и цветом заливки. В целом у меня вопрос: Как сделать границы треугольников...

В чем разница между типом функции и типом возвращаемого значения?
Читаю статью https:// code-live. ru/post/cpp-functions/ (ссылку изменил дабы не делать рекламу) Там написано - Любая функция...

Нужно переменной с типом real присвоить выражение a1 mod 2, где a1 - это переменная с типом integer.
Такой вопрос . Мне нужно переменной с типом real присвоить выражение a1 mod 2 где a1 это переменная с типом integer. Выдает ошибку, т.к....

С типом char работает, с типом int не хочет
Подскажите знающие люди, в чем загвоздка? Обнаружил такое в процессе решения задачи, исходящей от одного ТС. Кратко о задаче: в консоли...

Директива using namespace может применяться только к пространствам имен; "System.Object" является типом, а не пространством имен
Что с этим делать?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru