java项目实战——Java打飞机小游戏(附完整源码)

简介:

Paste_Image.png

写在前面

技术源于分享,所以今天抽空把自己之前用java做过的小游戏整理贴出来给大家参考学习。java确实不适合写桌面应用,这里只是通过这个游戏让大家理解oop面向对象编程的过程,纯属娱乐。代码写的很简单,也很容易理解,并且注释写的很清楚了,还有问题,自己私下去补课学习。

完整代码

敌飞机

import java.util.Random;


 敌飞机: 是飞行物,也是敌人

public class Airplane extends FlyingObject implements Enemy {
    private int speed = 3;  //移动步骤

    /** 初始化数据 */
    public Airplane(){
        this.image = ShootGame.airplane;
        width = image.getWidth();
        height = image.getHeight();
        y = -height;          
        Random rand = new Random();
        x = rand.nextInt(ShootGame.WIDTH - width);
    }

    /** 获取分数 */
    @Override
    public int getScore() {  
        return 5;
    }

    /** //越界处理 */
    @Override
    public     boolean outOfBounds() {   
        return y>ShootGame.HEIGHT;
    }

    /** 移动 */
    @Override
    public void step() {   
        y += speed;
    }

}

分数奖励

/** 
 * 奖励 
 */  
public interface Award {  
    int DOUBLE_FIRE = 0;  //双倍火力  
    int LIFE = 1;   //1条命  
    /** 获得奖励类型(上面的0或1) */  
    int getType();  
}

蜜蜂

import java.util.Random;  

/** 蜜蜂 */  
public class Bee extends FlyingObject implements Award{  
    private int xSpeed = 1;   //x坐标移动速度  
    private int ySpeed = 2;   //y坐标移动速度  
    private int awardType;    //奖励类型  

    /** 初始化数据 */  
    public Bee(){  
        this.image = ShootGame.bee;  
        width = image.getWidth();  
        height = image.getHeight();  
        y = -height;  
        Random rand = new Random();  
        x = rand.nextInt(ShootGame.WIDTH - width);  
        awardType = rand.nextInt(2);   //初始化时给奖励  
    }  

    /** 获得奖励类型 */  
    public int getType(){  
        return awardType;  
    }  

    /** 越界处理 */  
    @Override  
    public boolean outOfBounds() {  
        return y>ShootGame.HEIGHT;  
    }  

    /** 移动,可斜着飞 */  
    @Override  
    public void step() {        
        x += xSpeed;  
        y += ySpeed;  
        if(x > ShootGame.WIDTH-width){    
            xSpeed = -1;  
        }  
        if(x < 0){  
            xSpeed = 1;  
        }  
    }  
}

子弹类:是飞行物体

/** 
 * 子弹类:是飞行物 
 */  
public class Bullet extends FlyingObject {  
    private int speed = 3;  //移动的速度  

    /** 初始化数据 */  
    public Bullet(int x,int y){  
        this.x = x;  
        this.y = y;  
        this.image = ShootGame.bullet;  
    }  

    /** 移动 */  
    @Override  
    public void step(){     
        y-=speed;  
    }  

    /** 越界处理 */  
    @Override  
    public boolean outOfBounds() {  
        return y<-height;  
    }  

}

敌人的分数

/** 
 * 敌人,可以有分数 
 */  
public interface Enemy {  
    /** 敌人的分数  */  
    int getScore();  
}

飞行物(敌机,蜜蜂,子弹,英雄机)

import java.awt.image.BufferedImage;  

/** 
 * 飞行物(敌机,蜜蜂,子弹,英雄机) 
 */  
public abstract class FlyingObject {  
    protected int x;    //x坐标  
    protected int y;    //y坐标  
    protected int width;    //宽  
    protected int height;   //高  
    protected BufferedImage image;   //图片  

    public int getX() {  
        return x;  
    }  

    public void setX(int x) {  
        this.x = x;  
    }  

