冒泡排序、选择排序、二分查找、单例模式、生产消费者模型

一、冒泡排序

import java.util.Arrays;
public class Bubble {
    public static void main(String[] args) {
        int[]a= {-1,-99,20,11-3,188,21};
        int tem1;
        for(int i=0;i<a.length;i++) {
            for(int j=0;j<a.length-i-1;j++) {               
                if(a[j]<a[j+1]) {               
                    tem1=a[j];
                    a[j]=a[j+1];
                    a[j+1]=tem1;                    
                }       
            }
        }   
        String str = Arrays.toString(a);
        System.out.println(str);
    }
}

二、选择排序

package testdemo;

import java.util.Arrays;

public class Selected {

    public static void main(String[] args) {            
        int[] arr = {12,1,23,53,-99,17,0,888};
        int max=0;
        int index=0;        
        for(int i=0;i<arr.length-1;i++) {
            for(int j=0;j<arr.length-i;j++) {
                
                if(max<arr[j]) {
                    max=arr[j];
                    index=j;
                }               
            }           
            int tem=arr[arr.length-1-i];
            arr[arr.length-i-1]=max;
            arr[index]=tem;
            max=0;
            index=0;        
        }   
        System.out.println(Arrays.toString(arr));
    }
}

三、二分查找

package testdemo;

public class Banary {

    public static void main(String[] args) {
        //首先得是一个有序数组!!!
        int [] a= {1,2,3,4,5,6,7,8,9};
        //所要索引得数据
        int key=6;  
        
        //返回所要查找的数据的对应数组索引
        int search = binSearch(a,key);
        System.out.println(search);
    }
        
    public static int binSearch(int []arr,int key) {        
        //数组的长度
        int len=arr.length;
        //高位(最后一位)索引
        int high=len-1;
        //低位索引(0)
        int low=0;      
        //如果高位索引等于小于低位索引跳出寻呼
        while(low<=high) {
            //二分从这儿开始定义中间位索引
            int mid=(high-low)/2+low;
            //如果中间位的数值等于所要索引的数据的值则返回中间位索引
            if(arr[mid]==key) {
                return mid;
            //如果中间位的值小于所要索引的数据 的值,则低位索引切换为中间位索引+1(索引从0开始)
            }else if(arr[mid]<key) {
                low=mid+1;
            //如果中间位的值大于所要索引的数据 的值则,高位索引切换为中间位索引-1(索引从0开始)
            }else {
                high=mid-1;
            }       
        }
                //如果被索引的数据不存在则返回-1。
        return -1;  
    }
}

四、单例模式

  • 优点:节省静态方法区中的内存,使用时效率高。
  • 缺点:相对静态来讲,效率还是要低一些。

设计要点

  • 私有化构造方法
  • 自己创建对象并记录住
  • 保证整个变量的安全
  • 懒汉式:线程不安全,解决方法
//懒汉式   饱汉式 
public class MyTool {

    private static MyTool myTool = null;
    //私有话构造方法, 让使用者无法new对象
    //这样使用者就没有办法创建多个对象了
    private MyTool(){}
    //提供一个静态方法, 使用者调用这个方法可以获取对象
    //这样,我们就可以控制创建的对象了
    public static MyTool getInstance(){
        //第一次访问时,发现变量中没有记录对象, 就新建对象
        //如果已经创建过对象,就直接返回
        if(myTool==null){
            myTool = new MyTool();
        }
        
        return myTool; 
    }
    
}

饿汉式:线程安全

//饿汉式
public class MyTool2 {

    private static MyTool2 myTool = new MyTool2();
    //私有话构造方法, 让使用者无法new对象
    //这样使用者就没有办法创建多个对象了
    private MyTool2(){}
    //提供一个静态方法, 使用者调用这个方法可以获取对象
    //这样,我们就可以控制创建的对象了
    public static MyTool2 getInstance(){
        
        return myTool; 
    }
    
}

饿汉式2:

//饿汉式
public class MyTool3 {
    public static final MyTool3 MY_TOOL = new MyTool3();
    //私有话构造方法, 让使用者无法new对象
    //这样使用者就没有办法创建多个对象了
    private MyTool3(){}
}

五、生产消费者模型

  • 生产者线:母鸡,如果容器中没有空位(装满鸡蛋)则母鸡线程进入等待,只要容器中有空位则唤醒母鸡线程,生产鸡蛋。同时只要容器中有鸡蛋就要唤醒消费者线程。
  • 消费者线程:吃货,如果容器中的没有对象(没有鸡蛋size()=0)则吃货线程进入等待,只要容器中有鸡蛋吃货线程就持续运行,同时只要容器中有空位就应该唤醒母鸡线程进行生产
  • 容器:唯一的,有容量限制的,公用的资源。
  • 注意事项:sychronized()锁的是公用对象即list,也可以锁个大招。但是不能锁this。 线程等待与唤醒方法应该由锁对象进行调用。
package testdemo;

import java.util.LinkedList;

/**
 * 
 * @author 86183
 *
 */
class Egg{
    private int eggId;

    public Egg() {
        super();
        // TODO Auto-generated constructor stub
    }

    public Egg(int eggId) {
        super();
        this.eggId = eggId;
    }

    public int getEggId() {
        return eggId;
    }

    public void setEggId(int eggId) {
        this.eggId = eggId;
    }

    @Override
    public String toString() {
        return "Egg [eggId=" + eggId + "]";
    }
}
/**
 * 生产者线程
 * @author 86183
 *
 */
class Hen implements Runnable{
    private int iCounter=1;
    //公共容器
    private LinkedList<Egg> list;
    
    //由外部传入
    public Hen(LinkedList<Egg> list) {
        this.list=list;
    }


    @Override
    public void run() {
        while(true) {
            
            //一次执行需要保证不可分割的原子性操作
            synchronized(list) {
                if(list.size()==10) {
                        try {
                            list.wait();
                        } catch (InterruptedException e1) {
                            // TODO Auto-generated catch block
                            e1.printStackTrace();
                        }
                    }
                //如果容器没有满则母鸡下蛋母鸡生产一个鸡蛋          
                Egg e = new Egg(iCounter);
                iCounter++;
                //将鸡蛋放入容器中
                list.push(e);
                System.out.println(Thread.currentThread().getName()+"生产了"+e);           
                //只要篮子里鸡蛋不为0就要唤醒吃货线程
                list.notify();                      
            }   
        }
    }   
}

/**
 * 消费者线程
 * @author 86183
 *
 */
class Consumer implements Runnable{
    //公共容器
    private LinkedList <Egg> list;
    
    public Consumer(LinkedList <Egg> list) {
        this.list=list;
    }

    @Override
    public void run() {
        
        while(true) {           
            synchronized(list) {        
                if(list.size()==0) {
                    try {
                        list.wait();
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }//如果容器部位空吃货一直吃
                    //吃货吃了一个鸡蛋
                    Egg egg = list.pop();
                    System.out.println(Thread.currentThread().getName()+"吃了"+egg);          
                    list.notify();
            }
        }       
    }
    
}


public class CustoemrProducerModel {
    public static void main(String[] args) {
        LinkedList<Egg> list=new LinkedList<>();

        Hen hen = new Hen(list);
        Consumer consumer = new Consumer(list);
        
        Thread t1 = new Thread(hen, "母鸡");
        Thread t2 = new Thread(consumer, "吃货");
        
        
        t1.start();
        t2.start();
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345