Spring和Hibernate的整合操作示例

本文实例讲述了Spring和Hibernate的整合操作。分享给大家供大家参考,具体如下:

一 web配置

<?xml version="1.0" encoding="GBK"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
  http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  version="3.1">
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener
    </listener-class>
  </listener>
  <filter>
    <filter-name>struts2</filter-name>
    <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>struts2</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

二 applicationContext.xml

<?xml version="1.0" encoding="GBK"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xmlns="http://www.springframework.org/schema/beans"
  xmlns:p="http://www.springframework.org/schema/p"
  xmlns:tx="http://www.springframework.org/schema/tx"
  xmlns:aop="http://www.springframework.org/schema/aop"
  xsi:schemaLocation="http://www.springframework.org/schema/beans
  http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  http://www.springframework.org/schema/tx
  http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
  http://www.springframework.org/schema/aop
  http://www.springframework.org/schema/aop/spring-aop-4.0.xsd">
  <!-- 定义数据源Bean,使用C3P0数据源实现,并注入数据源的必要信息 -->
  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
    destroy-method="close"
    p:driverClass="com.mysql.jdbc.Driver"
    p:jdbcUrl="jdbc:mysql://localhost/spring"
    p:user="root"
    p:password="32147"
    p:maxPoolSize="40"
    p:minPoolSize="2"
    p:initialPoolSize="2"
    p:maxIdleTime="30"/>
  <!-- 定义Hibernate的SessionFactory,SessionFactory需要依赖数据源,注入dataSource -->
  <bean id="sessionFactory"
    class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"
    p:dataSource-ref="dataSource">
    <!-- mappingResources用来列出全部映射文件 -->
    <property name="annotatedClasses">
      <list>
        <!-- 以下用来列出所有的PO类-->
        <value>org.crazyit.booksys.domain.Book</value>
      </list>
    </property>
    <!-- 定义Hibernate SessionFactory的属性 -->
    <property name="hibernateProperties">
      <props>
        <!-- 指定Hibernate的连接方言 -->
        <prop key="hibernate.dialect">
          org.hibernate.dialect.MySQL5InnoDBDialect</prop>
        <!--是否根据Hiberante映射创建数据表 -->
        <prop key="hibernate.hbm2ddl.auto">update</prop>
        <prop key="hibernate.show_sql">true</prop>
        <prop key="hibernate.format_sql">true</prop>
      </props>
    </property>
  </bean>
  <!-- 定义Service组件,并将DAO组件注入Service组件 -->
  <bean id="bookService" class="org.crazyit.booksys.service.impl.BookServiceImpl"
    p:bookDao-ref="bookDao"/>
  <!-- 定义DAO组件,并将SessionFactory注入DAO组件 -->
  <bean id="bookDao" class="org.crazyit.booksys.dao.impl.BookDaoHibernate4"
    p:sessionFactory-ref="sessionFactory"/>
  <!-- 配置Hibernate的局部事务管理器,使用HibernateTransactionManager类 -->
  <!-- 该类是PlatformTransactionManager接口针对采用Hibernate的特定实现类 -->
  <!-- 配置HibernateTransactionManager需依赖注入SessionFactory -->
  <bean id="transactionManager"
    class="org.springframework.orm.hibernate4.HibernateTransactionManager"
    p:sessionFactory-ref="sessionFactory"/>
<!-- 配置事务增强处理Bean,指定事务管理器 -->
<tx:advice id="txAdvice"
  transaction-manager="transactionManager">
  <!-- 用于配置详细的事务定义 -->
  <tx:attributes>
    <!-- 所有以'get'开头的方法是read-only的 -->
    <tx:method name="get*" read-only="true"/>
    <!-- 其他方法使用默认的事务设置,指定超时时长为5秒 -->
    <tx:method name="*" isolation="DEFAULT"
      propagation="REQUIRED" timeout="5"/>
  </tx:attributes>
