<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    dream.in.java

    能以不變應(yīng)萬(wàn)變是聰明人做事的準(zhǔn)則。萬(wàn)事從小事做起,積累小成功,問(wèn)鼎大成功,是成功者的秘訣。

    必看的5個(gè)JAVA經(jīng)典實(shí)例(二)

    4.用JAVA中的多線程示例生產(chǎn)者和消費(fèi)者問(wèn)題

    package com.softeem.demo;

    class Producer implements Runnable {
        private SyncStack stack;

        public Producer(SyncStack stack) {
            this.stack = stack;
        }

        public void run() {
            for (int i = 0; i < stack.getProducts().length; i++) {
                String product = "產(chǎn)品" + i;
                stack.push(product);
                System.out.println("生產(chǎn)了: " + product);
                try {
                    Thread.sleep(200);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }

    }

    class Consumer implements Runnable {
        private SyncStack stack;

        public Consumer(SyncStack stack) {
            this.stack = stack;
        }

        public void run() {
            for (int i = 0; i < stack.getProducts().length; i++) {
                String product = stack.pop();
                System.out.println("消費(fèi)了: " + product);
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

            }

        }
    }

    class SyncStack {
        private String[] products = new String[10];
        private int index;

        public synchronized void push(String product) {
            if (index == product.length()) {
                try {
                    wait();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            notify();
            products[index] = product;
            index++;
        }

        public synchronized String pop() {
            if (index == 0) {
                try {
                    wait();
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            notify();
            index--;
            String product = products[index];
            return product;
        }

        public String[] getProducts() {
            return products;
        }

    }

    public class TestProducerConsumer {

        public static void main(String[] args) {
            SyncStack stack = new SyncStack();
            Producer p = new Producer(stack);
            Consumer c = new Consumer(stack);

            new Thread(p).start();
            new Thread(c).start();
        }
    }

    5.編程實(shí)現(xiàn)序列化的Student(sno,sname)對(duì)象在網(wǎng)絡(luò)上的傳輸

    package com.softeem.demo;

    import java.io.IOException;
    import java.io.ObjectInputStream;
    import java.io.ObjectOutputStream;
    import java.io.Serializable;
    import java.net.ServerSocket;
    import java.net.Socket;

    class Student implements Serializable {
        private int sno;
        private String sname;

        public Student(int sno, String sname) {
            this.sno = sno;
            this.sname = sname;
        }

        public int getSno() {
            return sno;
        }

        public void setSno(int sno) {
            this.sno = sno;
        }

        public String getSname() {
            return sname;
        }

        public void setSname(String sname) {
            this.sname = sname;
        }

        @Override
        public String toString() {
            return "學(xué)號(hào):" + sno + ";姓名:" + sname;
        }
    }
    class MyClient extends Thread {
        @Override
        public void run() {
            try {
                Socket s = new Socket("localhost", 9999);
                ObjectInputStream ois = new ObjectInputStream(s.getInputStream());
                Student stu = (Student) ois.readObject();
                String msg = "客戶端程序收到服務(wù)器端程序傳輸過(guò)來(lái)的學(xué)生對(duì)象>> " + stu;
                System.out.println(msg);
                ois.close();
                s.close();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (ClassNotFoundException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
    class MyServer extends Thread {

        @Override
        public void run() {
            try {
                ServerSocket ss = new ServerSocket(9999);
                Socket s = ss.accept();
                ObjectOutputStream ops = new ObjectOutputStream(s.getOutputStream());
                Student stu = new Student(1, "趙本山");
                ops.writeObject(stu);
                ops.close();
                s.close();
                ss.close();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }

    }
    public class TestTransfer {
        public static void main(String[] args) {
            new MyServer().start();
            new MyClient().start();
        }
    }

    posted on 2009-02-22 13:48 YXY 閱讀(288) 評(píng)論(0)  編輯  收藏


    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 最近免费字幕中文大全视频 | 免费大片黄在线观看yw| 亚洲精品蜜桃久久久久久| 精品久久久久久无码免费| 国产中文在线亚洲精品官网| 精品熟女少妇aⅴ免费久久| 亚洲中文字幕无码一久久区| 精品国产污污免费网站入口在线 | 亚洲av之男人的天堂网站| 99久热只有精品视频免费看| 精品日韩亚洲AV无码 | 成人av免费电影| 亚洲国产日韩a在线播放| 免费a级毛片无码av| a在线视频免费观看在线视频三区| 久久久无码精品亚洲日韩软件 | 亚洲av无码专区亚洲av不卡| 亚洲av日韩av欧v在线天堂| 久久一区二区三区免费| 在线观看亚洲一区二区| 免费精品人在线二线三线区别| 精品国产亚洲AV麻豆| 亚洲中文字幕无码久久精品1| 青青草原1769久久免费播放| 亚洲a视频在线观看| 免费国产真实迷j在线观看| 久久精品免费一区二区三区| 亚洲国产av一区二区三区丶| 免费看国产精品麻豆| 青青青国产手机频在线免费观看| 国产成+人+综合+亚洲专| 亚洲毛片网址在线观看中文字幕| 一个人免费日韩不卡视频| 亚洲色大成网站www永久网站| 亚洲综合色在线观看亚洲| 18成禁人视频免费网站| 日韩精品免费一线在线观看| 亚洲精品视频在线播放| 又粗又大又长又爽免费视频| 99在线观看视频免费| 黄色免费网址大全|