哦,这根本不容易。
Func<T>表示通用
delegate而不是表达式。如果有任何方法可以这样做(由于优化程序和编译器完成的其他工作,某些数据可能会被丢弃,因此可能无法恢复原始表达式),这将是在实时拆卸IL的过程。并推断表达式(绝非易事)。将lambda表达式视为data(
expression<Func<T>>)是
编译器的 一项神奇功能(基本上,编译器在代码中构建表达式树,而不是将其编译为IL)。
相关事实
这就是为什么将lambda推到极限的语言(例如Lisp)通常更易于实现为 解释器 。在这些语言中,代码和数据本质上是同一件事(即使在
运行时也是如此
),但是我们的芯片无法理解这种形式的代码,因此我们必须通过在可以理解该机器的基础上构建一个解释器来模拟这种机器(像语言一样由Lisp做出的选择)或在某种程度上牺牲了功能(代码不再完全等于数据)(C#做出的选择)。在C#中,编译器通过允许在
编译时 将lambda解释为 pre (
Func<T>)和 data
(
expression<Func<T>>)来给人一种将代码视为数据的错觉。 __



