【发布时间】:2016-02-12 13:44:57
【问题描述】:
如何调用泛型方法,我听说过反射,但我觉得我做错了,请检查。
public static LinkedListNode<T> MergeSortLL<T>(LinkedListNode<T> Head) where T : IComparable<T>
{
if (Head == null || Head.Next == null)
{
return Head;
}
LinkedListNode<T> middle = GetMiddle<T>(Head);
LinkedListNode<T> half = middle.Next;
middle.Next = null;
return Merge(Head, half);
}
在这里我试图用参数调用我的泛型方法
public void MSort()
{
Type type = typeof(MergeSort);
MethodInfo method = typeof(MergeSort).GetMethod("MergeSortLL");
MethodInfo generic = method.MakeGenericMethod(type);
generic.Invoke(null, null);
}
更新 2。 这里有更多信息我在我的班级 MergeSort 以及我为什么使用 IComparable
class MergeSort
{
public static LinkedListNode<T> MergeSortLL<T>(LinkedListNode<T> Head) where T : IComparable<T>
{
if (Head == null || Head.Next == null)
{
return Head;
}
LinkedListNode<T> middle = GetMiddle<T>(Head);
LinkedListNode<T> half = middle.Next;
middle.Next = null;
return Merge(Head, Head, half);
}
public static LinkedListNode<T> Merge<T>(LinkedListNode<T> Head, LinkedListNode<T> Left, LinkedListNode<T> Right) where T : IComparable<T>
{
LinkedListNode<T> mHead = Head;
LinkedListNode<T> curr = mHead;
while (Left != null && Right != null)
{
if (Left.Value.CompareTo(Right.Value) <= 0)
{
curr.Next = Left;
Left = Left.Next;
}
else
{
curr.Next = Right;
Right = Right.Next;
}
curr = curr.Next;
}
curr.Next = (Left == null) ? Right : Left;
return mHead.Next;
}
public static LinkedListNode<T> GetMiddle<T>(LinkedListNode<T> Head) where T : IComparable<T>
{
if (Head == null)
{
return Head;
}
LinkedListNode<T> slow, fast;
slow = fast = Head;
while (fast.Next != null && fast.Next.Next != null)
{
slow = slow.Next; fast = fast.Next.Next;
}
return slow;
}
}
【问题讨论】:
-
可以看stackoverflow中的帖子stackoverflow.com/questions/3957817/…
-
只需
var result = MergeSort.MergeSorLL(HeadNodeOfLinkedList);泛型将被推断 -
泛型和反射不能很好地混合。如果你不知道类型,你就不能在编译时对 output 做任何事情。如果这样做,则无需使用反射,只需按照@juharr 的建议调用即可。
标签: c# generics reflection