关于IL和元组()

2022/11/24.今天学习到了两个部分,一个是关于IL中间语言,一个是关于元组的

IL

用 C# 编写的源代码被编译成符合 CLI 规范的中间语言 (IL)。 IL 代码和资源(如位图和字符串)存储在扩展名通常为 .dll 的程序集中。 程序集包含一个介绍程序集的类型、版本和区域性的清单。
执行 C# 程序时,程序集将加载到 CLR。 CLR 会直接执行实时 (JIT) 编译,将 IL 代码转换成本机指令。 CLR 可提供其他与自动垃圾回收、异常处理和资源管理相关的服务。 CLR 执行的代码有时称为“托管代码”。而“非托管代码”被编译成面向特定平台的本机语言。

用 C# 编写的源代码被编译成符合 CLI 规范的中间语言 (IL)。 IL 代码和资源(如位图和字符串)存储在扩展名通常为 .dll 的程序集中。 程序集包含一个介绍程序集的类型、版本和区域性的清单。
执行 C# 程序时,程序集将加载到 CLR。 CLR 会直接执行实时 (JIT) 编译,将 IL 代码转换成本机指令。 CLR 可提供其他与自动垃圾回收、异常处理和资源管理相关的服务。 CLR 执行的代码有时称为“托管代码”。而“非托管代码”被编译成面向特定平台的本机语言。

就是,你编译后变成一种中间语言,真正要运行的时候,还要在编译一下的(JIT),在CLR上运行

元组

这个其实很简单,之前疏忽掉了,因为实在用处不大,可以代替out,让方法返回一个元组,可以返回多个数据

(double, int) t1 = (4.5, 3);
Console.WriteLine($"Tuple with elements {t1.Item1} and {t1.Item2}.");
// Output:
// Tuple with elements 4.5 and 3.

(double Sum, int Count,string str) t2 = (4.5, 3,"引用类型");
Console.WriteLine($"Sum of {t2.Count} elements is {t2.Sum}.");

真正让我觉得有意义的是,我在思考这个元组里面可以放应用类型的,那到底怎么算?是值类型还是引用类型?
这篇文章的4.2回答了我的问题,我觉得写的很不错,链接
同时也说明了我大学的时候确实好多科目没有认真听讲

————————

2022/11/24.今天学习到了两个部分,一个是关于IL中间语言,一个是关于元组的

IL

用 C# 编写的源代码被编译成符合 CLI 规范的中间语言 (IL)。 IL 代码和资源(如位图和字符串)存储在扩展名通常为 .dll 的程序集中。 程序集包含一个介绍程序集的类型、版本和区域性的清单。
执行 C# 程序时,程序集将加载到 CLR。 CLR 会直接执行实时 (JIT) 编译,将 IL 代码转换成本机指令。 CLR 可提供其他与自动垃圾回收、异常处理和资源管理相关的服务。 CLR 执行的代码有时称为“托管代码”。而“非托管代码”被编译成面向特定平台的本机语言。

用 C# 编写的源代码被编译成符合 CLI 规范的中间语言 (IL)。 IL 代码和资源(如位图和字符串)存储在扩展名通常为 .dll 的程序集中。 程序集包含一个介绍程序集的类型、版本和区域性的清单。
执行 C# 程序时,程序集将加载到 CLR。 CLR 会直接执行实时 (JIT) 编译,将 IL 代码转换成本机指令。 CLR 可提供其他与自动垃圾回收、异常处理和资源管理相关的服务。 CLR 执行的代码有时称为“托管代码”。而“非托管代码”被编译成面向特定平台的本机语言。

就是,你编译后变成一种中间语言,真正要运行的时候,还要在编译一下的(JIT),在CLR上运行

元组

这个其实很简单,之前疏忽掉了,因为实在用处不大,可以代替out,让方法返回一个元组,可以返回多个数据

(double, int) t1 = (4.5, 3);
Console.WriteLine($"Tuple with elements {t1.Item1} and {t1.Item2}.");
// Output:
// Tuple with elements 4.5 and 3.

(double Sum, int Count,string str) t2 = (4.5, 3,"引用类型");
Console.WriteLine($"Sum of {t2.Count} elements is {t2.Sum}.");

真正让我觉得有意义的是,我在思考这个元组里面可以放应用类型的,那到底怎么算?是值类型还是引用类型?
这篇文章的4.2回答了我的问题,我觉得写的很不错,链接
同时也说明了我大学的时候确实好多科目没有认真听讲