</tx:advice>
<!-- AOP配置的元素 -->
<aop:config>
  <!-- 配置一个切入点 -->
  <aop:pointcut id="myPointcut" expression="bean(bookService)"/>
  <!-- 指定在myPointcut切入点应用txAdvice事务增强处理 -->
  <aop:advisor advice-ref="txAdvice"
    pointcut-ref="myPointcut"/>
</aop:config>
</beans>

三 Struts配置

<?xml version="1.0" encoding="GBK"?>
<!-- 指定Struts 2配置文件的DTD信息 -->
<!DOCTYPE struts PUBLIC
  "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
  "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
  <!-- 配置了系列常量 -->
  <constant name="struts.i18n.encoding" value="GBK"/>
  <constant name="struts.enable.DynamicMethodInvocation" value="false" />
  <constant name="struts.devMode" value="true"/>
  <package name="lee" extends="struts-default">
    <action name="addBook" class="org.crazyit.booksys.action.BookAction"
      method="add">
      <!-- 添加图书成功,列出所有图书 -->
      <result type="chain">listBooks</result>
      <!-- 添加图书失败,跳转到添加图书的表单页 -->
      <result name="error">/WEB-INF/content/bookForm.jsp</result>
    </action>
    <action name="listBooks" class="org.crazyit.booksys.action.BookAction"
      method="list">
      <result>/WEB-INF/content/listBooks.jsp</result>
    </action>
    <action name="deleteBook" class="org.crazyit.booksys.action.BookAction"
      method="delete">
      <result type="chain">listBooks</result>
    </action>
    <!-- 让用户直接访问该应用时列出所有视图页面 -->
    <action name="*">
      <result>/WEB-INF/content/{1}.jsp</result>
    </action>
  </package>
</struts>

四 视图

1 bookForm.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>添加图书</title>
</head>
<body>
<h3>添加图书</h3>
<s:form action="addBook">
  <s:textfield name="book.name" label="书名"/>
  <s:textfield name="book.price" label="价格"/>
  <s:textfield name="book.author" label="作者"/>
  <tr align="center">
    <td colspan="2">
    <s:submit value="添加" theme="simple"/>
    <s:reset value="重设" theme="simple"/>
    </td>
  </tr>
</s:form>
</body>
</html>

2 listBooks.jsp

<%@ page contentType="text/html; charset=GBK" language="java" errorPage="" %>
<%@taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>全部图书</title>
</head>
<body>
<h3>全部图书</h3>
<table width="640" border="1">
  <s:iterator value="books" var="b">
    <tr>
      <td><s:property value="name"/></td>
      <td><s:property value="price"/></td>
      <td><s:property value="author"/></td>
      <td><a href="${pageContext.request.contextPath}/deleteBook?id=${b.id}" rel="external nofollow" >删除</a></td>
    </tr>
  </s:iterator>
</table>
</body>
</html>

五 domain

package org.crazyit.booksys.domain;
import javax.persistence.*;
@Entity
@Table(name="book_inf")
public class Book
{
  @Id @Column(name="book_id")
  @GeneratedValue(strategy=GenerationType.IDENTITY)
  private Integer id;
  @Column(name="book_name")
  private String name;
  private double price;
  private String author;
  public Integer getId()
  {
    return id;
  }
  public void setId(Integer id)
  {
    this.id = id;
  }
  public String getName()
  {
    return name;
  }
  public void setName(String name)
  {
    this.name = name;
  }
  public double getPrice()
  {
    return price;
  }
  public void setPrice(double price)
  {
    this.price = price;
  }
  public String getAuthor()
  {
    return author;
  }
  public void setAuthor(String author)
  {
    this.author = author;
  }
}

六 action

