【单例模式】
     确保某一个类,只能产生一个实例。
设计思路:
====将构造函数私有化,确保类外部,不能使用new关键字自行创建对象。
====在类内部实例化一个对象,并通过静态方法返回。
(1)饿汉式单例模式
优点:线程安全
缺点:在类加载的时候,就实例化对象,提前占用系统资源

 class Dog{

     private Dog(){

         System.out.println("小蠢狗");
} private static Dog cutedog=new Dog(); public static Dog getInstanca(){
return cutedog;
} }
(2.)懒汉式单例模式:
优点:解决了饿汉式单例,一加载就提前占用资源的问题。
缺点:线程不安全

 class Dog{

     private Dog(){

         System.out.println("小蠢狗");
} private static Dog cutedog=null; public static Dog getInstanca(){
if (cutedog==null) {
cutedog=new Dog();
}
return cutedog;
} }
(3.)线程锁懒汉式模式
通俗来说,就是在懒汉式单例模式的方法上加锁
synchronized:将一个方法或者代码块进行加锁,同一时间只允许一个线程访问
使用同步块对方法进行加锁,确保懒汉式单例,可以线程安全
缺点:效率低下
 class Dog{

     private Dog(){

         System.out.println("小蠢狗");
} private static Dog cutedog=null; public static synchronized Dog getInstanca(){
if (cutedog==null) {
cutedog=new Dog();
}
return cutedog;
} }

(4.)双重加锁懒汉模式

只有第一次Dog为null时,才进行线程锁,当后续Dog不为null时,说明第一次已经赋值了,·产生了一个实例,就无需线程锁,可以允许多个线程同时拿走dog
class Dog{

    private Dog(){

        System.out.println("小蠢狗");
} private static Dog cutedog=null; public static synchronized Dog getInstanca(){
if (cutedog==null) {
synchronized (Dog.class) {
if (cutedog==null) {
cutedog=new Dog();
}
}
}
return cutedog;
} }
(5.)静态内部类实现单例
优点:解决了饿汉式提前占用资源的问题,解决了懒汉式线程不安全的问题,静态内部类只有当被调用的时候才开始首次被加载。
 class Dog{

     private Dog(){

         System.out.println("小蠢狗");
} private static class KIttyDod{
private static Dog cutedog=new Dog();
}
public static Dog getInstance(){
return KIttyDod.cutedog;
} }
【Math】
;?Math位于Java.lang包中
(1.)Math.abs(); 求绝对值
(2.)Math.cbrt(); 求立方根
(3.)Math..sprt();求平方根
(4.)Math.max/min(double1,double2); 返回两个值中最大最小值
(5.)Math.pow(a,b); 求a的b次方
(6.)Math.floor();返回小于指定浮点数的一个整数,返回的是double类型,例如10.0
Math.ceil();------大于---------
(6.)Math.round();四舍五入,返回一个整数类型,如果传入double,返回long,传入float,返回int
(7.)Math.rint();返回最接近参数的整数,如果10.5与10和11同时接近,返回偶数
(8.)Math.random();返回[0.1,1.0)之间的double随机值
 
【求一个数保留几位小数】
double a=23.22122222;
double b=Math.round(a*Math.pow(10, 3))/Math.pow(10, 3);
System.out.println(b);
 
【Date】
/**实例化
* 空参构造,默认取到当前时间
*/
Date date=new Date();
Date d=new Date();
/**
* 传入一个long类型的时间戳,取到指定时间。
* date.getTime(); 取到一个时间的时间戳,从0时区,1970年1月1日0:0:0到当前时间毫秒数。
*/
System.out.println(d);
 
(1.)equals();比对两个时间是否相等
(2.)a.before(b); 检测一个时间是不是在制定时间之前
after(): --------------------------------------之后
(3.)a.compare to(b); 前面>参数 返回1 前面<小于参数,返回-1 相等,返回0
(4.)setTime();传入一个长整型(时间戳),重新设置时间
(5.)toString();格式化日期转义格式yyyy-mm-dd。
【SimpleDateFormat】
对日期格式进行实例化。
实例化对象时,传入格式化参数,用字母代表对应部分。
*  字母  日期或时间元素  表示  示例  
 * y  年  Year  1996; 96  
 * M  年中的月份  Month  July; Jul; 07  
 * d  月份中的天数  Number  10  
 * E  星期中的天数  Text  Tuesday; Tue  
 * H  一天中的小时数(0-23)  Number  0  
 * h  am/pm 中的小时数(1-12)  Number  12  
 * m  小时中的分钟数  Number  30  
 * s  分钟中的秒数  Number  55  
(1.)format();用于传人一个Date类型的参数,并返回格式化之后的字符串
Date date=new Date();
SimpleDateFormat sf=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss E" );
String s=sf.format(date);
System.out.println(s);
(2.)sf.parse("2018年04月13日 14:08:15 星期五");将字符串格式的时间,转成Date类型,要求传入的字符串格式,必须与实例化时的模式,保持一致。
(3.)toPattern();返回当前格式化的模式字符串。
【Calendar日历类】
Calendar ca=Calendar.getInstance();
(1.)Calendar日历类是一个抽象类,不能直接通过new拿到对象,必须使用Calendar.getInstance();拿到一个Calendar日历类对象
(2.)ca.getTime(); 返回一个日期对象
(3.)ca.add(int field, int amount) ; 根据日历的规则,将指定的时间量添加或减去给定的日历字段。
【Random随机数类】
取随机数,有两种构造:
--------------空参构造------------
Random ran=new Random();
--------------传入一个种子数--------只要种子数相同,那么在相同次数取到的随机数肯定相同,这是伪随机数。
Random ran=new Random(100);
Random ran=new Random(System.currentTimeMillis());
System.currentTimeMillis();拿到当前时间戳,这样就是取随机数了。
(1.)nextInt(); 随机获得一个整数
(2.)nextInt(n); 随机获得从0到n随机数,含0不含n
随机生成两位随机数: System.out.println(ran.nextInt(90)+10);

