java 静态方法

在使用java的时候,你会发现,有些对象,需要new ,有些则不需要时,比如Math类

int c = Math.abs(2);

如果你查看源码就会大致的发现,里面的属性和方法都是静态的:

    public static double sin(double a) {
        return StrictMath.sin(a); // default impl. delegates to StrictMath
    }

    public static double asin(double a) {
        return StrictMath.asin(a); // default impl. delegates to StrictMath
    }

如果说:实例变量和实例 方法 是属于某个对象的话,

那么:静态变量,和静态方法 就是属于所有对象的,所以不用new 出一个变量就可以使用。

这样的,一般用做java中些工具类的室时候用的比较多。

时间: 2024-11-05 16:27:43

java 静态方法的相关文章

内部类访问外部类的变量必须是final吗,java静态方法中不能引用非静态变量,静态方法中不能创建内部类的实例

内部类访问外部类的变量必须是final吗? 如下:class A{int i = 3;public void shout(){ class B{public void shout1(){System.out.println(i);} }B b=new B();b.shout1();} public static void main(String [] args){A a=new A();a.shout();} }可正常输出3,证明可以访问类的变量i,但改为下面的方式:class A{public

java静态方法的重写,为什么不能?

JAVA静态方法形式上可以重写,但从本质上来说不是JAVA的重写.因为静态方法只与类相关,不与具体实现相关,声明的是什么类,则引用相应类的静态方法(本来静态无需声明,可以直接引用),看下例子: Java代码   class Base{ static void a( ){System.out.println("A");  } void b( ){System.out.println("B"); } } public class  Inherit extends Bas

java静态方法(变量)、非静态方法(变量)区别

java静态方法.静态变量在调用时生成唯一标识,即在内存中给定一个静态位子,这样在调用时可以直接找到,而且会节省内存.但如果声明的静态方法.静态变量过多,会占用过多内存,有可能导致内存溢出. 非静态方法.非静态变量有gc管理,每new一个对象时,在堆上分配一块内存,不用时由gc回收. 即,静态方法.静态变量预先分配,非静态方法.非静态变量动态分配. 所有的class.static变量位于方法区,方法区既可以在堆上,又可以在栈上.

java 静态方法和实例方法的区别

静态方法和实例方法的区别主要体现在两个方面:   在外部调用静态方法时,可以使用"类名.方法名"的方式,也可以使用"对象名.方法名"的方式.而实例方法只有后面这种方式.也就是说,调用静态方法可以无需创建对象.   静态方法在访问本类的成员时,只允许访问静态成员(即静态成员变量和静态方法),而不允许访问实例成员变量和实例方法:实例方法则无此限制.   下面几个例子展示了这一区别.   1.调用静态方法示例. //-----------hasStaticMethod.j

java 静态方法和单例模式的区别

1.首先明白内存问题 Java内存分为两部分:堆内存.栈内存 无论是静态方法还是非静态方法,在内存中都只有一份:非静态方法在调用时会默认使用this传入当前对象: 2.静态方法不可以重写 静态方法是在 3.使用上 静态方法不需要new实例就可以调用:非静态方法必须new实例才可以调用: 4.加载时机的问题 静态方法是在类加载的时候就加载到内存中:

El中调用java静态方法

最近在项目中遇到需要调用静态方法的问题,形如: <c:forEach items="beans" var="bean"> <p>总数:${com.example.Tools.getTotal(bean.nums)}</p> </c:forEach> 不过上面的代码不能通过编译,只能寻求其他办法.经过查阅各种文档,找到了3种解决办法. 1,直接为Bean创建一个get方法 public double getTotal()

Java静态方法,静态变量,初始化顺序

1. 静态方法: 成员变量分为实例变量和静态变量.其中实例变量属于某一个具体的实例,必须在类实例化后才真正存在,不同的对象拥有不同的实例变量.而静态变量被该类所有的对象公有(相当于全局变量),不需要实例化就已经存在. 方法也可分为实例方法和静态方法.其中,实例方法必须在类实例化之后通过对象来调用,而静态方法可以在类实例化之前就使用.与成员变量不同的是:无论哪种方法,在内存中只有一份——无论该类有多少个实例,都共用同一个方法. 实例方法的调用: ClassA a = new ClassA();  

java静态方法调用非静态方法

我们都知道,静态static方法中不能调用非静态non-static方法,准确地说是不能直接调用non-static方法.但是可以通过将一个对象的引用传入static方法中,再去调用该对象的non-static方法. 其实这个事实的应用很经常,以至于我们不去重视:在主函数(static方法)中我们经常创建某个类的实例,再利用其饮用变量调用它的非静态方法. //StaticMethodTest.java //A ststic method cannot call a non-static meth

java静态方法和实例化方法的区别(copy)

[资料来源] http://blog.csdn.net/biaobiaoqi/article/details/6732117 方法是我们每天都在写得,很多程序员大多都使用实例化方法,而很少使用静态方法,问原因也说不出来所以然,或者简单的回答两者定义的区别,静态方法不需要new就可以使用 实例化方法需要new了以后才可以使用....我们真的理解了吗? 从实际项目开发说起,这里有开发项目的三种方式: 开发项目中把BLL和DAL分开,在BLL调用DAL的代码. 一.在DAL中使用静态方法,不创建实例直