    public int getY() {  
        return y;  
    }  

    public void setY(int y) {  
        this.y = y;  
    }  

    public int getWidth() {  
        return width;  
    }  

    public void setWidth(int width) {  
        this.width = width;  
    }  

    public int getHeight() {  
        return height;  
    }  

    public void setHeight(int height) {  
        this.height = height;  
    }  

    public BufferedImage getImage() {  
        return image;  
    }  

    public void setImage(BufferedImage image) {  
        this.image = image;  
    }  

    /** 
     * 检查是否出界 
     * @return true 出界与否 
     */  
    public abstract boolean outOfBounds();  

    /** 
     * 飞行物移动一步 
     */  
    public abstract void step();  

    /** 
     * 检查当前飞行物体是否被子弹(x,y)击(shoot)中 
     * @param Bullet 子弹对象 
     * @return true表示被击中了 
     */  
    public boolean shootBy(Bullet bullet){  
        int x = bullet.x;  //子弹横坐标  
        int y = bullet.y;  //子弹纵坐标  
        return this.x<x && x<this.x+width && this.y<y && y<this.y+height;  
    }  

}

英雄机

import java.awt.image.BufferedImage;  

/** 
 * 英雄机:是飞行物  Java学习交流QQ群:589809992 我们一起学Java!
 */  
public class Hero extends FlyingObject{  

    private BufferedImage[] images = {};  //英雄机图片  
    private int index = 0;                //英雄机图片切换索引  

    private int doubleFire;   //双倍火力  
    private int life;   //命  

    /** 初始化数据 */  
    public Hero(){  
        life = 3;   //初始3条命  
        doubleFire = 0;   //初始火力为0  
        images = new BufferedImage[]{ShootGame.hero0, ShootGame.hero1}; //英雄机图片数组  
        image = ShootGame.hero0;   //初始为hero0图片  
        width = image.getWidth();  
        height = image.getHeight();  
        x = 150;  
        y = 400;  
    }  

    /** 获取双倍火力 */  
    public int isDoubleFire() {  
        return doubleFire;  
    }  

    /** 设置双倍火力 */  
    public void setDoubleFire(int doubleFire) {  
        this.doubleFire = doubleFire;  
    }  

    /** 增加火力 */  
    public void addDoubleFire(){  
        doubleFire = 40;  
    }  

    /** 增命 */  
    public void addLife(){  //增命  
        life++;  
    }  

    /** 减命 */  
    public void subtractLife(){   //减命  
        life--;  
    }  

    /** 获取命 */  
    public int getLife(){  
        return life;  
    }  

    /** 当前物体移动了一下,相对距离,x,y鼠标位置  */  
    public void moveTo(int x,int y){     
        this.x = x - width/2;  
        this.y = y - height/2;  
    }  

    /** 越界处理 */  
    @Override  
    public boolean outOfBounds() {  
        return false;    
    }  

    /** 发射子弹 */  
    public Bullet[] shoot(){     
        int xStep = width/4;      //4半  
        int yStep = 20;  //步  
        if(doubleFire>0){  //双倍火力  
            Bullet[] bullets = new Bullet[2];  
            bullets[0] = new Bullet(x+xStep,y-yStep);  //y-yStep(子弹距飞机的位置)  
            bullets[1] = new Bullet(x+3*xStep,y-yStep);  
            return bullets;  
        }else{      //单倍火力  
            Bullet[] bullets = new Bullet[1];  
            bullets[0] = new Bullet(x+2*xStep,y-yStep);    
            return bullets;  
        }  
    }  

    /** 移动 */  
    @Override  
    public void step() {  
        if(images.length>0){  
            image = images[index++/10%images.length];  //切换图片hero0,hero1  
        }  
    }  