单例模式详解及java常用类的更多相关文章

  1. 9种Java单例模式详解(推荐)

    单例模式的特点 一个类只允许产生一个实例化对象. 单例类构造方法私有化,不允许外部创建对象. 单例类向外提供静态方法,调用方法返回内部创建的实例化对象.  懒汉式(线程不安全) 其主要表现在单例类在外 ...

  2. 事件驱动模型实例详解(Java篇)

    或许每个软件从业者都有从学习控制台应用程序到学习可视化编程的转变过程,控制台应用程序的优点在于可以方便的练习某个语言的语法和开发习惯(如.net和java),而可视化编程的学习又可以非常方便开发出各类 ...

  3. Java基础 —— Java常用类

    Java常用类: java.lang包: java.lang.Object类: hashcode()方法:返回一段整型的哈希码,代表地址. toString()方法:返回父类名+"@&quo ...

  4. <转>详解DNS的常用记录(上):DNS系列之二

    详解DNS的常用记录(上) 在上篇博文中,我们介绍了DNS服务器的体系结构,从中我们了解到如果我们希望注册一个域名,那么必须经过顶级域名服务器或其下级的域名服务器为我们申请的域名进行委派,把解析权委派 ...

  5. Java常用类之要点总结

    Java常用类之要点总结

  6. Java常用类:包装类,String,日期类,Math,File,枚举类

    Java常用类:包装类,String,日期类,Math,File,枚举类

  7. Java常用类学习笔记总结

    Java常用类 java.lang.String类的使用 1.概述 String:字符串,使用一对""引起来表示. 1.String声明为final的,不可被继承 2.String ...

  8. Java 常用类总结(SE基础)

    本篇博客对java常用类相关知识进行了归纳总结,比较详细,适用于学习和复习. 1. 字符串相关的类 1.1 String String是一个final类,代表不可变的字符序列.不可被继承. Strin ...

  9. 一文详解 Linux 系统常用监控工一文详解 Linux 系统常用监控工具(top,htop,iotop,iftop)具(top,htop,iotop,iftop)

    一文详解 Linux 系统常用监控工具(top,htop,iotop,iftop)     概 述 本文主要记录一下 Linux 系统上一些常用的系统监控工具,非常好用.正所谓磨刀不误砍柴工,花点时间 ...

随机推荐

  1. (floyd)佛洛伊德算法

    Floyd–Warshall(简称Floyd算法)是一种著名的解决任意两点间的最短路径(All Paris Shortest Paths,APSP)的算法.从表面上粗看,Floyd算法是一个非常简单的 ...

  2. 【Python】 子进程创建与使用subprocess

    subprocess *****本文参考了Vamei大神的http://www.cnblogs.com/vamei/archive/2012/09/23/2698014.html 运用subproce ...

  3. JDBC(通俗易懂)简单的操作(增、删、改、查)

    项目所写的类: 说明:①.DButil 动态加载数据库驱动,以及获取java.sql.Connection的对象. ②.Personmodel 数据库列(栏位)所对应的字段,定义了相应的set和get ...

  4. New UWP Community Toolkit - XAML Brushes

    概述 上一篇 New UWP Community Toolkit 文章中,我们对 V2.2.0 版本的重要更新做了简单回顾.接下来会针对每个重要更新,结合 SDK 源代码和调用代码详细讲解. 本篇我们 ...

  5. 定位bug的姿势对吗?

    举个例子来说明 WEB页面上数据显示错误,本来应该显示38,  结果显示35,这个时候你怎么去定位这个问题出在哪里? 1.通过fiddler抓包工具(或者其他抓包工具), 分析接口返回的数据是35还是 ...

  6. WEB 表格测试点

    Web页面的表格测试点: 1.表格列名 2.表格翻页.表格跳转到多少页.最后一页.首页 3.表格每页显示的数据, 数据的排序 4.表格无数据 5.表格支持的最大数据量 6.表格中数据内容超长时,显示是 ...

  7. SpringBoot12 QueryDSL01之QueryDSL介绍、springBoot项目中集成QueryDSL

    1 QueryDSL介绍 1.1 背景 QueryDSL的诞生解决了HQL查询类型安全方面的缺陷:HQL查询的扩展需要用字符串拼接的方式进行,这往往会导致代码的阅读困难:通过字符串对域类型和属性的不安 ...

  8. <经验杂谈>介绍Js简单的递归排列组合

    最近在开发SKU模块的时候,遇到这样一个需求,某种商品有N(用未知数N来表示是因为规格的数组由用户制定且随时可以编辑的,所以对程序来说,它是一个未知数)类规格,每一类规格又有M个规格值,各种规格值的组 ...

  9. python的Flask 介绍

    Flask 介绍 知识点 微框架.WSGI.模板引擎概念 使用 Flask 做 web 应用 模板的使用 根据 URL 返回特定网页 实验步骤 1. 什么是 Flask? Flask 是一个 web ...

  10. hdu 5274 Dylans loves tree

    Dylans loves tree http://acm.hdu.edu.cn/showproblem.php?pid=5274 Time Limit: 2000/1000 MS (Java/Othe ...