java类引用的问题

Python018

java类引用的问题,第1张

1.类之间不能调用各自的私有方法;

2.一个类只能直接调用另一个类的public static方法;

3.一个类只能在new出另一个类的时候才能调用它的public方法;

4.一个类要调用另一个类的方法时,2个类必须在同一个包中,不在同一个包的话需要import包;

5.只有子类可以调用父类的protect方法;

6.子类不可以调用抽象父类的抽象方法(需要重写);

7.匿名内部类中的方法无法被其他类调用;

暂时想到这么多。

引用包,如:import java.util.Dateimport java.util.Calendar

实例化对象,并调用类里面的方法,如:

Calendar calendar = Calendar.getInstance()

// 从一个 Calendar 对象中获取 Date 对象

Date date = calendar.getTime()

//使用给定的 Date 设置此 Calendar 的时间

calendar.setTime(date)

calendar.set(Calendar.DAY_OF_MONTH, 8)

System.out.println("当前时间日设置为8后,时间是:" + calendar.getTime())

calendar.add(Calendar.HOUR, 2)

System.out.println("当前时间加2小时后,时间是:" + calendar.getTime())

calendar.add(Calendar.MONTH, -2)

System.out.println(“当前日期减2个月后,时间是:" + calendar.getTime())

java中有两种数据类型:基本类型和引用类型。\x0d\x0a基本类型有8个:\x0d\x0a整数类型 byte、short、int、long\x0d\x0a浮点数类型 float、double\x0d\x0a字符型 char\x0d\x0a布尔类型 boolean\x0d\x0a引用类型包括三种:\x0d\x0a类 Class\x0d\x0a接口 Interface\x0d\x0a数组 Array\x0d\x0a基本类型是通过诸如 int a = 5long b = 6L的形式来定义的,称为自动变量,自动变量存放的是字面值,不是类的实例,它存放在内存的堆栈中,数据大小和生存期必须是确定的,存取速度比较快,在堆栈中的字面值可以共享,也就是说我们定义一个int a = 5然后又定义了一个int b = 5这时a与b在内存中指向的是同一个字面常量。\x0d\x0a引用类型一般是通过new关键字来创建,比如Integer num = new Integer(3)它存放在内存的堆中,可以在运行时动态的分配内存大小,生存期也不必事先告诉编译器,当引用类型变量不被使用时,Java内部的垃圾回收器GC会自动回收走。引用变量中存放的不是变量的内容,而是存放变量内容的地址。\x0d\x0a在参数传递时,基本类型都是传值,也就是传递的都是原变量的值得拷贝,改变这个值不会改变原变量,而引用类型传递的是地址,也就是参数与原变量指向的是同一个地址,所以如果改变参数的值,原变量的值也会改变。这点要注意。\x0d\x0a在java中,8种基本类型在java中都有对应的封装类型,也就是引用类型:\x0d\x0a整数类型 Byte、Short、Integer、Long\x0d\x0a浮点数类型 Float、Double\x0d\x0a字符型 Character\x0d\x0a布尔类型 Boolean\x0d\x0a有时候我们会看到这样的语句 Integer num = 3Boolean b = true这样定义也能行得通,其实这里面有一个自动装箱的问题,即java自动把3这个字面常量封装成了Integer对象,同理也有自动拆箱。\x0d\x0a还有些需要注意的比较特殊的地方:\x0d\x0a1.Integer类型\x0d\x0aInteger i1 = 3\x0d\x0aInteger i2 = 3\x0d\x0a此时i1 == i2 返回的是true\x0d\x0aInteger i1 = 128\x0d\x0aInteger i2 = 128\x0d\x0a此时i1 == i2返回的是false,\x0d\x0a这时因为Integer的数值在-128~127之间时,即在int的范围内,默认是按照基本类型int来存放的,仍旧存在堆栈中,如果超出了int的范围,就按照对象的方式来存放和比较了。\x0d\x0a \x0d\x0a2、String类型\x0d\x0aString类型我们有时候也会直接这样定义:\x0d\x0aString s = "abc"\x0d\x0a这里的"abc"称为字符串常量,也是存在堆栈中的,s中存放的就是指向这个堆栈地址的引用,如果再定义一个\x0d\x0aString s1 = "abc"\x0d\x0a这时,s与s1存放的是同一个地址的引用,即s与s1指向的是同一个字符串常量,\x0d\x0as == s1的值是true,\x0d\x0a但是如果有\x0d\x0aString s2 = new String("abc")\x0d\x0a这时s == s2则为false,因为使用new之后,每次生成的对象都不是同一个,即使存储的内容相同。\x0d\x0a上面的s == s1,s == s2其实比较的都是地址,并不是里面的内容。如果要比较内容,可以使用equals()方法。\x0d\x0a\x0d\x0a其他的就不多说了,打起来太慢了,可以自己去看一下java编程思想。