Java 基础知识点(必知必会其二)

   1.如何将数字输出为每三位逗号分隔的格式,例如“1,234,467”?   

 1 package com.Gxjun.problem;
 2 
 3 import java.text.DecimalFormat;
 4 import java.util.Scanner;
 5 
 6 
 7 /*
 8  * 如何将数字输出为每三位逗号分隔的格式,
 9  * 例如“1,234,467”?
10  * */
11 
12  public class FloatDirve {
13   
14   public static void main(String args []){
15      Scanner  reader = new Scanner(System.in);
16       while(reader.hasNext()){
17         System.out.println(funcFormat(reader.nextDouble()));
18       }
19    }
20   /* 使用一个方法来处理这个格式 */
21   public static String funcFormat(double doub){
22     String str="###";
23     int len=String.valueOf(doub).length();
24     for(int i=3;i<=len;i+=3){
25          str+=",###";
26     }
27     DecimalFormat decf = new DecimalFormat();
28     decf.applyPattern(str);
29    return decf.format(doub);
30   }
31 }

 2.如何将字符串转换为Boolean对象?

 1 package com.Gxjun.problem;
 2 
 3 /*
 4  * 如何将字符串转换为Boolean对象?
 5  * */
 6 
 7  public class StringToBoolean {
 8      public static void main(String args []){
 9      
10          System.out.println(new Boolean("true"));     
11          System.out.println(new Boolean("wahaha"));     
12          System.out.println(new Boolean("Gxjun"));     
13          System.out.println(new Boolean("false"));     
14   }
15 }
16  

   3.如何将一个四字节转换为一个整数?以及反过来

 1 package com.Gxjun.problem;
 2 
 3 /**
 4  * 如何将一个四字节转换为一个整数?以及反过来
 5  * */
 6 public class ByteToInt {
 7     
 8   public static void main(String args[]){
 9      byte[] byy = new byte[4];  //定义一个四字节的数组
10     for(int i=0;i<4;i++){
11       byy[i]=(byte) (i+1);
12     }   
13        bytetoint(byy);
14       inttobyte(16909060);
15   }
16   
17   /*
18    * byte[]转化为Intgter 
19    */
20   public static void bytetoint(byte b[]){
21     System.out.println(((b[0]&0x000000ff)<<24)|((b[1]&0x000000ff)<<16)|((b[2]&0x000000ff)<<8)|(b[3]&0x000000ff));       
22    }
23    /*
24     * Intgter转为byte[]其实就是一个逆过程 
25     */
26   public static void inttobyte(int num){
27       //这里需要考虑大端和小端的问题,对于不同的语言,有不同的方式
28      System.out.println((((byte)(num>>24))+""+((byte)(num>>16))+""+(byte)(num>>8))+""+(byte)num+"");       
29   }
30 }

 对于上面的字节转化为 int 时候,为何要进行&oxff操作,以及如果换成其他语言或者开发系统环境时,又该如何如何修改!!!!

     上面是将byte[]转化十六进制的字符串,注意这里b[ i ] & 0xFF将一个byte和 0xFF进行了与运算,然后使用Integer.toHexString取得了十六进制字符串,可以看出 b[ i ] & 0xFF运算后得出的仍然是个int,那么为何要和 0xFF进行与运算呢?直接 Integer.toHexString(b[ i ]);,将byte强转为int不行吗?答案是不行的. 其原因在于:    1.byte的大小为8bits而int的大小为32bits    2.java的二进制采用的是补码形式     ==================以下文字貌似有问题===================      在这里先温习下计算机基础理论 byte是一个字节保存的,有8个位,即8个0、1。 8位的第一个位是符号位,  也就是说0000 0001代表的是数字1  1000 0000代表的就是-1  所以正数最大位0111 1111,也就是数字127  负数最大为1111 1111,也就是数字-128 上面说的是二进制原码,但是在java中采用的是补码的形式,下面介绍下什么是补码 1、反码:         一个数如果是正,则它的反码与原码相同;         一个数如果是负,则符号位为1,其余各位是对原码取反; 2、补码:利用溢出,我们可以将减法变成加法        对于十进制数,从9得到5可用减法:        9-4=5    因为4+6=10,我们可以将6作为4的补数        改写为加法:        9+6=15(去掉高位1,也就是减10)得到5.        对于十六进制数,从c到5可用减法:        c-7=5    因为7+9=16 将9作为7的补数        改写为加法:        c+9=15(去掉高位1,也就是减16)得到5.     在计算机中,如果我们用1个字节表示一个数,一个字节有8位,超过8位就进1,在内存中情况为(100000000),进位1被丢弃。     ⑴一个数为正,则它的原码、反码、补码相同     ⑵一个数为负,刚符号位为1,其余各位是对原码取反,然后整个数加1 - 1的原码为                10000001 - 1的反码为                11111110                                                    + 1 - 1的补码为                11111111 0的原码为                 00000000 0的反码为                 11111111(正零和负零的反码相同)                                           +1 0的补码为               100000000(舍掉打头的1,正零和负零的补码相同) Integer.toHexString的参数是int,如果不进行&0xff,那么当一个byte会转换成int时,由于int是32位,而byte只有8位这时会进行补位, 例如补码11111111的十进制数为-1转换为int时变为11111111111111111111111111111111好多1啊,呵呵!即0xffffffff但是这个数是不对的,这种补位就会造成误差。 和0xff相与后,高24比特就会被清0了,结果就对了。 ---- Java中的一个byte,其范围是-128~127的,而Integer.toHexString的参数本来是int,如果不进行&0xff,那么当一个byte会转换成int时,对于负数,会做位扩展,举例来说,一个byte的-1(即0xff),会被转换成int的-1(即0xffffffff),那么转化出的结果就不是我们想要的了。 而0xff默认是整形,所以,一个byte跟0xff相与会先将那个byte转化成整形运算,这样,结果中的高的24个比特就总会被清0,于是结果总是我们想要的。

                                                     ---------------------------- 鸣谢桔子园作者 ,上述段落引自   http://www.blogjava.net/orangelizq/archive/2008/07/20/216228.html

  1。 如何获取当前的月份?

 1 package com.Gxjun.problem;
 2 
 3 import java.util.Calendar;
 4 
 5  //如何获取当前的月份?
 6 public class Javafrom {
 7     
 8   public static void main(String args[] ){
 9     int  moth = Calendar.MONTH+1;
10      System.out.println(moth);
11   }
12 }

  2.如何获取指定日期所在的周从哪一天开始?