    /** 碰撞算法 */  
    public boolean hit(FlyingObject other){  

        int x1 = other.x - this.width/2;                 //x坐标最小距离  
        int x2 = other.x + this.width/2 + other.width;   //x坐标最大距离  
        int y1 = other.y - this.height/2;                //y坐标最小距离  
        int y2 = other.y + this.height/2 + other.height; //y坐标最大距离  

        int herox = this.x + this.width/2;               //英雄机x坐标中心点距离  
        int heroy = this.y + this.height/2;              //英雄机y坐标中心点距离  

        return herox>x1 && herox<x2 && heroy>y1 && heroy<y2;   //区间范围内为撞上了  
    }  

}

游戏启动主类

如果你想学习java可以来这个群,首先是532,中间是259,最后是952,里面可以学习和交流,也有资料可以下载。
import java.awt.Font;  
import java.awt.Color;  
import java.awt.Graphics;  
import java.awt.event.MouseAdapter;  
import java.awt.event.MouseEvent;  
import java.util.Arrays;  
import java.util.Random;  
import java.util.Timer;  
import java.util.TimerTask;  
import java.awt.image.BufferedImage;  

import javax.imageio.ImageIO;  
import javax.swing.ImageIcon;  
import javax.swing.JFrame;  
import javax.swing.JPanel;  
/**
 * Java学习交流QQ群:532259952 我们一起学Java!
 */
public class ShootGame extends JPanel {  
    public static final int WIDTH = 400; // 面板宽  
    public static final int HEIGHT = 654; // 面板高  
    /** 游戏的当前状态: START RUNNING PAUSE GAME_OVER */  
    private int state;  
    private static final int START = 0;  
    private static final int RUNNING = 1;  
    private static final int PAUSE = 2;  
    private static final int GAME_OVER = 3;  

    private int score = 0; // 得分  
    private Timer timer; // 定时器  
    private int intervel = 1000 / 100; // 时间间隔(毫秒)  

    public static BufferedImage background;  
    public static BufferedImage start;  
    public static BufferedImage airplane;  
    public static BufferedImage bee;  
    public static BufferedImage bullet;  
    public static BufferedImage hero0;  
    public static BufferedImage hero1;  
    public static BufferedImage pause;  
    public static BufferedImage gameover;  

    private FlyingObject[] flyings = {}; // 敌机数组  
    private Bullet[] bullets = {}; // 子弹数组  
    private Hero hero = new Hero(); // 英雄机  

    static { // 静态代码块,初始化图片资源  
        try {  
            background = ImageIO.read(ShootGame.class  
                    .getResource("background.png"));  
            start = ImageIO.read(ShootGame.class.getResource("start.png"));  
            airplane = ImageIO  
                    .read(ShootGame.class.getResource("airplane.png"));  
            bee = ImageIO.read(ShootGame.class.getResource("bee.png"));  
            bullet = ImageIO.read(ShootGame.class.getResource("bullet.png"));  
            hero0 = ImageIO.read(ShootGame.class.getResource("hero0.png"));  
            hero1 = ImageIO.read(ShootGame.class.getResource("hero1.png"));  
            pause = ImageIO.read(ShootGame.class.getResource("pause.png"));  
            gameover = ImageIO  
                    .read(ShootGame.class.getResource("gameover.png"));  
        } catch (Exception e) {  
            e.printStackTrace();  
        }  
    }  

    /** 画 */  
    @Override  
    public void paint(Graphics g) {  
        g.drawImage(background, 0, 0, null); // 画背景图  
        paintHero(g); // 画英雄机  
        paintBullets(g); // 画子弹  
        paintFlyingObjects(g); // 画飞行物  
        paintScore(g); // 画分数  
        paintState(g); // 画游戏状态  
    }  

    /** 画英雄机 */  
    public void paintHero(Graphics g) {  
        g.drawImage(hero.getImage(), hero.getX(), hero.getY(), null);  
    }  

    /** 画子弹 */  
    public void paintBullets(Graphics g) {  
        for (int i = 0; i < bullets.length; i++) {  
            Bullet b = bullets[i];  
            g.drawImage(b.getImage(), b.getX() - b.getWidth() / 2, b.getY(),  
                    null);  
        }  
    }  

