MSIL Hello World
最近由于需要,开始阅读 MSIL 方面的东西。我读的是《.NET 探秘——MSIL 权威指南》(《Expert .NET 2.0 IL Assembler》中译版)。感觉没什么好说的,毕竟只要对 .NET 及其后面的东西了解一些,然后当做汇编来看,就好了。剩下的就是实践。
如书上所言,前面已经有人做出了这项研究了,如 Anders Liu、装配脑袋、Flier Lu。前辈们都是老手了,我也不好说什么,毕竟我刚刚入门。
这里就贴出昨晚写的一个 HelloWorld 程序吧。读了4天的收获。为了方便没学过 MSIL 的同志们,在上面都附上了实现同样功能的 C# 代码。
嗯,高级的东西还不敢说,要再仔细看,多练习才行啊。
.assembly extern mscorlib { auto }
.assembly MyIlApp { }
.module MyIlApp.exe
.namespace MyIlApp
{
// public struct VC
.class public value sealed auto VC
{
// public int val_int32;
.field public int32 val_int32
// public string val_string;
.field public string val_string
}
// public sealed class MainClass
.class public sealed auto ansi MainClass
{
// public static int _val;
.field public static int32 _val
// public static void check(int argument1)
.method public static void check(int32) cil managed
{
// string temp;
.locals init ([]string temp)
// if (MyIlApp.MainClass._val == argument1)
// {
// System.Console.WriteLine("The value equals to the argument.");
// }
// else
// {
// System.Console.WriteLine("The value does not equal to the argument.");
// }
ldsfld int32 MyIlApp.MainClass::_val
ldarg.0
beq TrueEqual
ldstr "The value does not equal to the argument."
call void [mscorlib]System.Console::WriteLine(string)
br ThisIsEnd
TrueEqual:
ldstr "The value equals to the argument."
call void [mscorlib]System.Console::WriteLine(string)
// temp = argument1.ToString(); // 注意这里用 call 而不是 callvirt,因为 argument1 是 int32 类型,未装箱的时候没有V表
ThisIsEnd:
ldarga.s
call instance string [mscorlib]System.Int32::ToString()
stloc.0
// System.Console.Write("The real value is:");
ldstr "The real value is: "
call void [mscorlib]System.Console::Write(string)
// System.Console.WriteLine(temp);
ldloc.0
call void [mscorlib]System.Console::WriteLine(string)
// return;
ret
}
// public static void Main()
.method public static void Main() cil managed
{
// .entrypoint 伪指令表示是程序入口点
.entrypoint
/* Test Case 1 */
// string input;
// int v;
.locals init ([] string input,
[] int32 v)
// System.Console.WriteLine("Hi. Please input a string:");
ldstr "Hi. Please input a string:"
call void [mscorlib]System.Console::WriteLine(string)
// input = System.Console.ReadLine();
call string [mscorlib]System.Console::ReadLine()
stloc.0
// System.Console.WriteLine(input);
ldloc.0
call void [mscorlib]System.Console::WriteLine(string)
// v = System.Int32.Parse(input);
ldloc.0
call int32 [mscorlib]System.Int32::Parse(string)
stloc.1
// MyIlApp.MainClass._val = 9000;
ldc.i4
stsfld int32 MyIlApp.MainClass::_val
// System.Console.WriteLine(MyIlApp.MainClass._val.ToString());
ldsflda int32 MyIlApp.MainClass::_val
call instance string [mscorlib]System.Int32::ToString()
call void [mscorlib]System.Console::WriteLine(string)
// MyIlApp.MainClass.check(v);
ldloc.1
call void [MyIlApp]MyIlApp.MainClass::check(int32)
/* Test Case 2 */
// VC vc1;
.locals init ([] valuetype [MyIlApp]MyIlApp.VC vc1)
// vc1.val_string = "Test string of VC";
ldloca.s
ldstr "Test string of VC"
stfld string MyIlApp.VC::val_string
// vc1.val_int32 = 8;
ldloca.s
ldc.i4.8
stfld int32 MyIlApp.VC::val_int32
// System.Console.WriteLine(vc1.val_string);
ldloca.s
ldfld string MyIlApp.VC::val_string
call void [mscorlib]System.Console::WriteLine(string)
// System.Console.WriteLine(vc1.val_int32.ToString()); // 《Expert .NET 2.0 IL Assembler》上说 ldflda “不能使用值类型的实例,也不能获取指向值类型实例的对象引用或指针”,有误。为了实现类似 a.X = 100(a 为 System.Drawing.Point 类型)这样的调用,需要用到 call 指令,也就需要用到 ldflda 而不是 ldfld;不过后者可以用在不访问实例函数/字段的情况下
ldloca.s
ldflda int32 MyIlApp.VC::val_int32
call instance string [mscorlib]System.Int32::ToString()
call void [mscorlib]System.Console::WriteLine(string)
// return;
ret
}
}
}
MSIL Hello World的更多相关文章
- Mono为何能跨平台?聊聊CIL(MSIL)
前言: 其实小匹夫在U3D的开发中一直对U3D的跨平台能力很好奇.到底是什么原理使得U3D可以跨平台呢?后来发现了Mono的作用,并进一步了解到了CIL的存在.所以,作为一个对Unity3D跨平台能力 ...
- 浅析MSIL中间语言——基础篇
一.开篇 研究MSIL纯属于个人喜好,说在前面MSIL应用于开发的地方很少,但是很大程度上能够帮着我们理解底层的原理,这是我了解MSIL的主要原因.托管代码表示应用程序的方法的功能,它们以微软的中间语 ...
- 写给自己的 程序集&msil 扫盲
嘴上不说 心里却想MD 这家伙在博客园装了这么久的高手 竟然连这都不会 ,我去噢. 程序集签名 .net 下 “程序集” 什么东东 ,反正就是听着挺牛x的,其实就是指“一堆程序”从我们传统的C++封装 ...
- 代码大全 MSIL语言程序设计
.NET平台的编译器会将高级语言(C#,VB.NET,F#)编译成MSIL(微软中间语言)格式.熟悉MSIL语言,可以读懂一些加密程序混淆过的算法,这些算法几乎不能还原成高级语言,但是可以还原成MSI ...
- MSIL 教程(三):类和异常处理(转)
转自:http://www.cnblogs.com/Yahong111/archive/2007/08/16/857771.html 续上文[翻译]MSIL 教程(二):数组.分支.循环.使用不安全代 ...
- MSIL 教程(二):数组、分支、循环、使用不安全代码和如何调用Win32 API(转)
转自:http://www.cnblogs.com/Yahong111/archive/2007/08/16/857574.html 续上文[翻译]MSIL 教程(一) ,本文继续讲解数组.分支.循环 ...
- MSIL解析一(转)
转自:http://www.cnblogs.com/Yahong111/archive/2007/08/15/857140.html 在网上发现了一个非常好的MSIL教程,可惜是英文版的,于是就翻译了 ...
- MSIL指令集
名称 说明 Add 将两个值相加并将结果推送到计算堆栈上. Add.Ovf 将两个整数相加,执行溢出检查,并且将结果推送到计算堆栈上. Add.Ovf.Un 将两个无符号整数值相加,执行溢出检查,并且 ...
- 解决:warning LNK4098: 默认库“MSVCRT”与其他库的使用冲突;找到 MSIL .netmodule 或使用 /GL 编译的模块;正在。。;LINK : warning LNK4075: 忽略“/INCREMENTAL”(由于“/LTCG”规范)
参考资料: http://blog.csdn.net/laogaoav/article/details/8544880 http://stackoverflow.com/questions/18612 ...
随机推荐
- 【noip 2005】 采药
题目描述 辰辰是个天资聪颖的孩子,他的梦想是成为世界上最伟大的医师.为此,他想拜附近最有威望的医师为师.医师为了判断他的资质,给他出了一个难题.医师把他带到一个到处都是草药的山洞里对他说:" ...
- 【转】POJ题目分类推荐 (很好很有层次感)
OJ上的一些水题(可用来练手和增加自信) (poj3299,poj2159,poj2739,poj1083,poj2262,poj1503,poj3006,poj2255,poj3094)初期: 一. ...
- Android 中关于ListView分割线的设置
今天发现许多App上的listview的item之间的分割线都只显示了右边一部分,而左边的那一半则没有,第一反应则是给分割线设置一张背景图片就ok了: android:divider="@m ...
- request对象和response对象
Request 和 Response 对象起到了服务器与客户机之间的信息传递作用.Request 对象用于接收客户端浏览器提交的数据,而 Response 对象的功能则是将服务器端的数据发送到客户端浏 ...
- 设计一个用于人事管理的People(人员)类
#include <iostream> #include <string> using namespace std; class Date //日期类 { private: i ...
- Web打印组件jatoolsPrinter
应用web化,不论对开发商,还是对用户来说,实在是一种很经济的选择,因为基于web的应用,客户端的规则很简单,容易学习,容易维护,容易发布.但对程序员来说,因为浏览器的局限性,却要面对很多挑战.怎么样 ...
- 阿里聚安全受邀参加SFDC安全大会,分享互联网业务面临问题和安全创新实践
现今,技术引领的商业变革已无缝渗透入我们的日常生活,「技术改变生活」的开发者们被推向了创新浪潮的顶端.国内知名的开发者技术社区 SegmentFault 至今已有四年多了,自技术问答开始,他们已经发展 ...
- 可在广域网部署运行的QQ高仿版 -- GGTalk总览
(最新版本:V5.5,2016.12.06 增加对MySQL数据库的支持.) (android移动端:2015.09.24 最初发布 ,2016.11.25 最后更新) GGTalk(简称GG)是 ...
- 迷你MVVM框架 avalonjs 入门教程
新官网 请不要无视这里,这里都是链接,可以点的 OniUI组件库 学习教程 视频教程: 地址1 地址2 关于AvalonJs 开始的例子 扫描 视图模型 数据模型 绑定 作用域绑定(ms-contro ...
- Google分布式构建软件之四:分发构建结果
注:本文英文原文在google开发者工具组的博客上[需要FQ],以下是我的翻译,欢迎转载,但请尊重作者版权,注名原文地址. 之前的文章,介绍了Google在分布式构建软件过程中,如何把构建过程分发到许 ...