Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28

Как использовать рефлексию для уточнения значения параметра метода?

01.08.2018, 15:13. Показов 1858. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго всем времени суток форумчане
Помогите пож возможно кто-то знает
Допустим есть метод
C#
1
2
3
public void Method(string a)
{
}
Как можно с помощью рефлексии узнать какое значении было передано в сам метод?
Все что удалось узнать сделать так это узнать тип параметра и его название
C#
1
2
3
4
5
ParameterInfo[] parameters = System.Reflection.MethodInfo.GetCurrentMethod().GetParameters();
            foreach (var par in parameters)
            {
                logger.Debug(par.ParameterType.Name + " " + par.Name);
            }
А как вытянуть значение? в par нет такого метода или свойства которое могло возвращать необходимо значение
par.DefaultValue и par.RawValue работает только со значением по умолчанию для параметра, все что нашел на msdn
однако есть возможность с помощью рефлексии узнавать значение свойств в классе, может есть и такая возможность для параметров методов но я не нашел
Пишется это все для фиксации логов в файл при прохождении автотестов
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.08.2018, 15:13
Ответы с готовыми решениями:

Как получить тело метода через рефлексию?
Скажите, а можно используя рефлексию вытащить тело метода в читабельном виде?

Почему в setnamedisc нужно использовать char * для установки значения, а при возвращении значения тип метода должен быть char* ?
Вопрос такой, почему в методе setnamedisc нужно использовать char *s для установки значения, а при возвращении значения в методе...

Описать применение метода итерации для уточнения корней уравнения
В работе требуется описать применение метода итерации для уточнения корней уравнения. Нигде не могу найти объяснение (теорию) этого...

15
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,569
01.08.2018, 15:27
Зачем что-то уточнять, если у вас и так значение уже есть в параметре метода, берите его и используйте...

https://ayende.com/blog/3474/logging-the-aop-way
https://www.codeproject.com/Ar... g-AOP-in-C
0
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
01.08.2018, 15:34  [ТС]
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
static List<String> LinksList = new List<String> { @"http://localhost:3000", @"http://localhost:3000/Groups/Dnipro", @"http://localhost:3000/admin" };
 
        [Test, TestCaseSource("LinksList")]
        public void Test_NavigateToLinks_LoginPageOpened(String link)
        {
            logger.Debug(System.Reflection.MethodInfo.GetCurrentMethod().DeclaringType);
            logger.Debug(System.Reflection.MethodInfo.GetCurrentMethod().Name);
            logger.Debug(System.Reflection.MethodInfo.GetCurrentMethod().GetCustomAttributesData());
            logger.Debug(System.Reflection.MethodInfo.GetCurrentMethod().GetParameters());
            ParameterInfo[] parameters = System.Reflection.MethodInfo.GetCurrentMethod().GetParameters();
            foreach (var par in parameters)
            {
                logger.Debug(par.ParameterType.Name + " " + par.Name + " " + par.GetType().);
            }
            driver.Url = link;
            Assert.IsTrue(wait.Until((d) => LoginPage.IsLoginPageOpened(driver)));
 
            logger.Debug(wait.Until((d) => LoginPage.IsLoginPageOpened(driver)));
        }
Потому что используются различные источники данных, в зависимости от этих данных будут менятся входные параметры и будут проходить/или не проходить автотесты, плюс это все в файл логов надо записывать
на этом примере статик обьект, а будет хмл файл или тхт файл
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18242 / 14156 / 5366
Регистрация: 17.03.2014
Сообщений: 28,844
Записей в блоге: 1
01.08.2018, 15:47
Цитата Сообщение от Hagawa Посмотреть сообщение
Как можно с помощью рефлексии узнать какое значении было передано в сам метод?
Никак. Рефлексия не предназначена для такого сценария.
0
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
01.08.2018, 16:29  [ТС]
возможно тогда другим путем можно сделать?
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,929
01.08.2018, 17:27
Hagawa, у меня лыжи не едут или это вы просите какую-то ерунду?

