C#定义了一个static方法,不调用这个方法,会占内存吗? 10
1、C#非静态类定义了一个static方法,不调用这个方法,会占内存吗?2、如果不占内存,那调用后是否占内存?3、如果调用后占内存,而且是否得到程序结果时,才回收内存?4...
1、C#非静态类定义了一个static方法,不调用这个方法,会占内存吗?
2、如果不占内存,那调用后是否占内存?
3、如果调用后占内存,而且是否得到程序结果时,才回收内存?
4、非静态类中的非静态方法呢?是否也跟static方法一样?
非静态类ClassA中有一个static方法A1,非静态类ClassB中有一个非static方法B1,
public class ClassA
{
public static A1()
{
ClassB b=new ClassB();
b.B1();
}
}
问题如下:
1、不调用ClaaA.A1()之前,A1是否占用了内存?
2、调用到ClaaA.A1()后,A1是否占用了内存?
3、如果占用了内存,什么情况下回收内存,是不是在程序结束时,才回收内存?
4、调用后A1()后的,A1中的ClassB被实例化,b什么情况下回收内存? 展开
2、如果不占内存,那调用后是否占内存?
3、如果调用后占内存,而且是否得到程序结果时,才回收内存?
4、非静态类中的非静态方法呢?是否也跟static方法一样?
非静态类ClassA中有一个static方法A1,非静态类ClassB中有一个非static方法B1,
public class ClassA
{
public static A1()
{
ClassB b=new ClassB();
b.B1();
}
}
问题如下:
1、不调用ClaaA.A1()之前,A1是否占用了内存?
2、调用到ClaaA.A1()后,A1是否占用了内存?
3、如果占用了内存,什么情况下回收内存,是不是在程序结束时,才回收内存?
4、调用后A1()后的,A1中的ClassB被实例化,b什么情况下回收内存? 展开
3个回答
展开全部
方法 (Method) 是一种类型定义,所以,它被存放在 Type Object 上,Type Object 是一个被分配在托管堆上的特殊类型,在同一个 AppDomain 中,每一个类型,都对应一个全局的 Type Object。每个引用类型的实例,都包含一个指向它的直接类型的 Type Object 的指针,每个 Type Object 也存在类似的指针,用来标识它的直接父类型的 Type Object。
当调用静态方法时,CLR 会根据方法调用去寻找其对应的 Type Object,然后,把方法 JIT,JIT 之后的方法是本机代码,可以直接运行,然后,这部分代码被加载进入内存,方法的参数被加载进入当前执行栈,原来的执行上下文地址也被记录到执行栈;方法开始执行,执行完后,执行栈中的返回地址被读出,然后 CLR 利用本机跳转指令,跳转到该返回至继续执行。
当调用实例方法时,CLR 会根据实例的 Type Object 指针找到对应的 Type Object,然后,把方法 JIT,JIT 之后的方法是本机代码,可以直接运行,然后,这部分代码被加载进入内存,该实例对象,以及方法的参数被加载进入当前执行栈 (实例对象永远是第一个参数,即 arg0,利用 ldarg0 指令进行读取),原来的执行上下文地址也被记录到执行栈;方法开始执行,执行完后,执行栈中的返回地址被读出,然后 CLR 利用本机跳转指令,跳转到该返回至继续执行。
如果方法已经被 JIT 过,则不会被第二次 JIT。
方法在 IL 中是以字节流的形式存在的,所以,它仍然会占据内存。
方法 JIT 之后会被驻留在该进程的地址空间里面,因此,它也会在运行时占据内存。
方法的元数据存放在程序集 MethodRef 以及 MethodDef 表中。
总结下,不管是实例还是静态方法,被JIT只存在一份,不过实例方法多了一个引用该实例的参数作为它的第一个参数!
当调用静态方法时,CLR 会根据方法调用去寻找其对应的 Type Object,然后,把方法 JIT,JIT 之后的方法是本机代码,可以直接运行,然后,这部分代码被加载进入内存,方法的参数被加载进入当前执行栈,原来的执行上下文地址也被记录到执行栈;方法开始执行,执行完后,执行栈中的返回地址被读出,然后 CLR 利用本机跳转指令,跳转到该返回至继续执行。
当调用实例方法时,CLR 会根据实例的 Type Object 指针找到对应的 Type Object,然后,把方法 JIT,JIT 之后的方法是本机代码,可以直接运行,然后,这部分代码被加载进入内存,该实例对象,以及方法的参数被加载进入当前执行栈 (实例对象永远是第一个参数,即 arg0,利用 ldarg0 指令进行读取),原来的执行上下文地址也被记录到执行栈;方法开始执行,执行完后,执行栈中的返回地址被读出,然后 CLR 利用本机跳转指令,跳转到该返回至继续执行。
如果方法已经被 JIT 过,则不会被第二次 JIT。
方法在 IL 中是以字节流的形式存在的,所以,它仍然会占据内存。
方法 JIT 之后会被驻留在该进程的地址空间里面,因此,它也会在运行时占据内存。
方法的元数据存放在程序集 MethodRef 以及 MethodDef 表中。
总结下,不管是实例还是静态方法,被JIT只存在一份,不过实例方法多了一个引用该实例的参数作为它的第一个参数!
展开全部
方法貌似没有分配内存这一说额,你应该问的是satatic变量吧
static方法或类只有在类的第一次访问时才会加载
程序启动时 即为之分配内存(方法在内存中主要是其变量和地址)
而static占用的资源不会被GC回收,直到程序结束
所以调用完ClassA.A1()后,内存依然被占用,直至程序结束才回收
static方法或类只有在类的第一次访问时才会加载
程序启动时 即为之分配内存(方法在内存中主要是其变量和地址)
而static占用的资源不会被GC回收,直到程序结束
所以调用完ClassA.A1()后,内存依然被占用,直至程序结束才回收
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
所有的静态方法只能加载一次,在加载完后就执行回收了
追问
你跟楼上回答的意思,正好相反,到底是谁对
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |