`
mmdev
  • 浏览: 13242889 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

人生如梦游戏间,RPG游戏开源开发讲座(JAVA篇)[2]——踏破红尘

 
阅读更多

“本鹏”上回书言道,Java 游戏中地图的构建是一件极其简单的事情,本次书接前文,探讨游戏中角色的移动问题。

众所周知,[角色]是一个游戏的灵魂所在,没有角色的游戏,就是没有灵魂的游戏。

那么,如何让这重要的角色[]起来呢?

现在“本鹏”先演示个简单的实例,以为抛砖引玉之用。

文件 Example2.Java

package org.loon.chair.example2;

import java.awt.Container;

import javax.swing.JFrame;

/**

*

* @author chenpeng

*

* Loon Framework in Game

*

*/

public class Example2 extends JFrame {

public Example2() {

// 默认的窗体名称

setTitle("Example2[Java游戏中角色的移动与限制]");

// 获得我们自定义面板[地图面板]的实例

MyPanel panel = new MyPanel();

Container contentPane = getContentPane();

contentPane.add(panel);

// 执行并构建窗体设定

pack();

}

public static void main(String[] args) {

Example2 e1 = new Example2();

// 设定允许窗体关闭操作

e1.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

// 显示窗体

e1.setVisible(true);

}

}

文件 MyPanel.Java

package org.loon.chair.example2;

import java.awt.Dimension;

import java.awt.Graphics;

import java.awt.Image;

import java.awt.event.KeyEvent;

import java.awt.event.KeyListener;

import javax.swing.ImageIcon;

import javax.swing.JPanel;

/**

* Example1中自定义面板,用于描绘底层地图。

*

* @author chenpeng

*

* Loon Framework in Game

*

* PS:请注意,此处与前例不同,新增键盘事件监听

*/

public class MyPanel extends JPanel implements KeyListener {

//窗体的宽与高

private static final int WIDTH = 480;

private static final int HEIGHT = 480;

//设定背景方格默认行数

private static final int ROW = 15;

//设定背景方格默认列数

private static final int <state w:st="on"><place w:st="on"><em><span lang="EN-US" style='font-size: 10pt; font-family: "Courier New"; color: rgb(0, 0, 192);'>COL</span></em></place></state> = 15;

//单个图像大小,我默认采用32x32图形,可根据需要调整比例。

//当时,始终应和窗体大小比例协调;比如32x32的图片,如何

//一行设置15个,那么就是480,也就是本例子默认的窗体大小,

//当然,我们也可以根据ROW*CS,COl*CS在初始化时自动调整

//窗体大小,以后的例子中会用到类似情况。总之一句话,编程

//[为目的而存在的],所有的方法,大家都可任意尝试和使用。

private static final int CS = 32;

//设定地图,通常在rpg类型游戏开发中,以[二维数组]对象为

//基础进行地图处理,用以描绘出X坐标和Y坐标。实际上,即令

//再华丽的RPG类游戏,都是从这些简单的X,Y坐标开始的。

//PS:所谓[数组],大家可以简单的理解为即数据的集合,一维数组

//仅包含X轴,而二维是由X,Y两个轴组成的,XY的交织点,即为

//一条数据。

private int[][] map = {

{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,1,1,1,1,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,1,0,1,1,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}};

//设定显示图像对象

private Image floorImage;

private Image wallImage;

//角色

private Image roleImage;

//角色坐标

private int x, y;

public MyPanel() {

//设定初始构造时面板大小

setPreferredSize(new Dimension(WIDTH, HEIGHT));

//于初始化时载入图形

loadImage();

//初始化角色所在位置,由于本例行列皆为15,估xy的极限数值也皆为15

//即由15x15的方格图像,组成了角色的可见活动区域。

x = 8;

y = 8;

//设定焦点在本窗体并付与监听对象

setFocusable(true);

addKeyListener(this);

}

//描绘窗体,此处在默认JPanel基础上构建底层地图.

public void paintComponent(Graphics g) {

super.paintComponent(g);

//画出地图

drawMap(g);

//画出人物

drawRole(g);

}

/**

* 载入图像

*

*/

private void loadImage() {

//获得当前类对应的相对位置image文件夹下的地板图像

ImageIcon icon = new ImageIcon(getClass().getResource("image/floor.gif"));

//将地板图像实例付与floorImage

floorImage = icon.getImage();

//获得当前类对应的相对位置image文件夹下的墙体图像

icon = new ImageIcon(getClass().getResource("image/wall.gif"));

//将墙体图像实例付与wallImage

wallImage = icon.getImage();

icon = new ImageIcon(getClass().getResource("image/hero.gif"));

roleImage = icon.getImage();

}

/**

* 有别于上一案例,为控制roleImage移动,需要将其提取至可操作函数中

*/

private void drawRole(Graphics g) {

g.drawImage(roleImage, x * CS, y * CS, this);

}

private void drawMap(Graphics g) {

//Java或任何游戏开发中,算法都是最重要的一步,本例尽使用

//简单的双层for循环进行地图描绘,

for (int x = 0; x < ROW; x++) {

for (int j = 0; j < <state w:st="on"><place w:st="on"><em><span lang="EN-US" style='font-size: 10pt; font-family: "Courier New"; color: rgb(0, 0, 192);'>COL</span></em></place></state>; j++) {

// switch作为java中的转换器,用于执行和()中数值相等

// case操作。请注意,在case操作中如果不以break退出

// 执行;switch函数将持续运算到最后一个case为止。

switch (map[x][j]) {

case 0 : //map的标记为0时画出地板

//在指定位置[描绘]出我们所加载的图形,以下同

g.drawImage(floorImage, j * CS, x * CS, this);

break;

case 1 : //map的标记为1时画出城墙

g.drawImage(wallImage, j * CS, x * CS, this);

break;

//我们可以依次类推出无数的背景组合,如定义椅子为2、宝座为3

//很容易即可勾勒出一张背景地图。

default: //当所有case值皆不匹配时,将执行此操作。

break;

}

}

}

}

public void keyPressed(KeyEvent e) {

//获得按键编号

int keyCode = e.getKeyCode();

//通过转换器匹配事件

switch (keyCode) {

//当触发Left

case KeyEvent.VK_LEFT :

// X--,即向左移动一方格

x--;

break;

//当触发Right

case KeyEvent.VK_RIGHT :

// X++,即向右移动一方格

x++;

break;

//当触发Up

case KeyEvent.VK_UP :

// y--,即向上移动一方格

y--;

break;

//当触发Down

case KeyEvent.VK_DOWN :

// y++,即向下移动一方格

y++;

break;

}

// 重新绘制窗体图像

// PS:在此例程中,仅进行了角色的简单移动处理

// ,关于避免闪烁及限制活动区域问题,请见后续

// 案例。

repaint();

}

/**

* 暂无释放键盘事件

*/

public void keyReleased(KeyEvent e) {

}

/**

* 暂无字符输入事件

*/

public void keyTyped(KeyEvent e) {

}

}

运行效果如下图:

<!--[if gte vml 1]><v:shapetype id="_x0000_t75" coordsize="21600,21600" o:spt="75" o:preferrelative="t" path="m@4@5l@4@11@9@11@9@5xe" filled="f" stroked="f"> <v:stroke joinstyle="miter" /> <v:formulas> <v:f eqn="if lineDrawn pixelLineWidth 0" /> <v:f eqn="sum @0 1 0" /> <v:f eqn="sum 0 0 @1" /> <v:f eqn="prod @2 1 2" /> <v:f eqn="prod @3 21600 pixelWidth" /> <v:f eqn="prod @3 21600 pixelHeight" /> <v:f eqn="sum @0 0 1" /> <v:f eqn="prod @6 1 2" /> <v:f eqn="prod @7 21600 pixelWidth" /> <v:f eqn="sum @8 21600 0" /> <v:f eqn="prod @7 21600 pixelHeight" /> <v:f eqn="sum @10 21600 0" /> </v:formulas> <v:path o:extrusionok="f" gradientshapeok="t" o:connecttype="rect" /> <o:lock v:ext="edit" aspectratio="t" /> </v:shapetype><v:shape id="_x0000_i1025" type="#_x0000_t75" style='width:360.75pt; height:378.75pt'> <v:imagedata src="file:///C:/DOCUME~1/ADMINI~1.443/LOCALS~1/Temp/msohtml1/01/clip_image001.gif" o:title="e3_01" /> </v:shape><![endif]--><!--[if !vml]--><!--[endif]-->

如何?角色确实动起来了吧?

但是,这样的角色缺点也是很明显的,主要体现在两点:

<!--[if !supportLists]-->1. <!--[endif]-->角色的活动区域:角色移动没有制约,简直如[天外飞仙]般横行无忌。

<!--[if !supportLists]-->2. <!--[endif]-->画面的闪烁:每当角色移动时都将重新绘制画面,以至于画面闪烁不定。

<!--[if !supportLists]-->3. <!--[endif]-->角色的行动:就一个动作还能移动,好像[驭剑飞行],又好像[百鬼夜行]……

那么,我们又将如何解决这些问题呢?

不要着急,请看下面的案例:

我们都知道,人在刚刚出生时,[思想]是不受任何制约的,或者说,连[制约]这个概念都不曾存在过,但为了适应[社会化]的生活,才不得接触和学习到所谓的[规范][法规]

游戏中的角色也是一样,当角色刚刚成型的那一瞬间,某种意义上根本就是[天下无敌]的最强存在,只有当我们用[规范]加以制约后,才分别出后来的[路人甲][恶魔王]

现在我们开始制造[规范],代码如下:

我们重新整理MyPanel.Java代码如下:

package org.loon.chair.example2;

import java.awt.Dimension;

import java.awt.Graphics;

import java.awt.Image;

import java.awt.event.KeyEvent;

import java.awt.event.KeyListener;

import javax.swing.ImageIcon;

import javax.swing.JPanel;

/**

* Example1中自定义面板,用于描绘底层地图。

*

* @author chenpeng

*

* Loon Framework in Game

*

* PS:请注意,此处与前例不同,新增键盘事件监听

*/

public class MyPanel extends JPanel implements KeyListener {

//窗体的宽与高

private static final int WIDTH = 480;

private static final int HEIGHT = 480;

//设定背景方格默认行数

private static final int ROW = 15;

//设定背景方格默认列数

private static final int <state w:st="on"><place w:st="on"><em><span lang="EN-US" style='font-size: 10pt; font-family: "Courier New"; color: rgb(0, 0, 192);'>COL</span></em></place></state> = 15;

//单个图像大小,我默认采用32x32图形,可根据需要调整比例。

//当时,始终应和窗体大小比例协调;比如32x32的图片,如何

//一行设置15个,那么就是480,也就是本例子默认的窗体大小,

//当然,我们也可以根据ROW*CS,COl*CS在初始化时自动调整

//窗体大小,以后的例子中会用到类似情况。总之一句话,编程

//[为目的而存在的],所有的方法,大家都可任意尝试和使用。

private static final int CS = 32;

//设定地图,通常在rpg类型游戏开发中,以[二维数组]对象为

//基础进行地图处理,用以描绘出X坐标和Y坐标。实际上,即令

//再华丽的RPG类游戏,都是从这些简单的X,Y坐标开始的。

//PS:所谓[数组],大家可以简单的理解为即数据的集合,一维数组

//仅包含X轴,而二维是由X,Y两个轴组成的,XY的交织点,即为

//一条数据。

private int[][] map = {

{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,1,1,1,1,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,0,0,0,1,0,0,0,0,1},

{1,0,0,0,0,1,1,0,1,1,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,0,0,0,0,0,0,0,0,0,0,0,0,0,1},

{1,1,1,1,1,1,1,1,1,1,1,1,1,1,1}};

//设定显示图像对象

private Image floorImage;

private Image wallImage;

//角色

private Image roleImage;

//角色坐标

private int x, y;

//此处我们添加一组常数,用以区别左右上下按键的触发,

//之所以采用数字进行区别,原因大家都很清楚^^,数字

//运算效率高嘛~

private static final int LEFT = 0;

private static final int RIGHT = 1;

private static final int UP = 2;

private static final int DOWN = 3;

public MyPanel() {

//设定初始构造时面板大小

setPreferredSize(new Dimension(WIDTH, HEIGHT));

//于初始化时载入图形

loadImage();

//初始化角色所在位置,由于本例行列皆为15,估xy的极限数值也皆为15

//即由15x15的方格图像,组成了角色的可见活动区域。

x = 8;

y = 8;

//设定焦点在本窗体并付与监听对象

setFocusable(true);

addKeyListener(this);

}

//描绘窗体,此处在默认JPanel基础上构建底层地图.

public void paintComponent(Graphics g) {

super.paintComponent(g);

//画出地图

drawMap(g);

//画出人物

drawRole(g);

}

/**

* 载入图像

*

*/

private void loadImage() {

//获得当前类对应的相对位置image文件夹下的地板图像

ImageIcon icon = new ImageIcon(getClass().getResource("image/floor.gif"));

//将地板图像实例付与floorImage

floorImage = icon.getImage();

//获得当前类对应的相对位置image文件夹下的墙体图像

icon = new ImageIcon(getClass().getResource("image/wall.gif"));

//将墙体图像实例付与wallImage

wallImage = icon.getImage();

icon = new ImageIcon(getClass().getResource("image/hero.gif"));

roleImage = icon.getImage();

}

/**

* 有别于上一案例,为控制roleImage移动,需要将其提取至可操作函数中

*/

private void drawRole(Graphics g) {

g.drawImage(roleImage, x * CS, y * CS, this);

}

private void drawMap(Graphics g) {

//Java或任何游戏开发中,算法都是最重要的一步,本例尽使用

//简单的双层for循环进行地图描绘,

for (int x = 0; x < ROW; x++) {

for (int j = 0; j < <state w:st="on"><place w:st="on"><em><span lang="EN-US" style='font-size: 10pt; font-family: "Courier New"; color: rgb(0, 0, 192);'>COL</span></em></place></state>; j++) {

// switch作为java中的转换器,用于执行和()中数值相等

// case操作。请注意,在case操作中如果不以break退出

// 执行;switch函数将持续运算到最后一个case为止。

switch (map[x][j]) {

case 0 : //map的标记为0时画出地板

//在指定位置[描绘]出我们所加载的图形,以下同

g.drawImage(floorImage, j * CS, x * CS, this);

break;

case 1 : //map的标记为1时画出城墙

g.drawImage(wallImage, j * CS, x * CS, this);

break;

//我们可以依次类推出无数的背景组合,如定义椅子为2、宝座为3

//很容易即可勾勒出一张背景地图。

default: //当所有case值皆不匹配时,将执行此操作。

break;

}

}

}

}

public void keyPressed(KeyEvent e) {

//获得按键编号

int keyCode = e.getKeyCode();

//通过转换器匹配事件

switch (keyCode) {

//当触发Left

case KeyEvent.VK_LEFT :

//进行left操作,仅符合move()[规范]时执行,以下相同

move(LEFT);

break;

//当触发Right

case KeyEvent.VK_RIGHT :

move(RIGHT);

break;

//当触发Up

case KeyEvent.VK_UP :

move(UP);

break;

//当触发Down

case KeyEvent.VK_DOWN :

move(DOWN);

break;

}

// 重新绘制窗体图像

// PS:在此例程中,仅进行了角色的简单移动处理

// ,关于避免闪烁及限制活动区域问题,请见后续

// 案例。

repaint();

}

/**

* 用于判定是否允许移动的发生,被move()函数调用

* @param x

* @param y

* @return

*/

private boolean isAllow(int x, int y) {

// (x,y)交点进行数据判定,我们都知道,

// 在本例中我仅以0作为地板的参数,1作为

// 墙的参数,由于我们的主角是[人类],而

// 不是[幽灵],所以当他要[撞墙]时,我们

// 当然不会允许,至少,是我讲到剧情的触发

// 以前……

if (map[y][x] == 1) {

// 不允许移动时,返回[]

return false;

}

// 允许移动时时,返回[]

return true;

}

/**

* 判断移动事件,关联isAllow()函数

* @param event

*/

private void move(int event) {

//以转换器判断相关事件,仅执行符合[规范]的操作。

switch (event) {

case LEFT:

//依次判定事件

if (isAllow(x-1, y)) x--;

break;

case RIGHT:

if (isAllow(x+1, y)) x++;

break;

case UP:

if (isAllow(x, y-1)) y--;

break;

case DOWN:

if (isAllow(x, y+1)) y++;

break;

default:

break;

}

}

/**

* 暂无释放键盘事件

*/

public void keyReleased(KeyEvent e) {

}

/**

* 暂无字符输入事件

*/

public void keyTyped(KeyEvent e) {

}

}

这样我们可怜的角色,就如同我们般被名为[规范]的枷锁所制约,永远无法穿墙破壁了……

好了,本讲到此告一段落,关于画面闪烁问题的解决和角色动作的变更,我们暂且留到下回分解

PS:另外请大家不要着急,本讲座将由浅入深,将本人业余时,对Java游戏开发的经验做一次彻底的归纳总结,没有一、二百节,是绝对讲不完的……(“本鹏”继续看“新番”去了……-_-|||

分享到:
评论

相关推荐

    java写的坦克游戏源代码

    这个游戏是在Eclipse3.3+JDK1.6下编译运行的(注意:必须要是在JDK1.6或者是JDK1.6以上才可以,不然就会出现错误). 游戏中简单增加了声音的处理,可惜的就是没有图片. 这是一个JAVA工程,下载下来之后直接有Eclipse导...

    java写的贪吃蛇游戏

    这个是比较原始的版本,因为游戏中只实现了蛇的基本功能,并没有加入游戏的规则. 这些代码是在JDK1.5下编译运行的.所以必须装上JDK1.5或者以上的版本,不然会出现一些小小的错误,这是JDK之间不兼容造成的. 蛇用...

    前端吃豆游戏小案列适合新手

    在本文中,我们将深入探讨一个非常适合前端新手学习的项目——"吃豆游戏"。这个案例旨在帮助初学者掌握基本的前端开发技术,并通过实践提升编程技能。吃豆游戏是一款经典的街机游戏,其简单易懂的规则和玩法使得它...

    WEB网页端进销存源代码C#、ASP.net全部开源

    该资源是一个基于C#语言和ASP.NET技术开发的WEB网页端进销存系统源代码,完全开源,适用于希望深入理解或定制此类应用的开发者。这个系统利用了MS-SQL2008作为后端数据库,提供了全面的企业级库存和财务管理功能。 ...

    java实现的电脑自动关机

    在Java编程环境中,实现电脑自动关机功能是一个实用且有趣的任务,它涵盖了多个核心知识点,包括线程处理、图形化用户界面(GUI)设计以及时间管理。以下将详细阐述这些内容。 首先,Java中的线程是多任务处理的...

    人生如梦,岁月如歌.doc

    人生如梦,岁月如歌,这篇文章收集了十八则人生哲理精华,涵盖了人生的各个方面,包括自我珍惜、生命的价值、人生的目标、情商管理、自我完善等方面。以下是从文章中提炼出的知识点: 1. 珍惜生命:人生的路上开满...

    Unity《勇士传说》横版卷轴动作类游戏开发教程

    Unity《勇士传说》横版卷轴动作类游戏开发教程

    基于Java语言和SSM框架编写的考试管理系统

    SSM框架是Java Web开发中常用的一种整合框架,由Spring、Spring MVC和MyBatis三个开源框架组成。这个基于Java语言和SSM框架编写的考试管理系统,充分利用了这三个框架的优点,实现了高效、灵活的考试管理功能。 1. ...

    蜘蛛纸牌VC++

    【蜘蛛纸牌VC++】是使用C++编程语言在Visual C++环境下开发的一款经典单机版纸牌游戏。蜘蛛纸牌作为一款广受欢迎的休闲益智游戏,其规则和玩法深受用户喜爱。在这个版本中,开发者利用VC++的MFC(Microsoft ...

    一个完全免费的WEB打印插件控件,支持:C#/vb.net/asp/PHP/JSP,也有实例

    2. VB.NET:Visual Basic .NET是另一种.NET语言,它简化了编程语法,使初学者更容易上手。VB.NET同样可以用于创建Web应用程序,并且可以调用Web打印插件,为用户提供打印服务。 3. ASP:Active Server Pages是微软...

    初三语文复习总指导讲座.ppt

    2. 生活中总会遇到困难和挫折,但我们要有坚定信念,正如苏轼《念奴娇·赤壁怀古》中所言:“人生如梦,一尊还酹江月。” 通过这些复习方法和技巧,学生可以有效地掌握古诗文知识,提高中考语文成绩。同时,对古...

    1临江仙——学习ppt课件

    ### 临江仙·夜登小阁,忆洛中旧游——解读与分析 #### 一、背景介绍 《临江仙·夜登小阁,忆洛中旧游》是北宋末、南宋初年杰出诗人陈与义创作的一首词。陈与义,字去非,号简斋,其作品以其独特的艺术魅力而闻名...

    2019年新版----特种设备作业——快开门式压力容器.docx

    本篇文章将详细解析快开门式压力容器的一些关键知识点。 首先,我们要了解简单压力容器的定义。根据描述,简单压力容器是指设计压力不超过1.6MPa,容积小于或等于1000L,工作压力与容积乘积在2.5MPa至1000MPa之间的...

    人生如梦,一尊还酹江月。苏轼念奴娇_赤壁怀古全诗翻译赏析

    人生如梦一尊还酹江月苏轼念奴娇赤壁 怀古全诗翻译赏析 原文 大江东去浪淘尽千古风流人物故垒西边人道是三国周郎赤壁 乱石穿空惊涛拍岸卷起千堆雪江山如画一时多少豪杰 遥想公瑾当年小乔初嫁了雄姿英发羽扇纶

    一个基于Spring boot+mybatis客户管理系统

    本项目——“基于Spring Boot+MyBatis的CRM客户管理系统”就是这样一个实用的平台,适合作为开发者的学习模板或企业内部的CRM解决方案。 Spring Boot是Spring框架的简化版,它内置了Tomcat服务器,提供了快速开发...

    高中语文经典素材优美句子.doc

    2. 人行秋色之中,脚下踩的,发上戴的,肩上似有意无意飘坠的,莫非明艳的金黄与黄金。——余光中 这句话运用了比喻的修辞手法,把落叶比作黄金,生动形象地表现了秋天的美丽景象。 3. 那雪,白得虚虚幻幻,冷得...

    安徽省六安市第一中学2019_2020学年高一语文下学期延期开学期间辅导作业专题卷一基础4202003100224

    (1) “人生如梦,一尊还酹江月”——《念奴娇·赤壁怀古》(苏轼) (2) “舞榭歌台,风流总被雨打风吹去”——《永遇乐·京口北固亭怀古》(辛弃疾) (3) “所守或匪亲,化为狼与豺”——《蜀道难》(李白) 这些知识...

    org.apache.commosjar包

    Apache Commons 是一个由 Apache 软件基金会维护的开源项目集合,它提供了许多Java库,以解决常见的编程任务。在给定的“org.apache.commons.jar”包中,我们可以期待找到一系列用于简化Java开发的工具类和实用程序...

    spring mvc示例

    2. **Hibernate**:Hibernate是一个对象关系映射(ORM)框架,它简化了Java应用程序与数据库之间的交互。在这个示例中,Hibernate用于处理数据持久化,将Java对象转化为SQL语句执行,并将查询结果转化为Java对象。...

    人生的感悟作文.doc

    《人生的感悟》这篇作文,通过阅读《钢铁是怎样炼成的》这部经典著作,引发了作者对人生的深入思考。这本书讲述了主人公保尔·柯察金在革命斗争中经历重重困难,最终成为一名坚定的共产主义战士的故事,带给读者深刻...

Global site tag (gtag.js) - Google Analytics