package org.crazyit.booksys.action;
import java.util.List;
import org.crazyit.booksys.domain.Book;
import org.crazyit.booksys.service.BookService;
import com.opensymphony.xwork2.ActionSupport;
public class BookAction extends ActionSupport
{
  private BookService bookService;
  // 依赖注入BookService组件必须的setter方法。
  // 该方法的方法名要与BookService的配置id对应
  public void setBookService(BookService bookService)
  {
    this.bookService = bookService;
  }
  private Book book;
  private List<Book> books;
  private int id;
  public Book getBook()
  {
    return book;
  }
  public void setBook(Book book)
  {
    this.book = book;
  }
  public List<Book> getBooks()
  {
    return books;
  }
  public void setBooks(List<Book> books)
  {
    this.books = books;
  }
  public int getId()
  {
    return id;
  }
  public void setId(int id)
  {
    this.id = id;
  }
  // 处理添加图书的add()方法
  public String add()
  {
    // 调用业务逻辑组件的addBook()方法来处理用户请求
    int result = bookService.addBook(book);
    if(result > 0)
    {
      addActionMessage("恭喜您,图书添加成功!");
      return SUCCESS;
    }
    addActionError("图书添加失败,请重新输入!");
    return ERROR;
  }
  public String list()
  {
    setBooks(bookService.getAllBooks());
    return SUCCESS;
  }
  public String delete()
  {
    bookService.deleteBook(id);
    return SUCCESS;
  }
}

七 service

1 BookService.java

package org.crazyit.booksys.service;
import java.util.List;
import org.crazyit.booksys.domain.Book;
public interface BookService
{
  // 添加图书
  int addBook(Book book);
  List<Book> getAllBooks();
  void deleteBook(int id);
}

2 BookServiceImpl.java

package org.crazyit.booksys.service.impl;
import java.util.List;
import org.crazyit.booksys.dao.BookDao;
import org.crazyit.booksys.domain.Book;
import org.crazyit.booksys.service.BookService;
public class BookServiceImpl implements BookService
{
  private BookDao bookDao;
  public void setBookDao(BookDao bookDao)
  {
    this.bookDao = bookDao;
  }
  @Override
  public int addBook(Book book)
  {
    return (Integer) bookDao.save(book);
  }
  @Override
  public List<Book> getAllBooks()
  {
    return bookDao.findAll(Book.class);
  }
  @Override
  public void deleteBook(int id)
  {
    bookDao.delete(Book.class,id);
  }
}

八 dao

BaseDao.java

package org.crazyit.common.dao;
import java.util.List;
import java.io.Serializable;
public interface BaseDao<T>
{
  // 根据ID加载实体
  T get(Class<T> entityClazz,Serializable id);
  // 保存实体
  Serializable save(T entity);
  // 更新实体
  void update(T entity);
  // 删除实体
  void delete(T entity);
  // 根据ID删除实体
  void delete(Class<T> entityClazz,Serializable id);
  // 获取所有实体
  List<T> findAll(Class<T> entityClazz);
  // 获取实体总数
  long findCount(Class<T> entityClazz);
}

BaseDaoHibernate3.java

