6 包,单例模式,访问修饰符(public、protected,private)Object String


1.   接口中所声明的方法都是抽象方法。接口中的方法都是 public 的。

2.   接口中也可以定义成员变量。接口中的成员变量都是publicfinalstatic的。

3.   一个类不能既是 final,又是 abstract 的。因为 abstract 的主要目的是定义一种约定, 让子类去实现这种约定,而 final 表示该类不能被继承,这样 abstract 希望该类可以 被继承而 final 明确说明该类不能被继承,两者矛盾。因此一个类不能既是 final 的, 又是 abstract 的。

4.   Design  Pattern(设计模式)。单例模式(Singleton):表示一个类只会生成唯一的一个对象。

public class SingletonTest
{
	public static void main(String[] args)
	{
		Singleton singleton = Singleton.getInstance();
		Singleton singleton2 = Singleton.getInstance();

		System.out.println(singleton == singleton2);
	}
}


class Singleton
{
	private static Singleton singleton;
	
	private Singleton()
	{
		
	}

	public static Singleton getInstance()
	{
		if(singleton == null)
		{
			singleton = new Singleton();
		}

		return singleton;
	}


}




5.   包(package)。用于将完成不同功能的类分门别类,放在不同的目录(包)下。包的命名规则:将公司域名反转作为包名。(包名),对于包名:每个字母都需要小写。如果定义类的时候没有使用 package,那么Java 就认为我们所定义的类位于默认包里面(default package)。

6.   编译带有 package 声明的 Java 源文件有两种方式:

a)  直接编译,然后根据类中所定义的包名,逐一手工建立目录结构,最后将生成的 class文件放到该目录结构中(很少使用,比较麻烦)。

b)   使用编译参数 –d,方式为 javac –d .  源文件.java,这样在编译后,编译器会自动帮助我们建立好包所对应的目录结构。

7.   有两个包名,分别是 aa.bb.cc 与 aa.bb.cc.dd,那么我们称后者为前者的子包。

8.   导入(import),将使用 package 分离的各个类导入回来,让编译器能够找到所需要的类。

9.   import 的语法:import com.shengsiyuan.PackageTest;

10. import com.shengsiyuan.*,表示导入 com.shengsiyuan 包下面的所有类。

11. import aa.bb.*并不会导入 aa.bb.cc 包下面的类。这时需要这样写:

import aa.bb.*;

import aa.bb.cc.*;

12. 关于 package、import、class 的顺序问题:

a)  首先需要定义包(package),可选 b)    接下来使用 import 进行导入,可选 c)    然后才是 class 或 interface 的定义。

13. 如果两个类在同一个包下面,那么则不需要导入,直接使用即可。

14. 访问修饰符(access modifier)。

1)   public(公共的):被 public 所修饰的属性和方法可以被所有类访问。

2)   protected(受保护的):被 protected 所修饰的属性和方法可以在类内部、相同包 以及该类的子类所访问(除此之外,跟默认的是一样的)(子类不在同一个包也可以)

被子类所使用:在子类的内部所使用,即被子类继承

3)   private(私有的):被 private 所修饰的属性和方法只能在该类内部使用

4)   默认的(不加任何访问修饰符):在类内部以及相同包下面的类所使用。

15.   instanceof: 判断某个对象是否是某个类的实例。语法形式:引用名 instanceof 类 名(接口名),返回一个 boolean 值。

16. People people = new Man();

17.  System.out.println(people instanceof People); //结果为 true,因为 Man 是 People 的子 类,根据继承,子类就是父类,因此 Man 也可以看作是 People 的实例。

18. 相等性的比较(==)


1)   对于原生数据类型来说,比较的是左右两边的值是否相等。

2)   对于引用类型来说,比较左右两边的引用是否指向同一个对象,或者说左右两 边的引用地址是否相同。

19.   java.lang.Object 类。java.lang 包在使用的时候无需显式导入,编译时由编译器自动帮助我们导入。

20. API  (Application Programming Interface),应用编程接口。

21. 当打印引用时,实际上会打印出引用所指对象的 toString()方法的返回值,因为每个 类都直接或间接地继承自 Object,而 Object 类中定义了 toString(),因此每个类都有 toString()这个方法。

