Debugger.ExecuteStatement - метод
Выполняет указанный оператор. Если флаг TreatAsExpression принимает значение true, строка интерпретируется как выражение и результат направляется в окно команд.
Пространство имен: EnvDTE
Сборка: EnvDTE (в EnvDTE.dll)
Синтаксис
'Декларация
Sub ExecuteStatement ( _
Statement As String, _
Timeout As Integer, _
TreatAsExpression As Boolean _
)
void ExecuteStatement(
string Statement,
int Timeout,
bool TreatAsExpression
)
void ExecuteStatement(
[InAttribute] String^ Statement,
[InAttribute] int Timeout,
[InAttribute] bool TreatAsExpression
)
abstract ExecuteStatement :
Statement:string *
Timeout:int *
TreatAsExpression:bool -> unit
function ExecuteStatement(
Statement : String,
Timeout : int,
TreatAsExpression : boolean
)
Параметры
- Statement
Тип: System.String
Выполняемый оператор.
- Timeout
Тип: System.Int32
Период ожидания, заданный в миллисекундах.
- TreatAsExpression
Тип: System.Boolean
Обрабатывать как выражение.Значение True, если строку следует интерпретировать как выражение; в противном случае — значение False.
Заметки
ExecuteStatement выполняет указанный оператор. Оператор отличается от выражения тем, что может состоять из одного или нескольких выражений. Поэтому обычно оператор не имеет и не возвращает какое-либо значение при выполнении.
Некоторые языки, например Visual Basic, поддерживают синтаксис, в котором способ обработки оператора определяется контекстом, в котором он находится. Например, если в коде Visual Basic используется оператор a = 1, то он интерпретируется как выражение, если код находится в операторе If…Then. Дополнительные сведения см. в разделе Оператор If...Then...Else (Visual Basic). В этом случае он интерпретируется как оператор, если находится отдельно на строке. Выражение проверяет a на равенство значению 1; оператор установит a равным 2. См. пример ниже.
Результат выполнения этого метода направляется в окно Команда.
Примеры
В следующем примере показано, как использовать метод ExecuteStatement.
Тестирование данного метода:
Задайте точку останова в целевом приложении после присваивания переменной значения.
Запустите приложение в режиме отладки.
Когда выполнение приложения остановится в точке останова, запустите надстройку.
Значение переменной изменяется на новое значение.
public static void ExecuteStatement(DTE dte)
{
// Setup the debug Output window.
Window w = (Window)dte.Windows.Item(EnvDTE.Constants.vsWindowKindOutput);
w.Visible = true;
OutputWindow ow = (OutputWindow)w.Object;
OutputWindowPane owp = ow.OutputWindowPanes.Add("ExecuteStatement Method Test");
owp.Activate();
dte.Debugger.ExecuteStatement("tempC = 100.0", 100, false);
}
Shared Sub ExecuteStatementTest(ByRef dte As EnvDTE.DTE)
dte.Debugger.ExecuteStatement("tempC = 100.0", 100, False)
End Sub
Безопасность платформы .NET Framework
- Полное доверие для непосредственно вызывающего метода. Этот член не может быть использован частично доверенным кодом. Дополнительные сведения см. в разделе Использование библиотек из не вполне надежного кода.