Unsafe.AsRef Метод
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Перегрузки
AsRef<T>(Void*) |
Преобразует неуправляемый указатель в управляемый указатель в значение типа |
AsRef<T>(T) |
Повторно интерпретирует указанную ссылку только для чтения в качестве изменяемой ссылки. |
AsRef<T>(Void*)
Важно!
Этот API несовместим с CLS.
Преобразует неуправляемый указатель в управляемый указатель в значение типа T
.
public:
generic <typename T>
static T % AsRef(void* source);
public static ref T AsRef<T> (void* source);
[System.CLSCompliant(false)]
public static ref T AsRef<T> (void* source);
static member AsRef : nativeptr<unit> -> 'T
[<System.CLSCompliant(false)>]
static member AsRef : nativeptr<unit> -> 'T
Параметры типа
- T
Элементный тип управляемого указателя.
Параметры
- source
- Void*
Неуправляемый указатель для преобразования.
Возвращаемое значение
- T
Управляемый указатель на значение типа T
.
- Атрибуты
Комментарии
Вызывающий объект отвечает за правильное выравнивание полученного управляемого указателя для указанного типа. Дополнительные сведения о требованиях к выравниванию см. в разделе ECMA-335, Sec. I.12.6.2 (Выравнивание).
Применяется к
AsRef<T>(T)
Повторно интерпретирует указанную ссылку только для чтения в качестве изменяемой ссылки.
public:
generic <typename T>
static T % AsRef(T % source);
public static ref T AsRef<T> (scoped in T source);
static member AsRef : 'T -> 'T
Public Shared Function AsRef(Of T) (ByRef source As T) As T
Параметры типа
- T
Базовый тип ссылки.
Параметры
- source
- T
Повторно интерпретируемая ссылка с доступом только для чтения.
Возвращаемое значение
- T
Изменяемая ссылка на значение типа T
.
Комментарии
Этот API концептуально похож на C++ const_cast<>
. Это ответственность вызывающего объекта, чтобы гарантировать, что данные не записываются в указанное расположение. Среда выполнения содержит внутреннюю логику, определяемую предположением о том, что ссылки только для чтения являются неизменяемыми, и вызывающие лица, которые нарушают эту инвариантную функцию, могут вызвать неопределенное поведение в среде выполнения.
AsRef
обычно используется для передачи ссылки на чтение в такие методы, как Addметоды, которые принимают изменяемые управляемые указатели в качестве аргументов. Рассмотрим следующий пример.
int ComputeSumOfElements(ref int refToFirstElement, nint numElements)
{
int sum = 0;
for (nint i = 0; i < numElements; i++)
{
sum += Unsafe.Add(ref refToFirstElement, i);
}
}
Если входной параметр не ref int refToFirstElement
являетсяref readonly int refToFirstElement
, предыдущий пример не будет компилироваться, так как ссылки только для чтения не могут использоваться в качестве аргументовAdd
. Вместо этого AsRef
можно использовать для удаления ограничения неизменяемости и обеспечения успешной компиляции, как показано в следующем примере.
int ComputeSumOfElements(ref readonly int refToFirstElement, nint numElements)
{
int sum = 0;
for (nint i = 0; i < numElements; i++)
{
sum += Unsafe.Add(ref Unsafe.AsRef(ref refToFirstElement), i);
}
}