public static void main(String[] args)
	{
		Object object = new Object();

		System.out.println(object);
		System.out.println(object.toString());
}



22. 关于进制的表示:16 进制,逢 16 进一,16 进制的数字包括:0~9,A,B,C,D,E,F,

23.equals()方法,该方法定义在Object类当中,因此Java中的每个类都具有该方法, 对于Object类的equals()方法来说,它是判断调用equals()方法的引用与传进来的引

用是否一致,即这两个引用是否指向的是同一个对象

对于Object类的equals()方 法来说,它等价于==

<span style="font-size:24px;">Java源码</span>
<span style="font-size:24px;">public boolean equals(Object obj) {
        return (this == obj);
    }</span>

24.对于String类的equals()方法来说,它是判断当前字符串与传进来的字符串的内容是否一致。(首先判断是否长度一致,然后按字符比较)

Java String 源码
public boolean equals(Object anObject) {
        if (this == anObject) {
            return true;
        }
        if (anObject instanceof String) {
            String anotherString = (String) anObject;
            int n = value.length;
            if (n == anotherString.value.length) {
                char v1[] = value;
                char v2[] = anotherString.value;
                int i = 0;
                while (n-- != 0) {
                    if (v1[i] != v2[i])
                            return false;
                    i++;
                }
                return true;
            }
        }
        return false;
    }



25. 对于 String 对象的相等性判断来说,请使用 equals()方法,而不要使用==

26. String 是常量,其对象一旦创建完毕就无法改变。当使用+拼接字符串时,会生成新 的String 对象,而不是向原有的 String 对象追加内容。

*************************************String Pool(字符串池)**********************************

28. String s = “aaa”;(采用字面值方式赋值)

1)   查找 String Pool 中是否存在“aaa”这个对象,如果不存在,则在 String Pool 中创建 一个“aaa”对象,然后将 String  Pool 中的这个“aaa”对象的地址返回来,赋给引

用变量 s,这样 s 会指向 String Pool 中的这个“aaa”字符串对象

2)   如果存在,则不创建任何对象,直接将 String Pool 中的这个“aaa”对象地址返回来, 赋给s 引用。

String str3 = "bbb";
String str4 = "bbb";
System.out.println(str3 == str4);
创建Str3时,字符串池没有bbb对象,先创建,并把bbb的地址返回给str3,创建str4时,字符串池中有bbb对象,直接返回bbb对象的地址,所有str3==str4,因为二者地址相同

29. String s = new String(“aaa”);

1)   首先在 String Pool 中查找有没有“aaa”这个字符串对象,如果有,则不在 String Pool 中再去创建“aaa”这个对象了,直接在堆中(heap)中创建一个“aaa”字符串对象,然后将堆中的这个“aaa”对象的地址返回来,赋给 s 引用,导致 s 指向了堆中 创建的这个“aaa”字符串对象。

2)     如果没有,则首先在 String Pool 中创建一个“aaa“对象,然后再在堆中(heap)创 建一个”aaa“对象,然后将堆中的这个”aaa“对象的地址返回来,赋给 s 引用, 导致 s 指向了堆中所创建的这个”aaa“对象。

<strong><span style="font-size:24px;">String s = "hello";
String s1 = "hel";
String s2 = "lo";

System.out.println(s == s1 + s2); //相当于比较两个对象的地址

System.out.println("----------------");

System.out.println(s == "hel" + "lo");//相当于比较字符串池中是否存在hello</span></strong>

intern()方法  寻找池中对象 

package testPackage;
class Test {
    public static void main(String[] args) {
        String hello = "Hello", lo = "lo";
        System.out.print((hello == "Hello") + " ");
        System.out.print((Other.hello == hello) + " ");
        System.out.print((other.Other.hello == hello) + " ");
        System.out.print((hello == ("Hel"+"lo")) + " ");
        System.out.print((hello == ("Hel"+lo)) + " ");
        System.out.println(hello == ("Hel"+lo).intern());
    }
}
class Other { static String hello = "Hello"; }
结果是:

true true true true false true



转载于:https://my.oschina.net/900116/blog/482259

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值