1 package com.Gxjun.problem;
2 import java.util.Calendar;
3  //如何获取指定日期所在的周从哪一天开始?
4 public class DateForJava {
5    public static void main(String args []){
6     System.out.println(Calendar.DATE);       
7    }
8 }

  3.如何知道现在距离指定的时间还有多久?

 1 package com.Gxjun.problem;
 2 
 3 //如何知道现在距离指定的时间还有多久?
 4 import java.text.ParseException;
 5 import java.text.SimpleDateFormat;
 6 import java.util.Date;
 7 
 8 public class JavaTr {
 9     public static void main(String[] args) {
10         try {
11               test("2015-04-29",30);
12             } catch (ParseException e) {
13                 e.printStackTrace();
14         }
15     }
16     
17   static void test(String d, int day) throws ParseException{
18            Date date = new Date();
19             long a = date.getTime();
20           SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
21           long b = sdf.parse(d).getTime();
22           int success = (int) ((b-a)/(1000*60*60*24));  //1000毫秒*60分钟*60秒*24小时 = 天
23           System.out.println("距离"+d+"还有"+success+"天");
24           if(success <= day){  //如果距离那天天数等于day
25             //把值存到某个地方,或者返回回去
26           }
27      }
28 }

  4.如何知道两个时间段是否有重合的部分?

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏函数式编程语言及工具

SDP(9):MongoDB-Scala - data access and modeling

    MongoDB是一种文件型数据库,对数据格式没有硬性要求,所以可以实现灵活多变的数据存储和读取。MongoDB又是一种分布式数据库,与传统关系数据库不同...

3894
来自专栏Jed的技术阶梯

图解 Java 位运算

需要说明的是,在计算机中,数字是以补码的形式存在的,计算也是用补码来进行计算,计算后的结果也是补码

2962
来自专栏web前端教室

javascript 红皮高程(15)

接上一次,今次来讲操作符的 按位非(NOT) 这个,按位非操作符是,~ 波浪线,而它的执行结果,就是返回数值的反码。 ========== 这个反码是什么意思?...

1835
来自专栏ml

位运算的方法,大结

Title:       位操作基础篇之位操作全面总结 Author:     MoreWindows E-mail:      morewindows@126...

5828
来自专栏swag code

HeapSort-堆排序-完全二叉树

堆可以看成是一棵完全二叉树,根节点永远是最大的值。每个根的子节点有两个,左子节点是2*i+1,右子节点是2*i+2。每个子节点的父节点是(i-1)/2。子节点...

1974
来自专栏Albert陈凯

2018-04-17 Java的Collection集合类3分钟搞掂Set集合前言

3分钟搞掂Set集合 前言 声明,本文用的是jdk1.8 现在这篇主要讲Set集合的三个子类: HashSet集合 A:底层数据结构是哈希表(是一个元素为链...

2977
来自专栏進无尽的文章

编码篇-开发中关于数字的那些事儿

在日常的开发中我们随时都会跟数字打着交道,对数字的处理也是很平常的事,本文仅对常用的数字操作一个小结,当一个笔记方便日后查看,也希望读者能从中收获些感觉有用的知...

1191
来自专栏五分钟学算法

LeeCode题目图解

There is an English version of README here. just click it!

1542
来自专栏码匠的流水账

聊聊storm TridentTopology的构建

storm-core-1.2.2-sources.jar!/org/apache/storm/trident/TridentTopology.java

1683
来自专栏数据结构与算法

P2580 于是他错误的点名开始了

题目背景 XS中学化学竞赛组教练是一个酷爱炉石的人。 他会一边搓炉石一边点名以至于有一天他连续点到了某个同学两次,然后正好被路过的校长发现了然后就是一顿欧拉欧拉...

2937

扫码关注云+社区