    /** 画飞行物 */  
    public void paintFlyingObjects(Graphics g) {  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            g.drawImage(f.getImage(), f.getX(), f.getY(), null);  
        }  
    }  

    /** 画分数 */  
    public void paintScore(Graphics g) {  
        int x = 10; // x坐标  
        int y = 25; // y坐标  
        Font font = new Font(Font.SANS_SERIF, Font.BOLD, 22); // 字体  
        g.setColor(new Color(0xFF0000));  
        g.setFont(font); // 设置字体  
        g.drawString("SCORE:" + score, x, y); // 画分数  
        y=y+20; // y坐标增20  
        g.drawString("LIFE:" + hero.getLife(), x, y); // 画命  
    }  

    /** 画游戏状态 */  
    public void paintState(Graphics g) {  
        switch (state) {  
        case START: // 启动状态  
            g.drawImage(start, 0, 0, null);  
            break;  
        case PAUSE: // 暂停状态  
            g.drawImage(pause, 0, 0, null);  
            break;  
        case GAME_OVER: // 游戏终止状态  
            g.drawImage(gameover, 0, 0, null);  
            break;  
        }  
    }  

    public static void main(String[] args) {  
        JFrame frame = new JFrame("Fly");  
        ShootGame game = new ShootGame(); // 面板对象  
        frame.add(game); // 将面板添加到JFrame中  
        frame.setSize(WIDTH, HEIGHT); // 设置大小  
        frame.setAlwaysOnTop(true); // 设置其总在最上  
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 默认关闭操作  
        frame.setIconImage(new ImageIcon("images/icon.jpg").getImage()); // 设置窗体的图标  
        frame.setLocationRelativeTo(null); // 设置窗体初始位置  
        frame.setVisible(true); // 尽快调用paint  

        game.action(); // 启动执行  
    }  

    /** 启动执行代码 */  
    public void action() {  
        // 鼠标监听事件  
        MouseAdapter l = new MouseAdapter() {  
            @Override  
            public void mouseMoved(MouseEvent e) { // 鼠标移动  
                if (state == RUNNING) { // 运行状态下移动英雄机--随鼠标位置  
                    int x = e.getX();  
                    int y = e.getY();  
                    hero.moveTo(x, y);  
                }  
            }  

            @Override  
            public void mouseEntered(MouseEvent e) { // 鼠标进入  
                if (state == PAUSE) { // 暂停状态下运行  
                    state = RUNNING;  
                }  
            }  

            @Override  
            public void mouseExited(MouseEvent e) { // 鼠标退出  
                if (state == RUNNING) { // 游戏未结束,则设置其为暂停  
                    state = PAUSE;  
                }  
            }  

            @Override  
            public void mouseClicked(MouseEvent e) { // 鼠标点击  
                switch (state) {  
                case START:  
                    state = RUNNING; // 启动状态下运行  
                    break;  
                case GAME_OVER: // 游戏结束,清理现场  
                    flyings = new FlyingObject[0]; // 清空飞行物  
                    bullets = new Bullet[0]; // 清空子弹  
                    hero = new Hero(); // 重新创建英雄机  
                    score = 0; // 清空成绩  
                    state = START; // 状态设置为启动  
                    break;  
                }  
            }  
        };  
        this.addMouseListener(l); // 处理鼠标点击操作  
        this.addMouseMotionListener(l); // 处理鼠标滑动操作  

        timer = new Timer(); // 主流程控制  
        timer.schedule(new TimerTask() {  
            @Override  
            public void run() {  
                if (state == RUNNING) { // 运行状态  
                    enterAction(); // 飞行物入场  
                    stepAction(); // 走一步  
                    shootAction(); // 英雄机射击  
                    bangAction(); // 子弹打飞行物  
                    outOfBoundsAction(); // 删除越界飞行物及子弹  
                    checkGameOverAction(); // 检查游戏结束  
                }  
                repaint(); // 重绘,调用paint()方法  
            }  

        }, intervel, intervel);  
    }  

    int flyEnteredIndex = 0; // 飞行物入场计数  

    /** 飞行物入场 */  
    public void enterAction() {  
        flyEnteredIndex++;  
        if (flyEnteredIndex % 40 == 0) { // 400毫秒生成一个飞行物--10*40  
            FlyingObject obj = nextOne(); // 随机生成一个飞行物  
            flyings = Arrays.copyOf(flyings, flyings.length + 1);  
            flyings[flyings.length - 1] = obj;  
        }  
    }  

    /** 走一步 */  
    public void stepAction() {  
        for (int i = 0; i < flyings.length; i++) { // 飞行物走一步  
            FlyingObject f = flyings[i];  
            f.step();  
        }  

        for (int i = 0; i < bullets.length; i++) { // 子弹走一步  
            Bullet b = bullets[i];  
            b.step();  
        }  
        hero.step(); // 英雄机走一步  
    }  

    /** 飞行物走一步 */  
    public void flyingStepAction() {  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            f.step();  
        }  
    }  

    int shootIndex = 0; // 射击计数  

    /** 射击 */  
    public void shootAction() {  
        shootIndex++;  
        if (shootIndex % 30 == 0) { // 300毫秒发一颗  
            Bullet[] bs = hero.shoot(); // 英雄打出子弹  
            bullets = Arrays.copyOf(bullets, bullets.length + bs.length); // 扩容  
            System.arraycopy(bs, 0, bullets, bullets.length - bs.length,  
                    bs.length); // 追加数组  
        }  
    }  

    /** 子弹与飞行物碰撞检测 */  
    public void bangAction() {  
        for (int i = 0; i < bullets.length; i++) { // 遍历所有子弹  
            Bullet b = bullets[i];  
            bang(b); // 子弹和飞行物之间的碰撞检查  
        }  
    }  

    /** 删除越界飞行物及子弹 */  
    public void outOfBoundsAction() {  
        int index = 0; // 索引  
        FlyingObject[] flyingLives = new FlyingObject[flyings.length]; // 活着的飞行物  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject f = flyings[i];  
            if (!f.outOfBounds()) {  
                flyingLives[index++] = f; // 不越界的留着  
            }  
        }  
        flyings = Arrays.copyOf(flyingLives, index); // 将不越界的飞行物都留着  

        index = 0; // 索引重置为0  
        Bullet[] bulletLives = new Bullet[bullets.length];  
        for (int i = 0; i < bullets.length; i++) {  
            Bullet b = bullets[i];  
            if (!b.outOfBounds()) {  
                bulletLives[index++] = b;  
            }  
        }  
        bullets = Arrays.copyOf(bulletLives, index); // 将不越界的子弹留着  
    }  

    /** 检查游戏结束 */  
    public void checkGameOverAction() {  
        if (isGameOver()==true) {  
            state = GAME_OVER; // 改变状态  
        }  
    }  

    /** 检查游戏是否结束 */  
    public boolean isGameOver() {  

        for (int i = 0; i < flyings.length; i++) {  
            int index = -1;  
            FlyingObject obj = flyings[i];  
            if (hero.hit(obj)) { // 检查英雄机与飞行物是否碰撞  
                hero.subtractLife(); // 减命  
                hero.setDoubleFire(0); // 双倍火力解除  
                index = i; // 记录碰上的飞行物索引  
            }  
            if (index != -1) {  
                FlyingObject t = flyings[index];  
                flyings[index] = flyings[flyings.length - 1];  
                flyings[flyings.length - 1] = t; // 碰上的与最后一个飞行物交换  

                flyings = Arrays.copyOf(flyings, flyings.length - 1); // 删除碰上的飞行物  
            }  
        }  

        return hero.getLife() <= 0;  
    }  

    /** 子弹和飞行物之间的碰撞检查 */  
    public void bang(Bullet bullet) {  
        int index = -1; // 击中的飞行物索引  
        for (int i = 0; i < flyings.length; i++) {  
            FlyingObject obj = flyings[i];  
            if (obj.shootBy(bullet)) { // 判断是否击中  
                index = i; // 记录被击中的飞行物的索引  
                break;  
            }  
        }  
        if (index != -1) { // 有击中的飞行物  
            FlyingObject one = flyings[index]; // 记录被击中的飞行物  

            FlyingObject temp = flyings[index]; // 被击中的飞行物与最后一个飞行物交换  
            flyings[index] = flyings[flyings.length - 1];  
            flyings[flyings.length - 1] = temp;  

            flyings = Arrays.copyOf(flyings, flyings.length - 1); // 删除最后一个飞行物(即被击中的)  

            // 检查one的类型(敌人加分,奖励获取)  
            if (one instanceof Enemy) { // 检查类型,是敌人,则加分  
                Enemy e = (Enemy) one; // 强制类型转换  
                score += e.getScore(); // 加分  
            } else { // 若为奖励,设置奖励  
                Award a = (Award) one;  
                int type = a.getType(); // 获取奖励类型  
                switch (type) {  
                case Award.DOUBLE_FIRE:  
                    hero.addDoubleFire(); // 设置双倍火力  
                    break;  
                case Award.LIFE:  
                    hero.addLife(); // 设置加命  
                    break;  
                }  
            }  
        }  
    }  

    /** 
     * 随机生成飞行物 
     *  
     * @return 飞行物对象 
     */  
    public static FlyingObject nextOne() {  
        Random random = new Random();  
        int type = random.nextInt(20); // [0,20)  
        if (type < 4) {  
            return new Bee();  
        } else {  
            return new Airplane();  
        }  
    }  

}

写在最后

以上就是这个游戏我整理的完整代码,因为图片差不多9张,所以图片没上传,需要图片的友友请简信我,最后,我做了一张思维导图贴出来让大家更好的理解OOP面向对象编程的过程。

相关文章
|
1月前
|
XML Java 编译器
Java注解的底层源码剖析与技术认识
Java注解(Annotation)是Java 5引入的一种新特性,它提供了一种在代码中添加元数据(Metadata)的方式。注解本身并不是代码的一部分,它们不会直接影响代码的执行,但可以在编译、类加载和运行时被读取和处理。注解为开发者提供了一种以非侵入性的方式为代码提供额外信息的手段,这些信息可以用于生成文档、编译时检查、运行时处理等。
71 7
|
12天前
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
|
1月前
|
存储 JavaScript 前端开发
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
128 13
|
1月前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
1月前
|
人工智能 移动开发 安全
家政上门系统用户端、阿姨端源码,java家政管理平台源码
家政上门系统基于互联网技术,整合大数据分析、AI算法和现代通信技术,提供便捷高效的家政服务。涵盖保洁、月嫂、烹饪等多元化服务,支持多终端访问,具备智能匹配、在线支付、订单管理等功能,确保服务透明、安全,适用于家庭生活的各种需求场景,推动家政市场规范化发展。
|
15天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
71 17
|
25天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
11天前
|
缓存 安全 算法
Java 多线程 面试题
Java 多线程 相关基础面试题
|
27天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。
|
27天前
|
消息中间件 缓存 安全
Java多线程是什么
Java多线程简介:本文介绍了Java中常见的线程池类型,包括`newCachedThreadPool`(适用于短期异步任务)、`newFixedThreadPool`(适用于固定数量的长期任务)、`newScheduledThreadPool`(支持定时和周期性任务)以及`newSingleThreadExecutor`(保证任务顺序执行)。同时,文章还讲解了Java中的锁机制,如`synchronized`关键字、CAS操作及其实现方式,并详细描述了可重入锁`ReentrantLock`和读写锁`ReadWriteLock`的工作原理与应用场景。