JAVA中的一些比较方法详解

一. \\. 详解

在java中 \代表转义字符 \n \t 等,而 \\ 代表一个反斜杠 而.代表一个元字符要表示一个.就需要用 要用\.所以"\\." 在实际编译中 就代表 .

 

二. valueOf 详解

如果存在任意原始值,它就默认将对象转换为表示它的原始值;对象是复合值,而大多数对象无法真正表示为一个原始值,因此默认的valueOf()方法简单地返回对象本身,而不是返回一个原始值

 

三.  <<< 详解

1、>>表示是带符号的右移:按照二进制把数字右移指定数位,高位如符号位为正补零,符号位负补一,低位直接移除

2、>>>表示无符号的右移:按照二进制把数字右移指定数位,高位直接补零,低位移除。

 

四. split(".")[1] 详解

先用split('.')方法将字符串以"."开割形成一个字符串数组,然后再通过索引[1]取出所得数组中的第二个元素的值

 

五. return;  详解:

这是种错误的用法,但是没有触犯编译器的底限。一般情况下,返回类型是void的函数使用return语句是为了引起函数的强制结束,这种return的用法类似于循环结构中的break语句

return语句有两种形式: return; return expression。不带返回值的return语句只能用于返回类型为void的函数。在返回类型为void的函数中,return返回语句不是必需的,隐式的return发生在函数的最后一个语句完成时。

return 表示从被调函数返回到主调函数继续执行,返回时可附带一个返回值,由return后面的参数指定。 return通常是必要的,因为函数调用的时候计算结果通常是通过返回值带出的。 如果函数执行不需要返回计算结果,也经常需要返回一个状态码来表示函数执行的顺利与否(-1和0就是最常用的状态码),主调函数可以通过返回值判断被调函数的执行情况。

 

六. tailf、tail -f、tail -F三者区别 详解

tail -f      等同于--follow=descriptor,根据文件描述符进行追踪,当文件改名或被删除,追踪停止

tail -F     等同于--follow=name  --retry,根据文件名进行追踪,并保持重试,即该文件被删除或改名 后,如果再次创建相同的文件名,会继续追踪

tailf        等同于tail -f -n 10(貌似tail -f或-F默认也是打印最后10行,然后追踪文件),与tail -f不同的是,如果文件不增长,它不会去访问磁盘文件,所以tailf特别适合那些便携机上跟踪日志文件,因为它减少了磁盘访问,可以省电

 

七.Null,isEmpty(),””三者区别 详解

Null:对象为空,null只能分辨出值是否不分配内存空间

isEmpty():值为空

1.如果不分配内存空间,不能用isEmpty(),否则报空指针异常

2.isEmpty()不能分辨出值是空还是空字符串

“”:.不管值是否分配内存空间都不会报错

 

八. null和""的区别

String s=null;string.trim()就会抛出为空的exception   

String s="";   string.trim()就不会抛,为什么? 

答:NULL代表声明了一个空对象,根本就不是一个字符串。   ""代表声明了一个对象实例,这个对象实例的值是一个长度为0的空字符串。

NULL代表声明了一个空对象,对空对象做任何操作都不行的,除了=和==   ""是一个字符串了,只是这个字符串里面没有内容了

String s=null;只是定义了一个句柄,也就是说你有了个引用,但是这个引用未指向任何内存空间   

String s="";这个引用已经指向了一块是空字符串的内存空间,是一个实际的东东了,所以你可以对它操作,而不用担心什么了

而且,null可以赋值给任何对象.""就不行了.

这里""和NULL绝对是两个概念   ""代表一个字符串存在,它的值就是“”   

NULL代表字符串根本没有实际的值,你并不知道它是什么。。。

哦,我明白了,意思就是String   string   =   null   跟String   string;是一回事儿

null是空对象     ""是空字符串

String s=null;//null是未分配堆内存空间   

String   a;//分配了一个内存空间,没存入任何对象   

String   a="";//分配了一个内存空间,存了一个字符串对象

 

问题二:

String s;和String s=null;和String s="a";有什么区别?   

针对这三种情况,使用out.println(s);的时候,第一个会出现异常,第二个会输出null.第三个则会输出a.   

这是为什么呢?这三句声明语句,各自作了什么呢?

答:第一个只是定义了一个String类型变量s,并没有给它赋初值,在Java中,默认在使用一个变量的时候必须赋予它初值(降低风险)。

第二个和第三个都定义了String类型变量s,并赋予它初值,只不过第二个赋予的值为null(空)罢了

主要要理解的是String s; s为一个引用~~它不是对象   

第一个是没有初始化的引用;   

第二个为空引用;

第三个是在字符串池里写入一个字符'a',然后用s指向它。

另外,   

String s="a"和String s=new String("a");是有本质上的区别的   