package org.crazyit.common.dao.impl;
import java.io.Serializable;
import java.util.List;
import org.crazyit.common.dao.BaseDao;
import org.hibernate.*;
import org.springframework.orm.hibernate4.support.HibernateDaoSupport;
import org.springframework.orm.hibernate4.HibernateCallback;
public class BaseDaoHibernate3<T> extends HibernateDaoSupport
  implements BaseDao<T>
{
  // 根据ID加载实体
  public T get(Class<T> entityClazz,Serializable id)
  {
    return getHibernateTemplate().get(entityClazz,id);
  }
  // 保存实体
  public Serializable save(T entity)
  {
    return getHibernateTemplate().save(entity);
  }
  // 更新实体
  public void update(T entity)
  {
    getHibernateTemplate().saveOrUpdate(entity);
  }
  // 删除实体
  public void delete(T entity)
  {
    getHibernateTemplate().delete(entity);
  }
  // 根据ID删除实体
  public void delete(Class<T> entityClazz,Serializable id)
  {
    delete(get(entityClazz,id));
  }
  @Override
  @SuppressWarnings("unchecked")
  public List<T> findAll(Class<T> entityClazz)
  {
    return (List<T>)getHibernateTemplate().find("select en from "
      + entityClazz.getSimpleName() + " en");
  }
  @Override
  @SuppressWarnings("unchecked")
  public long findCount(Class<T> entityClazz)
  {
    List<Long> list = (List<Long>)getHibernateTemplate().find(
      "select count(*) from " + entityClazz.getSimpleName() + " en");
    return list.get(0);
  }
  /**
   * 使用hql 语句进行分页查询操作
   * @param hql 需要查询的hql语句
   * @param pageNo 查询第pageNo页的记录
   * @param pageSize 每页需要显示的记录数
   * @return 当前页的所有记录
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(final String hql,final int pageNo,final int pageSize)
  {
    // 通过一个HibernateCallback对象来执行查询
    List<T> list = getHibernateTemplate()
      .execute(new HibernateCallback<List<T>>()
    {
      // 实现HibernateCallback接口必须实现的方法
      public List<T> doInHibernate(Session session)
      {
        // 执行Hibernate分页查询
        List<T> result = session.createQuery(hql)
          .setFirstResult((pageNo - 1) * pageSize)
          .setMaxResults(pageSize)
          .list();
        return result;
      }
    });
    return list;
  }
  /**
   * 使用hql 语句进行分页查询操作
   * @param hql 需要查询的hql语句
   * @param pageNo 查询第pageNo页的记录
   * @param pageSize 每页需要显示的记录数
   * @param params 如果hql带占位符参数,params用于传入占位符参数
   * @return 当前页的所有记录
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(final String hql,final int pageSize,final Object... params)
  {
    // 通过一个HibernateCallback对象来执行查询
    List<T> list = getHibernateTemplate()
      .execute(new HibernateCallback<List<T>>()
    {
      // 实现HibernateCallback接口必须实现的方法
      public List<T> doInHibernate(Session session)
      {
        // 执行Hibernate分页查询
        Query query = session.createQuery(hql);
        // 为包含占位符的HQL语句设置参数
        for(int i = 0,len = params.length ; i < len ; i++)
        {
          query.setParameter(i + "",params[i]);
        }
        List<T> result = query.setFirstResult((pageNo - 1) * pageSize)
          .setMaxResults(pageSize)
          .list();
        return result;
      }
    });
    return list;
  }
}

BaseDaoHibernate4.java

package org.crazyit.common.dao.impl;
import org.hibernate.*;
import java.util.List;
import java.io.Serializable;
import org.crazyit.common.dao.*;
public class BaseDaoHibernate4<T> implements BaseDao<T>
{
  // DAO组件进行持久化操作底层依赖的SessionFactory组件
  private SessionFactory sessionFactory;
  // 依赖注入SessionFactory所需的setter方法
  public void setSessionFactory(SessionFactory sessionFactory)
  {
    this.sessionFactory = sessionFactory;
  }
  public SessionFactory getSessionFactory()
  {
    return this.sessionFactory;
  }
  // 根据ID加载实体
  @SuppressWarnings("unchecked")
  public T get(Class<T> entityClazz,Serializable id)
  {
    return (T)getSessionFactory().getCurrentSession()
      .get(entityClazz,id);
  }
  // 保存实体
  public Serializable save(T entity)
  {
    return getSessionFactory().getCurrentSession()
      .save(entity);
  }
  // 更新实体
  public void update(T entity)
  {
    getSessionFactory().getCurrentSession().saveOrUpdate(entity);
  }
  // 删除实体
  public void delete(T entity)
  {
    getSessionFactory().getCurrentSession().delete(entity);
  }
  // 根据ID删除实体
  public void delete(Class<T> entityClazz,Serializable id)
  {
    getSessionFactory().getCurrentSession()
      .createQuery("delete " + entityClazz.getSimpleName()
        + " en where en.id = ?0")
      .setParameter("0",id)
      .executeUpdate();
  }
  // 获取所有实体
  public List<T> findAll(Class<T> entityClazz)
  {
    return find("select en from "
      + entityClazz.getSimpleName() + " en");
  }
  // 获取实体总数
  public long findCount(Class<T> entityClazz)
  {
    List<?> l = find("select count(*) from "
      + entityClazz.getSimpleName());
    // 返回查询得到的实体总数
    if (l != null && l.size() == 1 )
    {
      return (Long)l.get(0);
    }
    return 0;
  }
  // 根据HQL语句查询实体
  @SuppressWarnings("unchecked")
  protected List<T> find(String hql)
  {
    return (List<T>)getSessionFactory().getCurrentSession()
      .createQuery(hql)
      .list();
  }
  // 根据带占位符参数HQL语句查询实体
  @SuppressWarnings("unchecked")
  protected List<T> find(String hql,Object... params)
  {
    // 创建查询
    Query query = getSessionFactory().getCurrentSession()
      .createQuery(hql);
    // 为包含占位符的HQL语句设置参数
    for(int i = 0,len = params.length ; i < len ; i++)
    {
      query.setParameter(i + "",params[i]);
    }
    return (List<T>)query.list();
  }
  /**
   * 使用hql 语句进行分页查询操作
   * @param hql 需要查询的hql语句
   * @param pageNo 查询第pageNo页的记录
   * @param pageSize 每页需要显示的记录数
   * @return 当前页的所有记录
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(String hql,int pageNo,int pageSize)
  {
    // 创建查询
    return getSessionFactory().getCurrentSession()
      .createQuery(hql)
      // 执行分页
      .setFirstResult((pageNo - 1) * pageSize)
      .setMaxResults(pageSize)
      .list();
  }
  /**
   * 使用hql 语句进行分页查询操作
   * @param hql 需要查询的hql语句
   * @param params 如果hql带占位符参数,params用于传入占位符参数
   * @param pageNo 查询第pageNo页的记录
   * @param pageSize 每页需要显示的记录数
   * @return 当前页的所有记录
   */
  @SuppressWarnings("unchecked")
  protected List<T> findByPage(String hql,int pageSize,params[i]);
    }
    // 执行分页,并返回查询结果
    return query.setFirstResult((pageNo - 1) * pageSize)
      .setMaxResults(pageSize)
      .list();
  }
}

BookDao.java

package org.crazyit.booksys.dao;
import java.util.List;
import org.crazyit.booksys.domain.Book;
import org.crazyit.common.dao.BaseDao;
public interface BookDao extends BaseDao<Book>
{
}

BookDaoHibernate4.java

package org.crazyit.booksys.dao.impl;
import java.util.List;
import org.crazyit.booksys.dao.BookDao;
import org.crazyit.booksys.domain.Book;
import org.crazyit.common.dao.impl.BaseDaoHibernate3;
import org.crazyit.common.dao.impl.BaseDaoHibernate4;
public class BookDaoHibernate4 extends BaseDaoHibernate4<Book>
  implements BookDao
{
}

九 测试

Spring和Hibernate的整合操作示例

Spring和Hibernate的整合操作示例

更多关于java相关内容感兴趣的读者可查看本站专题:《Spring框架入门与进阶教程》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本文从从Bitcask存储模型讲起,谈轻量级KV系统设计与实现。从来没有最好的K-V系统,只有最适合应用业务实际场景的系统,做任何的方案选择,要结合业务当前的实际情况综合权衡,有所取有所舍。
内部的放到gitlab pages的博客,需要统计PV,不蒜子不能准确统计,原因在于gitlab的host设置了strict-origin-when-cross-origin, 导致不蒜子不能正确获取referer,从而PV只能统计到网站的PV。 为了方便统计页面的PV,这里简单的写了一个java程
PCM 自然界中的声音非常复杂,波形极其复杂,通常我们采用的是脉冲代码调制编码,即PCM编码。PCM通过抽样、量化、编码三个步骤将连续变化的模拟信号转换为数字编码。 采样率 采样频率,也称为采样速度或者采样率,定义了每秒从连续信号中提取并组成离散信号的采样个数,它用赫兹(Hz)来表示。采样频率的倒数
本文介绍如何离线生成sst并在线加载,提供一种用rocksdb建立分布式kv系统替换mongodb的思路
验证用户输入是否正确是我们应用程序中的常见功能。Spring提供了`@Valid`和@`Validated`两个注解来实现验证功能,本文详细介绍 [@Valid]和[@Validated]注解的区别 。
引入pdf2dom &lt;dependency&gt; &lt;groupId&gt;net.sf.cssbox&lt;/groupId&gt; &lt;artifactId&gt;pdf2dom&lt;/artifactId&gt; &lt;version&gt;1.8&lt;/version&
grafana 是一款非常优秀的可视化报表工具,有设计精良的可视化工具,今天来聊一聊如何将grafana集成到自己的应用中。 原理是: grafana允许iframe访问,开启auth.proxy, java 后端鉴权后代理grafana 前端通过iframe访问后端代理过的grafana graf
介绍 Call Graph是一款IDEA插件,用于可视化基于IntelliJ平台的IDE的函数调用图。 这个插件的目标是让代码更容易理解,有助于读懂和调试代码。当前只支持Java。针对Typescript、Javascript或Python工具,可以使用作者的另外一款工具Codemap(https:
原理 通过线程安全findAndModify 实现锁 实现 定义锁存储对象: /** * mongodb 分布式锁 */ @Data @NoArgsConstructor @AllArgsConstructor @Document(collection = &quot;distributed-loc
Singleton 单例模式 单例模式是确保每个应用程序只存在一个实例的机制。默认情况下,Spring将所有bean创建为单例。 你用@Autowired获取的bean,全局唯一。 @RestController public class LibraryController { @Autowired
pipeline 分布式任务调度器 目标: 基于docker的布式任务调度器, 比quartzs,xxl-job 更强大的分布式任务调度器。 可以将要执行的任务打包为docker镜像,或者选择已有镜像,自定义脚本程序,通过pipeline框架来实现调度。 开源地址: https://github.c
python训练的模型,转换为onnx模型后,用python代码可以方便进行推理,但是java代码如何实现呢? 首先ONNX 推理,可以使用`onnxruntime` ```xml com.microsoft.onnxruntime onnxruntime 1.15.1 ``` 另外,训练的模型需要
要获取内网地址,可以尝试连接到10.255.255.255:1。如果连接成功,获取本地套接字的地址信息就是当前的内网IP。 python实现: ```python import socket def extract_ip(): st = socket.socket(socket.AF_INET, s
为什么要有索引 gremlin 其实是一个逐级过滤的运行机制,比如下面的一个简单的gremlin查询语句: g.V().hasLabel(&quot;label&quot;).has(&quot;prop&quot;,&quot;value&quot;) 运行原理就是: 找出所有的顶点V 然后过滤出
最近在分析一个应用中的某个接口的耗时情况时,发现一个看起来极其普通的对象创建操作,竟然每次需要消耗 8ms 左右时间,分析后发现这个对象可以通过对象池模式进行优化,优化后此步耗时仅有 0.01ms。
点赞再看,动力无限。Hello world : ) 微信搜「 程序猿阿朗 」。 本文 Github.com/niumoo/JavaNotes 和 未读代码网站 已经收录,有很多知识点和系列文章。 此篇文章介绍 Java JMX 技术的相关概念和具体的使用方式。 当前文章属于Java 性能分析优化系列
如何将Java JAR 转化为 win/mac/linux 独立可执行程序?不需要预装 JRE 运行?
点赞再看,动力无限。 微信搜「 程序猿阿朗 」。 本文 Github.com/niumoo/JavaNotes 和 未读代码博客 已经收录,有很多知识点和系列文章。 Java 19 在2022 年 9 月 20 日正式发布,Java 19 不是一个长期支持版本,直到 2023 年 3 月它将被 JD
点赞再看,动力无限。Hello world : ) 微信搜「 程序猿阿朗 」。 本文 Github.com/niumoo/JavaNotes 和 未读代码博客 已经收录,有很多知识点和系列文章。 前言 Java 反编译,一听可能觉得高深莫测,其实反编译并不是什么特别高级的操作,Java 对于 Cla
JSON 对于开发者并不陌生,如今的 WEB 服务、移动应用、甚至物联网大多都是以 **JSON** 作为数据交换的格式。学习 JSON 格式的操作工具对开发者来说是必不可少的。这篇文章将介绍如何使用 **Jackson** 开源工具库对 JSON 进行常见操作。