|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
|||||||||||
.NET 8 Переназначение ссылки с помощью оператора ref не работает24.07.2024, 19:21. Показов 2364. Ответов 29
Метки нет (Все метки)
Приветствую всех. Очень хотелось бы разобраться с данным вопросом, буду рад ответам.
https://learn.microsoft.com/en... t-operator В данной статье говорится об операторе "ref"(не который используется в параметрах методах, а который служит некоторым псведонимом для ссылки на объект) Например:
0
|
|||||||||||
| 24.07.2024, 19:21 | |
|
Ответы с готовыми решениями:
29
Ссылки в C#: ref и out Передача ссылки по ссылке (ref) Программирование с помощью условного оператора и оператора выбора |
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
||||||
| 24.07.2024, 19:44 | ||||||
|
А если так:
0
|
||||||
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
|
| 24.07.2024, 19:51 [ТС] | |
|
Так, конечно, работает. Но это совершенно другое поведение.
В вашем случае я просто заберу объект с program, то есть присвою null. А в моем случае хотелось бы чтобы эти две ссылки стали связными. То есть в моем дальнейшем поведении при написании program = new Program() у меня сразу же изменился бы и указатель pr в Main() как в первом примере. А в вашем случае изменится только статика, а ссылка в мейне так и будет указывать в пустоту
0
|
|
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
||||||||||||||||||||
| 24.07.2024, 20:09 | ||||||||||||||||||||
|
Avoid memory copying:
В переменной/выражении значимого типа хранится само значение - это т.н. self-contained экземпляры - именно поэтому мы можем делать финт:
А вот ваш случай:
Добавлено через 2 минуты Ятп ref assignment придумали, чтобы избавиться от копирования больших кусков памяти при передаче/возврате у значимых типов, то есть сохранить семантику передачи по ссылке. А с непосредственно ссылочными типами этого делать не надо, то есть вы полезли не туда куда надо. Добавлено через 2 минуты Покажите мне хотя бы один пример из кодовой базы Microsoft где ref assignment оперируют со ссылочными типами.
0
|
||||||||||||||||||||
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
||||||
| 24.07.2024, 20:13 [ТС] | ||||||
|
Не совсем понял эту "очевидность". Я понимаю стандартное присваивание референс типов, но речь же идет о другом
Приведу ещё раз пример.
0
|
||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|
| 24.07.2024, 20:14 | |
|
То есть сам факт, что вы в принципе ссылочный тип передаете по ref, уже говорит о том, что скорее всего (не всегда) вы идете не туда.
0
|
|
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
||||||
| 24.07.2024, 20:17 [ТС] | ||||||
|
Мы же сейчас не говорим о том как правильно/неправильно. Хотелось бы понять структуру самого языка и его возможностей.
И насчет кодовой базы: В классе словаря есть подобный код.
0
|
||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|||||||||||
| 24.07.2024, 20:44 | |||||||||||
|
Чтобы супер точно ответить на ваш вопрос, тут уже надо в IL-код смотреть.
0
|
|||||||||||
|
3085 / 3240 / 556
Регистрация: 17.02.2019
Сообщений: 5,154
|
|
| 24.07.2024, 20:47 | |
|
0
|
|
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|||||||||||||||||||||||||||||||||||||
| 24.07.2024, 21:23 | |||||||||||||||||||||||||||||||||||||
|
Второй случай:
То есть разница в командах, как уже сказал: Ref assignment в методе Bar:
Обычное value assignment на ссылочных типах в методе Bar:
Разные команды: starg.s VS stind.ref. Добавлено через 18 минут Условно, две команды: 1. Обычное reference assignment, но слева АДРЕС (мб тоже самое что и просто имя переменной). stind.ref address value - по указанному адресу записать значение.2. Необычное ref assignment над reference type variables (в конкретном частном случае): Тут пара команд для наглядности:
Я не знаю, что тут еще добавить. В такие вещи не нужно погружаться ятп, до тех пор, пока вы не пилите сам Roslyn.
0
|
|||||||||||||||||||||||||||||||||||||
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
|
| 24.07.2024, 21:31 [ТС] | |
|
Не ожидал, что все дойдет до IL кода. Говоря, честно, я все равно до конца не понял почему в методе мейн ссылка никак не меняется, хотя, кстати, если попробовать в том же методе бар после присвоения аргументу Program указателя на статическое поле изменить этот указатель, то статическое поле меняется, но опять таки эта связь сохраняется только в самом методе, а со стороны вызова остается все точно так же. Согласен с последним, это просто излишнее любопытство, которые обычно до хорошего не доводит и только разрушает уже устоявшиеся слои абстракций.
Спасибо за ответы
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|||||||||||||||||||||||||
| 25.07.2024, 11:06 | |||||||||||||||||||||||||
|
1. Переменная — это именованный участок памяти, доступный для чтения/записи через имя переменной. 2. Ref-переменная — это алиас/псевдоним/дополнительное имя для некоего участкая памяти. 3. Оператор присваивания = — это операция записи значения по правую сторону в память, доступную через имя по левую сторону.4. Оператор ref-присваивания = ref — это привязка дополнительного имени по левую сторону к памяти, доступную через имя по правую сторону.При вызове метода Bar алиас Bar.pr привязывается к участку памяти, доступному через имя Main.pr. Все дальнейшие манипуляции с Bar.pr будут производиться над тем же участком памяти, который доступен через Main.pr При выполнении операции pr = ref program; на 7-й строчке псевдоним Bar.pr отвязывается от участка памяти Main.pr и привязывается к участку памяти, доступному через Program.program. Все дальнейшие манипуляции с Bar.pr будут производиться над тем же участком памяти, который доступен через Program.program. Ни на память, доступную через Main.pr, ни на хранящееся в этой памяти значение это никак не влияет. Примерное представление памяти на момент входа в Bar:
Оно же, но после выполнения 7-й строчки:
Моральный эквивалент этого же примера, но без дополнительных функций:
Имеется два файла: C:\mainPr.txt и C:\program.txt Создается ярлык на C:\mainPr.txt с именем barPr.lnk. Если открыть блокнот через этот ярлык, что-то напечатать и сохранить, то это будет аналогично операции присваивания: barPr = ....Если зайти в свойства ярлыка и изменить поле Target на C:\program.txt, то это эквивалентно операции barPr = ref program.Ни на содержимое C:\mainPr.txt, ни на то, какой файл откроется щелчком по mainPr.txt, изменение свойств ярлыка никак не влияет.
3
|
|||||||||||||||||||||||||
|
151 / 135 / 29
Регистрация: 02.07.2013
Сообщений: 962
|
||
| 25.07.2024, 12:19 | ||
|
то есть окажется, что "поле" объекта указывает на память не лежащую в объекте? или тут у точки Main.pr Bar.pr другой смысл? это работает только с локальными переменными?
0
|
||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||||
| 25.07.2024, 13:12 | ||||
|
Память под эту переменную — часть экземпляра.
0
|
||||
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
|||||||||||
| 25.07.2024, 13:45 [ТС] | |||||||||||
|
В документации майков написано следующее: https://learn.microsoft.com/ru... parameters
То есть что-то подобное:
Я решил поискать дальше и нашел следующее: https://github.com/dotnet/docs/issues/32853 Оказывается речь шла про те самые ref assignment, из чего можно сделать вывод, что в пункте про ссылочные типы по ссылке говорится о том же самом:
0
|
|||||||||||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 25.07.2024, 14:36 | ||
|
Одна и та же фраза "assigns the parameter to refer to a different object" может означать разные операции в зависимости от типа переменной. Третий пункт говорит о переменных значимого типа. Они не могут ни на что ссылаться, потому здесь эта фраза скорее всего подразумевает оператор = ref.Четвертый пункт говорит о переменных ссылочного типа, которые могут ссылаться на объекты, потому там скорее всего идет речь про обычный оператор присваивания =.
0
|
||
|
3 / 2 / 1
Регистрация: 04.02.2023
Сообщений: 34
|
|
| 25.07.2024, 17:19 [ТС] | |
|
Видимо, и вправду так. Думаю тему можно закрывать.
Всем спасибо за ответы
0
|
|
|
17 / 16 / 1
Регистрация: 25.01.2023
Сообщений: 468
|
|||||||||||
| 22.08.2024, 12:18 | |||||||||||
|
IamRain, вопрос касаемо
ref readonly:
1
|
|||||||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,228
|
|||||||||||||||||||||||
| 22.08.2024, 13:05 | |||||||||||||||||||||||
SpinLock - жирная структура, поэтому для быстродействия имеет смысл передавать ее по Managed Pointer-у (по ссылке), это да. Однако следующая строка создает ref readonly pointer, который запрещает изменять состояние экземпляра, через создание defensive copy - метод вызывается именно на defensive copy, а не на оригинале. + дополнительно этой строкой вы очевидно производите (при будущих вызовах методов над этой переменной) копирование, чего так пытались избежать, передавая по ref-у.
Добавлено через 1 минуту Добавлено через 2 минуты
Добавлено через 17 минут INexteR, а не подскажете, чем могут оказаться полезными кастомные ref-like структуры? Просто интересно.
1
|
|||||||||||||||||||||||
|
17 / 16 / 1
Регистрация: 25.01.2023
Сообщений: 468
|
|||||||
| 22.08.2024, 13:26 | |||||||
|
Добавлено через 16 минут
0
|
|||||||
| 22.08.2024, 13:26 | |
|
Помогаю со студенческими работами здесь
20
Как сделать данный код с помощью OUT\REF ??? Переназначение линейного входа на микрофонный не работает
Не работает ref параметр
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Налог на собак: https:/ / **********/ gallery/ V06K53e
Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf
Пост отсюда. . .
|
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод
Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод.
Thinkpad X220 Tablet —. . .
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|