前者是在字符串池里写入一个字符'a',然后用s指向它;

后者是在堆上创建一个内容为"a"的字符串对象。

String   str="aaa";                    //于栈上分配内存

String   str=new   String("aaa");      //于堆上分配内存

String s; 系统会自动赋值null

String s;只是给s分配一个内存空间   

String s=null;是分配的空间中存储的值为空值   

String s="a";这句就不用我多说了分配的空间的值为字符a

 

问题三:

声明了一个string a;变量    

在以后的判断中,a==""和a==null有何不同?  

答:如果没有给a赋过值,a==""会导致异常。     

在实际处理时,往往认为""和null代表相同的含义,即都代表无值。   

此时建议用如下语法:   if(a==null   ||   a=="")   

{   

}   

如果a为null,就不会执行后面的判断,直接返回true。   

null是用来判断引用类型是否分配了存储空间   ""是针对字符串的;   

string类型实际上是字符串指针,也即是一个引用类型   

所以如果没有给a赋过值,a==""会导致异常   

所以if(a==null   ||   a==""){}这种写法也是正确的

 

问题四:

String abc=null;String abc="";String abc;三种写法有什么区别?

答:1:创建一个空字符串对象,   2:创建一个字符串为空的字符串对象。   3:声明一个字符串对象,但并没有分配内存,而1,2已经分配了内存   

对于最后一种表示,你不能if(abc==null),或者int   length   =   abc.length();编译的时候会提示可能没有初始化.

String   abc=null;   

String   abc="";   

一般推荐使用第二种   

第一种abc指向null,很多时候要判断字符串是否为空时,容易漏掉这种情况,在调用String的相关方法的时候就会出错   

第二种则相对简单,String的方法都可以用,判断的时候也不会出错

1) String   abc=null;   2) String   abc;    3)String   a="";   4) String   b="";   5) String   c=new String("");   6) String   d=new String(""); //1)等于2),和C语言不同,JAVA为安全原因不允许一个悬挂引用,没有赋值的引用地址一律自动赋值为NULL,以防止访问到任意内存   //3)和4)中,变量a和b将会指向同一内存地址(""的地址)   //5)和6)中,变量c和d不会指向同一地址,而是两个""内容的地址,并且和a,b不同,实际上,3)和4)相当于new String("").intern().   //String类维护着一个字符串池,对于像3)和4)这样的赋值方法,String会在这个池中查找字符串是否已经在池中,如果在,就直接指向该地址,

如果不在,生成一个实例放入池中再指向那个地址,可见对于同样内容的字符串多次引用时3)4)的方法要比5)6)的方法剩内存,之所以这样做,是

因为String是一个内容不可变的量,运用的是设计模式GOF.FlyWeight   

但有个关键的一点,没有人说到,这就是:   

String s;在什么情况下可以等同于String s=null;而在什么情况下又不等同?!

考虑下面的代码:   //StringTest.java   public   class   StringTest   {      

    static   String   s;     //*   

    public   static   void   main(String[]   args)   {   

        //String   s;         //**   

        System.out.println(s);   

    }   

}     

编译并运行上面的代码,将打印null。

可见标有*号的行是自动初始化了的(s被自动初始化为null)。   

而如果把标有**号的行取消注释,代码将不能通过编译,这是因为这行定义的是本地变量,而本地变量是不会自动初始化的。

由此得出结论:

在成员变量的定义中,String s;等同于String s=null;

而在本地变量(方法变量)的定义中,String s;不等同于String s=null;,这时要使用s必须显式地赋值。

这些虽然是小知识点,但在实际应用中很重要,也很容易被一些人忽视,特此提出。

还有一点要说明的是:

只要是在方法在中定义变量都要显示赋初值,main()方法也不例外,而在方法之外编译器回自动赋初值。

 

九.If中null写在前面 

详解:在C语言里面,为了防止少敲一个等号,编程人员仍然能在编译的时候找到错误。因为if(name=null)是在编译的时候,不会出现错误,而if(null=name)是会编译出错,java中效果一样,

Integer.parseInt(String)的作用就是将String字符类型数据转换为Integer整型数据。

Integer.parseInt(String)遇到一些不能被转换为整型的字符时,会抛出异常。

str=bf.readLine() ;//bf是一个Buffer流,str是一个字符串
num=Integer.parseInt(str) ;//此处将str字符串转换为整型并存储到int类型的num中
其作用在于,若读取的str不为整型,则会报错,可以抛出异常解决此问题

 

十. intValue()方法和valueOf()方法 详解:
1.intValue()是把Integer对象类型变成int的基础数据类型;
  parseInt()是把String 变成int的基础数据类型;
  valueOf()是把给定的String参数转化成Integer对象类型;(现在JDK版本支持自动装箱拆箱了。)

