我是靠谱客的博主 忧虑黄蜂,最近开发中收集的这篇文章主要介绍排序算法和设计模式,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述


两种基本排序算法

冒泡排序

相邻元素两两进行比较,大的往后放,第一次比较完毕后,最大值在最大索引处。循环进行,直到全部比完。

代码:

public static voidbubbleSort(int[] arr) {
                                   for(int x=0;x<arr.length-1; x++){
                                          for(inty=0; y<arr.length-1-x; y++){
                                                 if(arr[y]>arr[y+1]){
                                                        inttemp = arr[y];
                                                        arr[y]= arr[y+1];
                                                        arr[y+1]= temp;
                                                 }
                                          }
                                   }
                            }


选择排序

拿0索引处的元素和后面所有元素依次比较,小的放大0索引处。第一次比较完毕,最小值出现在最小索引处。循环进行,直到全部比完。

代码:

public static voidselectSort(int[] arr) {
                                   for(int x=0;x<arr.length-1; x++){
                                          for(inty=x+1; y<arr.length; y++){
                                                 if(arr[x]>arr[y]){
                                                        inttemp = arr[y];
                                                        arr[y]= arr[x];
                                                        arr[x]= temp;
                                                 }
                                          }
                                   }
                            }


设计模式

就是前人总结的一些经验和思想,给我们提供了从抽象到具体的方法。

 

单例设计模式

定义:确保一个类只有一个实例,而且自行实例化并向整个系统提供这个实例。

要素:

1,私有的构造方法。

2,指向自己实例的私有静态引用。

3,以自己实例为返回值的静态的公有的方法。

 

注意:单例模式根据实例化对象时机的不同分为两种:一种是饿汉式单例,一种是懒汉式单例。饿汉式单例在单例类被加载时候,就实例化一个对象交给自己的引用;而懒汉式在调用取得实例方法的时候才会实例化对象。

 

饿汉式单例

public class Single{
    private staticSingle singlet = new Single();
 
    private Single(){
    }
 
    public staticSingle getInstance() {
    returnsingleton;
    }
}


 

懒汉式单例

public class Single2 {
    private staticSingle2 single;
 
    privateSingle2() {
 
    }
 
    public staticsynchronized Single2 getInstance() {
 
       if (single ==null) {
 
           single =new Single2();
 
           }
       returnsingle;
    }
}
 


单例模式的优点:
1,在内存中只有一个对象,节省内存空间。
2,避免频繁的创建销毁对象,可以提高性能。
3,避免对共享资源的多重占用。
4,可以全局访问。

适用场景:

由于单例模式的以上优点,所以是编程中用的比较多的一种设计模式。
1,需要频繁实例化然后销毁的对象。
2,创建对象时耗时过多或者耗资源过多,但又经常用到的对象。
3,有状态的工具类对象。
4,频繁访问数据库或文件的对象。
5,以及其他我没用过的所有要求只有一个对象的场景。

注意事项:
1,只能使用单例类提供的方法得到单例对象,不要使用反射,否则将会实例化一个新对象。
2,不要做断开单例类对象与类中静态引用的危险操作。
3,多线程使用单例使用共享资源时,要注意线程安全问题。特别是使用懒汉式时会出现线程安全问题。

 

最后

以上就是忧虑黄蜂为你收集整理的排序算法和设计模式的全部内容,希望文章能够帮你解决排序算法和设计模式所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(76)

评论列表共有 0 条评论

立即
投稿
返回
顶部