У вас в методе уже доступны все переданные в него параметры. В коде выше это string link. Есть какая-то сила непреодолимая, что мешает напрямую к параметру обратиться?
0
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
01.08.2018, 19:51  [ТС]
Потому что это будет применяться ко многим методам с разными видами и именами параметров , и чтобы не писать в каждом выполняемом методе дополнительный код, а реализовать отдельный универсальный класс/метод для этого действия и чтобы это была одна/две строчки
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18242 / 14156 / 5366
Регистрация: 17.03.2014
Сообщений: 28,844
Записей в блоге: 1
01.08.2018, 20:40
Hagawa, можно применить MethodBoundaryAspect.Fody
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,929
02.08.2018, 04:43
Hagawa, а зачем вообще логировать тесты? NUnit и так это делает. А на падающие тесты вообще под отладкой можно посмотреть.

Я всё ещё считаю, что вы спросили ерунду потому, что ерунду сделать и пытаетесь...
1
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
02.08.2018, 08:08  [ТС]
во первых результаты всех тестов надо записать в файл, и во вторых учитывая количество тестов и масштабируемость тестов легче сделать универсальное чтото чем в каждом тесте писать большое количество кода
есть класс Logging, он все отлично работает, но писать для каждого теста столько каждому участнику команды не целесообразно
возможно в Nunit есть другой какой то способ?
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,929
02.08.2018, 08:23
Hagawa, для чего нужно логировать результаты тестов? Если и логируют, то только упавшие тесты. Сам прогонщик тестов NUnut Console Runner сохраняет логи, но пишет только об упавших тестах.

Какая вам практическая польза логировать параметры прошедших тестов? Это же нонсенс!
1
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
02.08.2018, 09:44  [ТС]
а как то можно с помощью NUnit Console Runner записывать это все в файл? Или где он сохраняет эти логи?

Добавлено через 3 минуты
Цитата Сообщение от OwenGlendower Посмотреть сообщение
Hagawa, можно применить MethodBoundaryAspect.Fody

а не подскажите что именно из этого можно применить?
куча информации но ничего не ясно
вижу что там есть логирование но толком не понятно
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,929
02.08.2018, 10:05
Hagawa, NUnit Console Runner сам создаёт файл лога, когда один из тестов падает.

Зачем вам логировать работу проходящих тестов? Зачем вам вообще тесты логировать?
1
0 / 0 / 0
Регистрация: 02.08.2013
Сообщений: 28
02.08.2018, 10:18  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
Hagawa, NUnit Console Runner сам создаёт файл лога, когда один из тестов падает.
если создает сам файл, как он называется и где его найти в проекте?
и создает файл только для одного теста или там ифнормация о всех упавших тестах?
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,929
02.08.2018, 11:54
Hagawa, посмотрите сами: ссылко.

И забудьте о логировании тестов и использовании рефлексии в них.
1
187 / 100 / 19
Регистрация: 15.09.2011
Сообщений: 801
09.08.2018, 08:51
Hagawa, возможно использовать как вариант решения данной проблемы
https://forums.asp.net/t/11658... +a+Method+, там klaus_b ответил в конце.
только для этого вам потребуется установить PostSharp.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.08.2018, 08:51
Помогаю со студенческими работами здесь

Опишите суть метода и постройте алгоритм для уточнения корня уравнения
Опишите суть метода и постройте алгоритм для уточнения корня уравнения 5 sin 2x=sqrt{1-x} на отрезке с точностью {10}^{4} методом...

Опишите суть метода половинного деления и постройте алгоритм для уточнения корня
Опишите суть метода и постройте алгоритм для уточнения корня уравнения 5 \sin{2x}=sqrt{1-x} на отрезке с точностью {10}^{4} методом...

Что передать в качестве параметра методу, чтобы использовать данные с помощью метода `xpath`?
def get_hash(node) { weight: node.xpath('.//span/text()').text, price: node.xpath('.//span/text()').text, logo:...

Передача значения или параметра из одного метода в другой
Приветствую всех. Подскажите, как решить данную проблему. Мне нужно из метода CreateVector передать значение vector1 в метод ShowVector для...

Как задать значения статического поля класса используя рефлексию?
Народ как задать значение статическому полю класса при помощи рефлексии. Есть тема...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
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
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru