会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132885个问题
JAVA 全系列/第十阶段:百战旅游网项目/百战旅游网 7696楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 7697楼

package cn.sxt.game;


import java.awt.Frame;

import java.awt.Graphics;

import java.awt.Image;

import java.awt.event.KeyAdapter;

import java.awt.event.KeyEvent;

import java.awt.event.WindowAdapter;

import java.awt.event.WindowEvent;


public class MyGameFrame extends Frame {


Image mm = GameUtil.getImage("images/mm.png");

Image q = GameUtil.getImage("images/q.jpg");


Plane plane = new Plane(mm, 460, 460);//new飞机

//Shell shell = new Shell();//new炮弹

Shell[] shells = new Shell[50];//数组产生多发炮弹


@Override

public void paint(Graphics g) { // 帮助做窗口的绘制,自动被调用,g相当于一支画笔

super.paint(g);


g.drawImage(q, 0, 0, null);


plane.drawSelf(g);// 画飞机

//画出所有炮弹

for(int i =0;i<shells.length;i++) {

shells[i].draw(g);//画炮弹

//看有没有和飞机相碰撞

boolean peng = shells[i].getRect().intersects(plane.getRect());

             

            if(peng) {

                plane.live = false;

            }

}


}


// 帮助我们反复的重画窗口

class PaintThread extends Thread {

@Override

public void run() {

while (true) {

//System.out.println("窗口画一次");

repaint(); // 重画


try {

Thread.sleep(40); // 1s==1000ms

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}


}


// 定义键盘监听的内部类

class KeyMonitor extends KeyAdapter {


@Override

public void keyPressed(KeyEvent e) {

plane.addDirection(e);

}


@Override

public void keyReleased(KeyEvent e) {

plane.minusDirection(e);

}


}


/*

* 初始化窗口*

*/

public void launchFrame() {

this.setTitle("梁乾康作品!");

this.setVisible(true);// 使可见

this.setSize(Constant.GAME_WIDTH,Constant.GAME_HEIGHT);

this.setLocation(200, 100);


this.addWindowListener(new WindowAdapter() {

@Override

public void windowClosing(WindowEvent arg0) {

System.exit(0);

}

});


new PaintThread().start();// 启动重画窗口的线程

addKeyListener(new KeyMonitor());// 给窗口增加键盘的监听

//初始化50发炮弹

for(int i=0;i<shells.length;i++) {

shells[i] = new Shell();

}


}


public static void main(String[] args) {

MyGameFrame f = new MyGameFrame();

f.launchFrame();

}


/**

* 解决闪烁问题

* */

private Image offScreenImage=null;

public void update(Graphics g) {

if(offScreenImage==null) 

offScreenImage=this.createImage(Constant.GAME_WIDTH,Constant.GAME_HEIGHT);//游戏窗口宽高

Graphics gOff = offScreenImage.getGraphics();

paint(gOff);

g.drawImage(offScreenImage, 0, 0, null);

}

}

image.png老师请问学生哪里出错了

JAVA 全系列/第一阶段:JAVA 快速入门/飞机大战小项目训练 7698楼
Python 全系列/第五阶段:数据库编程/MySQL数据库的使用 7701楼
JAVA 全系列/(旧的隐藏)第十阶段:spring全家桶(SpringData)/Spring Data 7702楼
JAVA 全系列/第一阶段:JAVA 快速入门/面向对象详解和JVM底层内存分析 7704楼
Python 全系列/第六阶段:生产环境部署与协同开发/Linux基本命令 7705楼
Python 全系列/第二阶段:Python 深入与提高/GUI编程(隐藏) 7707楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/GraphQL 7708楼
JAVA 全系列/第一阶段:JAVA 快速入门/数组和数据存储 7709楼

package com.itbaizhan.myLIST;

public class MyDoublyLinkedList<E> implements MyList<E> {

    //定义双向列表节点对象
    class Node<E>{
        E item;
        Node<E> prev;//用来记录前一个地址的节点对象
        Node<E> next;//记录下一个
        Node(Node<E> prev,E item,Node<E> next){
            this.item = item;
            this.next = next;
            this.prev = prev;
        }
    }
    private Node head;//记录头节点
    private Node tail;//记录尾节点
    private int size;


    @Override
    public void add(E element) {
        this.LinkLast(element);

    }

    //将节点对象添加到双向链表的尾部

    private void LinkLast(E element){
        Node t = this.tail;
        //创建节点对象
        Node<E> node = new Node<>(t,element,null);
        //将新节点定义为尾节点
        this.tail = node;
        if (t==null){
            this.head = node;
        }else {
            t.next= node;

        }
        this.size++;

    }

    @Override
    public E get(int index) {
        //先进行合法性校验
        this.checkIndex(index);
        //根据位置查找节点对象
        Node<E> node = this.getNode(index);

        return node.item;
    }

    private void checkIndex(int index){
        if (index>=0&&index<this.size){
            throw new IndexOutOfBoundsException(index+"     "+size);
        }
    }
    //根据位置获取指定节点对象
    private Node getNode(int index){
        //判断当前位置距离头尾哪个节点近
        if (index<(this.size>>1)){
            Node node = this.head;
            for (int i = 0;i<index;i++){
                node = node.next;
            }
            return node;
        }else{
            Node node = this.tail;
            for (int i = this.size-1;i>index;i--){
                node = node.prev;
            }
            return node;
        }

    }

    @Override
    public int size() {
        return this.size;
    }

    @Override
    public E remove(int index) {
        //对index进行合法性校验
        this.checkIndex(index);
        //根据位置获取节点对象
        Node<E> node =  this.getNode(index);
        //获取节点对象中的元素
        E item = node.item;
        //判断当前节点是否为头节点
        if (node.prev == null){
            this.head = node.next;
        }else{
            //完成当前节点的直接前驱节点与当前节点的直接后继节点的挂接
            node.prev.next = node.next;
        }
        //判断当前节点是否为尾节点
        if (node.next==null){
            this.tail = node.prev;

        }else {
            node.next.prev = node.prev;
        }
        node.prev = null;
        node.next = null;
        node.item = null;
        this.size--;
        return item;
    }


    //再双向列表的头添加元素
    public void addFirst(E element){
        this.linkFirst(element);

    }

    //在链表的头添加元素

    private void linkFirst(E element){
        //获取头节点对象
        Node head = this.head;
        Node node = new Node(null,element,head);
        //将新节点定义为头节点
        this.head = node;
        //判断当前链表中是否有节点,如果有即是头也是尾
        if (head==null){
            this.tail = node;

        }else{
            head.prev = node;
        }
        //记录个数
        this.size++;

    }

    public void addLast(E element){
        this.LinkLast(element);
    }

    public static void main(String[] args) {

        System.out.println("-------------------");
        MyDoublyLinkedList<String> list = new MyDoublyLinkedList<>();
        list.add("a");
        list.addFirst("A");
        list.addLast("b");
        System.out.println(list.get(1));

        for (int i = 0;i<list.size();i++){
            System.out.println(list.get(i));
        }



    }
}

报了一个这样的错误,但我总觉得没错才对,所以想请教一下老师


-------------------

Exception in thread "main" java.lang.IndexOutOfBoundsException: 1     3

at com.itbaizhan.myLIST.MyDoublyLinkedList.checkIndex(MyDoublyLinkedList.java:57)

at com.itbaizhan.myLIST.MyDoublyLinkedList.get(MyDoublyLinkedList.java:48)

at com.itbaizhan.myLIST.MyDoublyLinkedList.main(MyDoublyLinkedList.java:151)


JAVA 全系列/第二阶段:JAVA 基础深化和提高/数据结构 7710楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637