注:  intValue()用法与另外两个不同,比如int i = new Integer("123"), j = i.intValue(); 相当于强制类型转换(强制类型转换事实上就是调用的这个方法)。
另外两个用法:Integer.valueOf(),Integer.parseInt()用的是Interger类名。
i.intValue()用的是对象i

2. Integer a=new Integer(1)
   Integer a=Integer.valueOf(1);
两个都是得到一个Integer对象,但是Integer.valueOf的效率高。

3.intValue()是java.lang.Number类的方法,Number是一个抽象类。Java中所有的数值类都继承它。也就是说,不单是Integer有intValue方法,Double,Long等都有此方法。
此方法的意思是:输出int数据。每个数值类中具体的实现是不同的。例如:
Float类和Double类的intValue方法,就是丢掉了小数位,而Long的intValue方法又不一样的

 

十一. compareTo()方法 详解:

compareTo()方法很简单就实现字符串大小比较的问题。该方法用于判断一个字符串是大于、等于还是小于另一个字符串。判断字符串大小的依据是根据它们在字典中的顺序决定的。

Str1.compareTo(Str2);
其返回的是一个int类型值。若Str1等于参数字符串Str2字符串,则返回0;若该Str1按字典顺序小于参数字符串Str2,则返回值小于0;若Str1按字典顺序大于参数字符串Str2,则返回值大于0。

 

十二. 正则表达式的一些字符  详解:

\ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个 向后引用、或一个八进制转义符。例如,'n' 匹配字符 "n"。'\n' 匹配一个换行符。序列 '\\' 匹配 "\" 而 "\(" 则匹配 "("。

^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 '\n' 或 '\r' 之后的位置。

$ 匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 '\n' 或 '\r' 之前的位置。

* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等价于{0,}。

+ 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。

? 匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等价于 {0,1}。

{n} n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。

  

{n,} n 是一个非负整数。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。

{n,m} m 和 n 均为非负整数,其中n <= m。最 

少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。

 

十三. A instanceof B  详解:

instanceof是Java的一个二元操作符,和==,>,<是同一类东东。由于它是由字母组成的,所以也是Java的保留关键字。它的作用是测试它左边的对象是否是它右边的类的实例,返回boolean类型的数据

用法: 某个实例对象      instanceof      某个类名 
result = object instanceof class
参数:
Result:布尔类型。
Object:必选项。任意对象表达式。
Class:必选项。任意已定义的对象类。
说明: 如果 object 是 class 的一个实例,则 instanceof 运算符返回 true。如果 object 不是指定类的一个实例,或者 object 是 null,则返回 false。

instanceof 通常用于根据不同的实例调用不同的方法:

1、在有继承关系的类中我们可以通过多态来调用不同实例中的不同方法:

例1:

  有三个类,类名以及它们之间的关系如下

   Animal (Superclass)     Dog(Subclass)     Cat(Subclass)

   则可得出如下对象

   Animal  animal =new Animal (); ====》animal  instanceof Animal    返回 true

   Dog   dog=new  Dog();====》dog  instanceof  Dog    返回 true

   Cat    cat=new  Cat();====》cat  instanceof  Cat    返回  true

   Animal  dog=new  Dog();====》dog  instanceof  Animal    返回 true

   Animal  cat=new  Cat();====》cat  instanceof  Animal    返回 true


  Animal dog=new Dog();
  Animal cat=new Cat();

  List list = new ArrayList();

  list.add(dog);
  list.add(cat);

  Iterator it = list.iterator();
  while (it.hasNext()) {
     it.next().animalDo();

  }
在这里我们可以在Dog与Cat类中重写Animal中的animalDo方法,通过调用animalDo方法,然后会自动根据不同的实例调用不同类中的方法.

2、

  Station s = new Station();
  Cell c = new Cell();


  List list = new ArrayList();

  list.add(s);
  list.add(c);


  Iterator it = list.iterator();
  while (it.hasNext()) {
   Object obj = it.next();
   if (obj instanceof Station ) {
    Station s1 = (Station ) obj;
    s1.stationDo();
   }
   if (obj instanceof Cell ) {
    Cell c1 = (Cell ) obj;
    c1.cellDo();
   }
  }


 在这里我们可以通过instanceof 判断结果,执行不同类中的相应动作方法(stationDo()、cellDo())。

一般在使用无泛型的集合( List、set等)时,比较多的使用  instanceof  ,由于集合能够存各种对象,所以在读取时一般要进行相应的判断。

 

String s=side.getString(44).trim();

If(s.split(“\\.”).length>2||(s.split(“\\.”).length==2&&s.split(“\\.”)[1].length()>4)){

Log.info(“单位:元,精度:4位”);

Throw new BussException(..... );

}

isFile():判断是否是文件,也可能是文件或者目录
exists():判断该文件是否存在

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值