Pourquoi les packagers apparaissent-ils ?
Les types de données de base n'ont pas les caractéristiques des objets. Par exemple, les types de base ne peuvent pas appeler de méthodes et ont des fonctions simples. Afin que les types de données de base aient également les caractéristiques des objets, Java fournit une classe wrapper pour chaque type de données de base, afin que les types de données de base puissent être manipulés comme des objets. Chaque type de base a une classe d'emballage correspondante :
Je pense que vous connaissez tous très bien les types de données de base, tels que int, float, double, boolean, Char et coll. Les types de données de base n'ont pas les caractéristiques des objets. Par exemple, les types de données de base ne peuvent pas appeler de méthodes et ont des fonctions simples. . . , Afin que les types de données de base aient également les caractéristiques des objets, Java fournit une classe wrapper pour chaque type de données de base, afin que nous puissions utiliser des types de données de base comme des objets.
Correspondance entre les types de base et les classes wrapper :
Remarque : Il existe deux classes wrapper avec des noms spéciaux, l'une est Integer et l'autre est Character, other. les types de données de base sont en majuscules.
La classe packaging propose principalement deux catégories de méthodes :
1 Méthodes de conversion de ce type et d'autres types de base
2. classes d'emballage les unes aux autres
>>>>>>>>>>>>>>>>>> ; >>>>>>>>>>>>>>>>>>
La conversion entre les types de base et les classes d'emballage est souvent requise, en prenant Integer comme exemple (les opérations des autres classes d'emballage sont similaires) :
1 Integer a=new Integer(3);//定义Integer包装类对象,值为32 int b=a+5;//将对象和基本类型进行运算
Après l'introduction du mécanisme de boxing et de unboxing automatique dans JDK1.5, la conversion entre les classes wrapper et les types de base est devenue plus facile et plus pratique.
Alors, qu'est-ce que l'emballage et le déballage ? Examinons-les séparément :
Boxing : Convertissez le type de base en une classe d'emballage afin qu'il ait les propriétés d'un objet, et puisse être divisé en boxe manuelle et boxe automatique.
1 int i=10;//定一个int基本数据类型2 Integer x=new Integer(i);//手动装箱3 Integer y=i;//自动装箱
1 Double n=i;//类型不同不能自动装箱2 Double m=new Double(i);//不同类型可以通过手动装箱
Unboxing : L'opposé de la boxe, convertit l'objet de classe encapsulé en une valeur de type de base, et il peut être divisé en unboxing manuel et unboxing automatique.
1 Integer j=new Integer(8);//定义Integer包装类对象,值为82 int n=j.intValue();//手动拆箱3 int m=j;//自动拆箱
1 double x=j.doubleValue();//不同类型手动拆箱2 double y=j;//不同类型可以自动拆箱
Remarque : ne peut pas être automatiquement mis en boîte si le type est différent , mais est différent Les types peuvent être automatiquement déballés .
>>>>>>>>>>>>>>>>>>> ;>> ;>>>>>>>>>>>>>
Dans le développement de programmes, nous devons souvent effectuer des conversions entre les types de données de base et les chaînes.
Parmi eux, il existe trois façons de convertir un type de base en chaîne :
1 Utilisez la méthode toString() de la classe wrapper
. 2. Utilisez String La méthode valueOf() de la classe
3. Ajoutez une chaîne vide au type de base, et le résultat est la chaîne correspondant aux données du type de base
Le code est. comme suit :
1 //将基本类型转化为字符串2 int x=10;3 String str1=Integer.toString(x);//方法一4 String str2=String.valueOf(x);//方法二5 String str3=x+"";//方法三,本质利用系统自动转换类型
En y regardant à nouveau, il existe deux façons de convertir la chaîne de caractères en type de base :
1 . Appelez la méthode statique parseXxx de la classe d'emballage
2. Appelez la méthode valueOf() de la classe wrapper pour la convertir en un type de base de classe wrapper, qui déballera automatiquement le
. codez comme suit :
1 //将字符串转换为基本类型2 String str="8";3 int n=Integer.parseInt(str);//方法一4 int y=Integer.valueOf(str);//方法二
Remarque : caractères Si la chaîne contient d'autres caractères lors de la conversion de la chaîne en un type de base, une exception sera levée lors de l'exécution du programme. Par conséquent, il est préférable d'utiliser des instructions try-catch pour capturer et traiter lors de l'utilisation de cette méthode.
PS : La conversion entre les autres types et chaînes de base n'est pas répertoriée une par une ici, les méthodes sont similaires.
Dans le développement de programmes, nous avons souvent besoin de traiter des données liées à la date et à l'heure. À ce stade, nous pouvons utiliser la classe Date dans Java. paquet util. La fonction principale de cette classe est d'obtenir l'heure actuelle. Jetons un coup d'œil à l'utilisation de la classe Date :
1 Date d=new Date();//使用默认的构造方法创建Date对象2 System.out.println(d);
使用 Date 类的默认无参构造方法创建出的对象就代表当前时间,我们可以直接输出 Date 对象显示当前的时间,显示的结果如下:
其中, Thu 代表 星期四, Jul 代表 七月,06 代表 06 号, CST 代表 China Standard Time (中国标准时间,也就是北京时间,东八区)。
从上面的输出结果中,我们发现,默认的时间格式不是很友好,与我们日常看到的日期格式不太一样,如果想要按指定的格式进行显示,如 2017-07-06 13:31:28 ,那该怎么做呢?
此时就到了 java.text 包中的 SimpleDateFormat 类大显身手的时候了!!可以使用 SimpleDateFormat 来对日期时间进行格式化,如可以将日期转换为指定格式的文本,也可将文本转换为日期。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
1. 使用 format() 方法将日期转换为指定格式的文本
1 //使用 format() 方法将日期转换为指定格式的文本2 Date d=new Date();//使用默认的构造方法创建Date对象3 SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//指定日期格式4 String today=sdf.format(d);5 System.out.println(today);
运行结果:
结果分析:
代码中的 “yyyy-MM-dd HH:mm:ss” 为预定义字符串, yyyy 表示四位年, MM 表示两位月份, dd 表示两位日期, HH 表示小时(使用24小时制), mm 表示分钟, ss 表示秒,这样就指定了转换的目标格式,最后调用 format() 方法将时间转换为指定的格式的字符串。
2. 使用 parse() 方法将文本转换为日期
1 //创建日期格式的字符串 2 String day="2017年07月06日 13:42:10"; 3 //创建SimpleDateFormat对象,指定字符串的日期格式 4 SimpleDateFormat sd=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss"); 5 //调用parse方法,将字符串转化为日期 6 Date date; 7 try { 8 date = sd.parse(day); 9 System.out.println(date);10 } catch (ParseException e) {11 // TODO Auto-generated catch block12 e.printStackTrace();13 }
运行结果:
结果分析:
代码中的 “yyyy年MM月dd日 HH:mm:ss” 指定了字符串的日期格式,调用 parse() 方法将文本转换为日期。因为将字符串转换为Date类型可能会抛出异常,所以要用try-catch语句捕获。
一定要注意哦:
1、 调用 SimpleDateFormat 对象的 parse() 方法时可能会出现转换异常,即 ParseException ,因此需要进行异常处理。
2、 使用 Date 类时需要导入 java.util 包,使用 SimpleDateFormat 时需要导入 java.text 包。
Date 类最主要的作用就是获得当前时间,同时这个类里面也具有设置时间以及一些其他的功能,但是由于本身设计的问题,这些方法却遭到众多批评,不建议使用,更推荐使用 Calendar 类进行时间和日期的处理。
java.util.Calendar 类是一个抽象类,可以通过调用 getInstance() 静态方法获取一个 Calendar 对象,此对象已由当前日期时间初始化,即默认代表当前时间,如 Calendar c = Calendar.getInstance();
那么如何使用 Calendar 获取年、月、日、时间等信息呢?我们来看下面的代码:
1 public static void main(String[] args) { 2 // TODO Auto-generated method stub 3 Calendar c = Calendar.getInstance();//创建Calendar对象 4 int year = c.get(Calendar.YEAR);//获取年 5 int month = c.get(Calendar.MONTH)+1;//获取月份,0表示一月份 6 int day = c.get(Calendar.DAY_OF_MONTH);//获取日期 7 int hour = c.get(Calendar.HOUR_OF_DAY);//获取小时 8 int minute = c.get(Calendar.MINUTE);//获取分钟 9 int second = c.get(Calendar.SECOND);//获取秒10 System.out.println("当前时间:"+year+"-"+month+"-"+day+"-"+hour+":"+minute+":"+second);11 12 }
运行结果:
结果分析:
调用 Calendar 类的 getInstance() 方法获取一个实例,然后通过调用 get() 方法获取日期时间信息,参数为需要获得的字段的值, Calendar.Year 等为 Calendar 类中定义的静态常量。
注意:其中有两个特别的参数:DAY_OF_MONTH和HOUR_OF_DAY,千万不要写成DAY和HOUR了;MONTH获取的月份,0表示一月。
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
Calendar 类提供了 getTime() 方法,用来获取 Date 对象,完成 Calendar 和 Date 的转换,还可通过 getTimeInMillis() 方法,获取此 Calendar 的时间值,以毫秒为单位。如下所示:
1 Date date=c.getTime();//将Calendar对象转换为Date对象2 Long time=c.getTimeInMillis();//获取当前毫秒数3 System.out.println("当前时间:"+date);4 System.out.println("当前毫秒数"+time);
运行结果:
1.通过调用 getInstance() 静态方法获取一个 Calendar 对象---对象初始化
Calendar c = Calendar.getInstance();
2.通过调用 get() 方法获取日期时间信息
int month=c.get(Calendar.MONTH)+1;----0表示1月份
3.提供 getTime() 方法,用来获取 Date 对象
Date date=c.getTime();----将Calender对象转换为Date对象
4.通过 getTimeInMillis() 方法,获取此 Calendar 的时间值
long time=c.getTimeInMillis();----获取当前毫秒
Math 类位于 java.lang 包中,包含用于执行基本数学运算的方法, Math 类的所有方法都是静态方法,所以使用该类中的方法时,可以直接使用类名.方法名,如: Math.round();
常用的方法:
下面用代码来实现:
1 public static void main(String[] args) { 2 double a=12.81; 3 int b=(int)a;//强制类型转换 4 System.out.println("强制类型转换:"+b); 5 long c=Math.round(a);//调用round方法,进行四舍五入 6 System.out.println("四舍五入:"+c); 7 double d=Math.floor(a);//调用floor方法,返回小于参数的最大整数 8 System.out.println("floor方法:"+d); 9 double e=Math.ceil(a);//调用ceil方法,返回大于参数的最小整数10 System.out.println("ceil方法:"+e);11 double x=Math.random();//调用random方法,产生[0,1)之间的随机数12 System.out.println("随机数:"+x);13 int y=(int)(Math.random()*100);//产生[0,100)之间的随机数14 System.out.println("[0,100)之间的随机数:"+y);15 16 }
运行结果:
注意:要注意Math各个方法返回值类型,可以用强制类型转换来转为自己想要的类型。
PS: Math 类还提供了许多其他方法,各位小伙伴们可以按需去API文档查找想要知道的方法。
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!