С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/22: Рейтинг темы: голосов - 22, средняя оценка - 4.77
8 / 8 / 3
Регистрация: 31.05.2012
Сообщений: 100
1

Вызов метода базового класса игнорируя переопределенный метод в производном классе

08.02.2016, 16:58. Показов 4261. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Как вызвать метод базового класса игнорируя переопределенный метод в производном классе.
PS переопределение метода в производном классе удалить нельзя, вшит в dll
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApplication1
{
    public class Person
    {
        protected string ssn = "444-55-6666";
        protected string name = "John L. Malgraine";
 
        public virtual void GetInfo()
        {
            Console.WriteLine("Name: {0}", name);
            Console.WriteLine("SSN: {0}", ssn);
        }
    }
    class Employee : Person
    {
        public string id = "ABC567EFG";
        public override void GetInfo()
        {
            // Calling the base class GetInfo method:
            base.GetInfo();
            Console.WriteLine("Employee ID: {0}", id);
        }
 
    }
 
    class TestClass
    {
        static void Main()
        {
            Employee E = new Employee();
            E.GetInfo();
            Console.ReadKey();
           
        }
    }
 
}
Добавлено через 17 минут
изменить тело классов базового и производного нельзя.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.02.2016, 16:58
Ответы с готовыми решениями:

Полиморфизм: вызов метода базового класса, переопределенного метода и нового метода
В базовом классе метод помечен как virtual. Насколько я понял из книги: override означает, что...

Вызов метода базового класса
public class BaseClass { public virtual void Foo() { Console.WriteLine ("BaseClass.Foo"); } }...

Вызов метода наследика с базового класса
Здравствуйте. Подскажите, как в базовом классе можно вызвать метод наследника, который не...

Вызов переопределенного метода класса наследника из базового класса
Предположим есть два класа: public class A { /* ... некая...

5
708 / 708 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
08.02.2016, 17:36 2
Никак. Либо инстанцируйте базовый класс либо пересматривайте вашу архитктуру.
0
26 / 26 / 14
Регистрация: 09.06.2014
Сообщений: 162
08.02.2016, 20:40 3
Создайте объект базового класса, ну или приведите к базовому классу.
0
8 / 8 / 3
Регистрация: 31.05.2012
Сообщений: 100
08.02.2016, 21:11  [ТС] 4
тут не всё так просто, работать можно только с экземпляром E. Сделав upcast к базовому типу, метод из производного класса всё равно исполниться.А мне нужно, чтобы исполнился только метод из базового класса...)
0
Эксперт .NETАвтор FAQ
10418 / 5148 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
08.02.2016, 21:20 5
System9266, Нормальным способом сделать нельзя.
Нот вот тут есть решение http://stackoverflow.com/a/4358250
2
8 / 8 / 3
Регистрация: 31.05.2012
Сообщений: 100
08.02.2016, 22:22  [ТС] 6
Storm23, Благодарю.
Вот этот вариант сработал. Пользуйтесь
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Reflection.Emit;
 
namespace System.Reflection
{
    public static class MethodInfoExtensions
    {
        public static object InvokeNotOverride(this MethodInfo MethodInfo, object Object, params object[] Arguments)
        { // void return, this parameter
            var Parameters = MethodInfo.GetParameters();
 
            if (Parameters.Length == 0)
            {
                if (Arguments != null && Arguments.Length != 0) throw new Exception("The number of arguments does not match the number of parameters");
            }
            else {
                if (Parameters.Length != Arguments.Length) throw new Exception("The number of arguments does not match the number of parameters");
            }
 
            Type ReturnType = null;
            if (MethodInfo.ReturnType != typeof(void))
            {
                ReturnType = MethodInfo.ReturnType;
            }
 
            var Type = Object.GetType();
            var DynamicMethod = new DynamicMethod("", ReturnType, new Type[] { Type, typeof(Object) }, Type);
            var ILGenerator = DynamicMethod.GetILGenerator();
            ILGenerator.Emit(OpCodes.Ldarg_0); // this
 
            for (var i = 0; i < Parameters.Length; i++)
            {
                var Parameter = Parameters[i];
 
                ILGenerator.Emit(OpCodes.Ldarg_1); // load array argument
 
                // get element at index
                ILGenerator.Emit(OpCodes.Ldc_I4_S, i); // specify index
                ILGenerator.Emit(OpCodes.Ldelem_Ref); // get element
 
                var ParameterType = Parameter.ParameterType;
                if (ParameterType.IsPrimitive)
                {
                    ILGenerator.Emit(OpCodes.Unbox_Any, ParameterType);
                }
                else if (ParameterType == typeof(object))
                {
                    // do nothing
                }
                else {
                    ILGenerator.Emit(OpCodes.Castclass, ParameterType);
                }
            }
 
            ILGenerator.Emit(OpCodes.Call, MethodInfo);
 
            var TestLabel = ILGenerator.DefineLabel();
 
            ILGenerator.Emit(OpCodes.Ret);
            return DynamicMethod.Invoke(null, new object[] { Object, Arguments });
        }
    }
    class Program
    {
        class BaseClass
        {
            public virtual void Test()
            {
                Console.WriteLine("Test() from BaseClass");
            }
        }
 
        class OverridingClass : BaseClass
        {
            public override void Test()
            {
                Console.WriteLine("Test() from OverridingClass");
            }
        }
 
        public static void Main()
        {
            var d = new OverridingClass();
            //typeof(BaseClass).GetMethod("Test").Invoke(d, null);
            typeof(BaseClass).GetMethod("Test").InvokeNotOverride(d, null);
            Console.ReadKey();
        }
     
    }
}
ссылка на первоисточник http://www.simplygoodcode.com/... eflection/
Длинновато получается. Попробую упростить.

Добавлено через 23 минуты
может быть кто предложит более упрощённый вариант, посмотрим.
0
08.02.2016, 22:22
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.02.2016, 22:22
Помогаю со студенческими работами здесь

Вызов метода дочернего класса из базового
Привет всем. Ни как не могу понять как позволить базовому классу вызвать метод дочернего. Например:...

Постоянный вызов метода основного класса в наследованном классе
Всем привет! Вопрос про наследование. Можно сделать так, чтобы при вызове в производном классе...

Не получается вызвать Change из базового класса в производном
Не получается вызвать Change из базового класса в производном, помогите. using System; using...

Наследование метода toString() в производном классе
В главном классе определил метод toString(): /// &lt;summary&gt; /// вывод на экран значений ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru