在学习JDBC的时候,项目开发的过程中,总会遇到对数据库表数据增删改查的操作,而很多基本的JDBC代码都会出现大量的重复编写,不仅对DAO的编写造成了繁琐,也对以后的维护增加了困难。当然,很多开源的框架可以解决这些问题,比如Mybatis,Hibernate等这些好的框架可以很好的实现相应的效果,但处在学习基础的过程中,这些框架不建议使用,那么最好的方法就是可以封装原来重复的代码,这样的话,一个可以适用学习的过程,其次也可以提高对Java基础的掌握程度,再而可以通过自己的封装适用最基本的项目开发,而且很容易,很方便的进行自己的项目维护开发。

    注:本博文所使用的代码可以通过以下链接进行获取http://download.csdn.net/detail/songdeitao/6753631

    下面就来看看最基本的JDBC轻量型封装项目的实例。

    首先来看一下最终的效果。

    比如仅仅对数据库中数据增加的DAO操作,代码需要这样写:

    UserDao中实现User数据的新增操作

public boolean doCreate(User user) {// 创建标志位boolean flag = false;// 创建sql语句String sql = "insert into t_user values(?,?,?,?,?)";// 填充参数(主键不需要填写,自增)Object[] parameters = new Object[] { null, user.getUserName(),user.getAge(), user.getBirthday(), user.getIsVip() };flag = DaoHandle.executeDML(sql, parameters) > 0 ? true : false;return flag;}
    首先创建sql语句,这里的sql语句需要通过预处理的方式进行操作,通过占位符填写相应的参数,然后将需要的参数(和占位符个数相同)创建成Object对象数组,数组中包含将要对占位符操作的数据,而轻量型封装的DaoHandle这个类,就主要负责了对数据库数据增删改查的操作。

    调用的测试代码这样编写:

/*** 测试增加一条记录到数据库中*/public static void addUser() {// 创建对象User user = new User("steven", 23, new Date(), true);// 创建一条记录boolean flag = userDao.doCreate(user);// 是否成功创建记录System.out.println(flag);}
    这个时候就可以在数据库表中新增一条数据。


    下面就来进行主要代码的实现过程编写:

    本项目中主要采用MyEclipse8.5+Mysql5.0开发环境来实现开发。首先给出项目的结构图,如图1所示:


图1

    在这个图中,可以看到,这是一个最基本的项目搭建结构,而在这个过程中本文主要对dao进行封装,而所使用的轻量型封装的代码主要是DaoHandle这个类,所以以后的功能扩展,代码可靠性的提高,主要就是对此类进行修改。这里就按照项目搭建的过程一步步讲解。

    首先创建数据库,而用到的数据库代码都在mysql.sql文件,

mysql.sql

--创建数据库steven
create database steven;
--应用数据库
use steven;
--创建表
create table t_user(userId	    int(10)	 not null primary key auto_increment,userName    varchar(100) not null,age	        int(2),birthday    datetime,isVip       boolean
);
--显示表结构
desc t_user;
--显示表中数据
select * from t_user;
--提交
commit;
    这个时候可以将这些代码如图2所示进行执行:


                        图2

这个时候数据库已经创建成功。

    注:小技巧,在windows的命令提示符中如果想如上图所示改变字体和背景的颜色,可以通过color f4这个命令来实现,不清楚的可以动手试试。后面的f4分别指代的是背景和字体的颜色。

    然后给出User实体的java代码:

User.java

package com.steven.entity;import java.util.Date;/*** 实体类* * @author Steven* */
public class User {// 用户Idprivate int userId;// 用户名private String userName;// 用户年龄private int age;// 用户生日private Date birthday;// 用户是否是会员 true:是 false:不是private boolean isVip;public User() {}// 有参构造public User(String userName, int age, Date birthday, boolean isVip) {this.userName = userName;this.age = age;this.birthday = birthday;this.isVip = isVip;}public int getUserId() {return userId;}public void setUserId(int userId) {this.userId = userId;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public boolean getIsVip() {return isVip;}public void setIsVip(boolean isVip) {this.isVip = isVip;}@Overridepublic String toString() {return "用户信息: [年龄是" + this.getAge() + ", 生日是" + this.getBirthday()+ ", 用户编号是" + this.getUserId() + ", 用户名是" + userName+ isVip(this.getIsVip()) + "]";}public String isVip(boolean isVip) {return ", " + (isVip == true ? "是" : "不是") + "会员";}}
      这个时候给出数据库资源文件的代码,这个资源文件的获取有很多种方式,感兴趣的可以参照(http://blog.csdn.net/songdeitao/article/details/17447627)这篇博文进行学习。

jdbc.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/steven
user=root
password=mysqladmin
        连接Mysql数据库的代码,这里的连接驱动的jar包已经附属到项目中,

DatabaseConnection.java

package com.steven.dbc;import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;/*** 进行数据库连接的操作* * @author Steven* */
public class DatabaseConnection {public static String driver;// 驱动public static String url;// urlpublic static String user;// 用户名public static String password;// 密码public DatabaseConnection() {}static {File file = new File("src/jdbc.properties");Properties pro = new Properties();try {FileInputStream in = new FileInputStream(file);pro.load(in);// 读取属性配置文件driver = pro.getProperty("driver");url = pro.getProperty("url");user = pro.getProperty("user");password = pro.getProperty("password");} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}}/*** 获取数据库连接* * @return*/public static Connection getConnection() {Connection conn = null;try {Class.forName(driver);conn = DriverManager.getConnection(url, user, password);} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}return conn;}/*** 关闭数据库对象* * @param con* @param stmt* @param rs*/public static void closeAll(Connection con, Statement stmt, ResultSet rs) {if (rs != null) {try {rs.close();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}rs = null;}if (stmt != null) {try {stmt.close();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}stmt = null;}if (con != null) {try {con.close();} catch (SQLException e) {// TODO Auto-generated catch blocke.printStackTrace();}con = null;}}/*** 测试数据库连接* * @param args*/public static void main(String[] args) {Connection conn = DatabaseConnection.getConnection();System.out.println(conn);}
}
    注:一般情况下如果写完了连接数据库的代码,都要进行一次测试,如果成功可以进行接下来的编码,如果失败了,就要进行错误纠正,这样可以保证以后的代码编写不会因为之前的错误而影响到,也减少了更改bug的难度。这种递进式的代码开发,是常用的开发模式。尤其在大的项目中,一定要对自己的每一个模块可以进行测试,确保项目的正确性。
测试结果:

com.mysql.jdbc.JDBC4Connection@f11404
获取了连接对象,是正确的。 
下面将给出博文的核心,也是轻量型JDBC代码的封装的具体实现,DaoHandle类的具体实现如下所示:

DaoHandle.java

package com.steven.util;import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;import com.steven.dbc.DatabaseConnection;/*** DAO数据操作的辅助类* * @author Steven* */
public class DaoHandle {private static Connection con;private static PreparedStatement pstmt;private static ResultSet rs;/*** 执行所有的DML操作* * @param sql* @param parameters* @return*/public static int executeDML(String sql, Object[] parameters) {int count = -1;// 获取连接con = DatabaseConnection.getConnection();if (con != null) {try {// 获取处理器对象pstmt = con.prepareStatement(sql);// 注入参数for (int i = 0; i < parameters.length; i++) {// 根据参数的类型判断调用注入方法// 参数类型不安全pstmt.setObject(i + 1, parameters[i]);}// 执行SQL语句count = pstmt.executeUpdate();} catch (SQLException e) {e.printStackTrace();} finally {DatabaseConnection.closeAll(con, pstmt, null);}}return count;}/*** 查询获取单个对象* * @param <T>* @param sql* @param paramters* @param objClass* @return*/public static <T> T executeQueryForSingle(String sql, Object[] parameters,Class<T> objClass) {T t = null;// 获取连接con = DatabaseConnection.getConnection();if (con != null) {try {// 获取处理器pstmt = con.prepareStatement(sql);// 注入参数if (parameters != null) {for (int i = 0; i < parameters.length; i++) {pstmt.setObject(i + 1, parameters[i]);}}// 执行查询rs = pstmt.executeQuery();// 获取结果集的元数据ResultSetMetaData metaData = rs.getMetaData();// 获取所有列名String[] colNames = getColNames(metaData);// 获取所有列的数据类型// int[] colTypes = getColTypes(metaData);// 使用反射获取当前类的方法Method[] methods = objClass.getDeclaredMethods();// 获取结果集的数据while (rs.next()) {// 获取类的实例t = objClass.newInstance();// 循环判断每列的数据类型for (int i = 0; i < colNames.length; i++) {// 获取每列的结果Object value = null;// 进行所有参数类型的赋值,不能保证类型安全value = rs.getObject(i + 1);// 遍历每个方法for (Method m : methods) {if (value != null) {// 如果是和该列同名的set方法,则调用该方法if (m.getName().equalsIgnoreCase("set" + colNames[i])) {// 进行对set方法的调用,向其中置值m.invoke(t, value);}}}}}} catch (SecurityException e) {e.printStackTrace();} catch (IllegalArgumentException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();} catch (InvocationTargetException e) {// TODO Auto-generated catch blocke.printStackTrace();} finally {DatabaseConnection.closeAll(con, pstmt, rs);}}// 返回对象return t;}/*** 通过元数据获取列名数组* * @param metaData* @return*/private static String[] getColNames(ResultSetMetaData metaData) {String[] colNames = null;try {// 获取结果集的列数int colCount = metaData.getColumnCount();// 创建数组colNames = new String[metaData.getColumnCount()];// 遍历每列for (int i = 1; i <= colCount; i++) {// 获取列名colNames[i - 1] = metaData.getColumnLabel(i);}} catch (SQLException e) {e.printStackTrace();}return colNames;}/*** 根据元数据获取所有列的数据类型* * @param metaData* @return*/private static int[] getColTypes(ResultSetMetaData metaData) {int[] colNames = null;try {// 获取列数int colCount = metaData.getColumnCount();// 创建数组colNames = new int[colCount];for (int i = 1; i <= colCount; i++) {// colNames[i-1] = metaData.getColumnTypeName(i);colNames[i - 1] = metaData.getColumnType(i);}} catch (SQLException e) {e.printStackTrace();}return colNames;}/*** 查询多行对象* * @param <T>* @param sql* @param paramters* @param objClass* @return*/public static <T> List<T> executeQueryForMultiple(String sql,Object[] parameters, Class<T> objClass) {List<T> list = new ArrayList<T>();// 获取连接con = DatabaseConnection.getConnection();if (con != null) {try {// 获取处理器pstmt = con.prepareStatement(sql);if (parameters != null) {// 注入参数for (int i = 0; i < parameters.length; i++) {pstmt.setObject(i + 1, parameters[i]);}}// 执行查询rs = pstmt.executeQuery();// 获取结果集的元数据ResultSetMetaData metaData = rs.getMetaData();// 获取所有列名String[] colNames = getColNames(metaData);// 获取所有列的数据类型// int[] colTypes = getColTypes(metaData);// 使用反射获取当前类的方法Method[] methods = objClass.getDeclaredMethods();// 获取结果集的数据while (rs.next()) {T t = null;// 获取类的实例t = objClass.newInstance();// 循环判断每列的数据类型for (int i = 0; i < colNames.length; i++) {// 获取每列的结果Object value = null;// 进行所有参数类型的赋值,不能保证类型安全value = rs.getObject(i + 1);// 遍历每个方法for (Method m : methods) {if (value != null) {// 如果是和该列同名的set方法,则调用该方法if (m.getName().equalsIgnoreCase("set" + colNames[i])) {// 进行对set方法的调用,向其中置值m.invoke(t, value);}}}}// 向集合中添加数据list.add(t);}} catch (SecurityException e) {e.printStackTrace();} catch (IllegalArgumentException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();} catch (InvocationTargetException e) {e.printStackTrace();} finally {DatabaseConnection.closeAll(con, pstmt, rs);}}// 返回集合return list;}/*** 返回数据表中数据的条数* * @param sql* @param paramters* @return*/public static int executeQueryForCount(String sql, Object[] parameters) {int count = 0;// 获取连接con = DatabaseConnection.getConnection();try {// 获取处理器pstmt = con.prepareStatement(sql);if (parameters != null) {// 注入参数for (int i = 0; i < parameters.length; i++) {pstmt.setObject(i + 1, parameters[i]);}}// 执行查询rs = pstmt.executeQuery();// 遍历查找的结果集while (rs.next()) {count = rs.getInt(1);}} catch (SQLException e) {e.printStackTrace();} finally {DatabaseConnection.closeAll(con, pstmt, rs);}return count;}
}

   注:这个过程中用到了反射机制,也是java底层代码实现的最基本应用,功能很强大,通过相应的方法,可以进行动态的方法调用,实现数据库表元素和对象之间的互相映射。其实在数据库框架中,也大量使用这反射机制。

然后给出Dao层中,iface和impl的实现代码:

IBaseDao.java

package com.steven.dao.iface;import java.util.List;/*** 通过泛型机制为所有的实现类提供一下方法* * @author Steven* */
public interface IBaseDao<T> {/*** 新增一条数据* * @param t* @return*/public boolean doCreate(T t);/*** 根据编号(主键)进行删除一条数据* * @param id* @return*/public boolean delete(int id);/*** 修改数据* * @param t* @return*/public boolean update(T t);/*** 根据ID查找到该信息* * @param id* @return*/public T findById(int id);/*** 返回所有的信息* @return*/public List<T> findAll();
}
IUserDao.java

package com.steven.dao.iface;import com.steven.entity.User;public interface IUserDao extends IBaseDao<User> {}
UserDao.java

package com.steven.dao.impl;import java.util.List;import com.steven.dao.iface.IUserDao;
import com.steven.entity.User;
import com.steven.util.DaoHandle;public class UserDao implements IUserDao {@Overridepublic boolean delete(int id) {// 创建标志位boolean flag = false;// 创建sql语句String sql = "delete from t_user where userId=?";// 填充参数Object[] parameters = new Object[] { id };// 执行数据库数据删除操作flag = DaoHandle.executeDML(sql, parameters) > 0 ? true : false;return flag;}@Overridepublic boolean doCreate(User user) {// 创建标志位boolean flag = false;// 创建sql语句String sql = "insert into t_user values(?,?,?,?,?)";// 填充参数(主键不需要填写,自增)Object[] parameters = new Object[] { null, user.getUserName(),user.getAge(), user.getBirthday(), user.getIsVip() };flag = DaoHandle.executeDML(sql, parameters) > 0 ? true : false;return flag;}@Overridepublic List<User> findAll() {// 创建sql语句String sql = "select * from t_user";// 查询所有的记录List<User> list = (List<User>) DaoHandle.executeQueryForMultiple(sql,null, User.class);return list;}@Overridepublic User findById(int id) {// 创建sql语句String sql = "select * from t_user where userId = ?";// 填充参数Object[] parameters = new Object[] { id };// 查找单个记录User user = DaoHandle.executeQueryForSingle(sql, parameters, User.class);return user;}@Overridepublic boolean update(User user) {// 创建标志位boolean flag = false;// 创建sql语句String sql = "update t_user set userName=?,age=?,birthday=?,isVip=? where userId=?";// 注入参数Object[] parameters = new Object[] { user.getUserName(), user.getAge(),user.getBirthday(), user.getIsVip(), user.getUserId() };flag = DaoHandle.executeDML(sql, parameters) > 0 ? true : false;return flag;}
}
接下来将给出UserDao的测试代码,也是对轻量型封装的DaoHandle的检验,

CRUDTest.java

package com.steven.test;import java.util.Date;
import java.util.List;import com.steven.dao.impl.UserDao;
import com.steven.entity.User;public class CRUDTest {private static UserDao userDao = new UserDao();/*** @param args*/public static void main(String[] args) {// addUser();// retrieveUser();// deleteUser();// updateUser();// retrieveAll();}/*** 测试增加一条记录到数据库中*/public static void addUser() {// 创建对象User user = new User("steven", 23, new Date(), true);// 创建一条记录boolean flag = userDao.doCreate(user);// 是否成功创建记录System.out.println(flag);}/*** 测试从数据库中读取一条记录*/public static void retrieveUser() {// 从数据库中读取一条记录User user = userDao.findById(1);// 将此记录的相应对象输出System.out.println(user);}/*** 从数据库表中删除一条数据*/public static void deleteUser() {// 首先从数据库中查找出一条记录User user = userDao.findById(1);// 然后根据查找后的对象id从数据库中删除此记录boolean flag = false;if (user != null) {flag = userDao.delete(user.getUserId());}// 输出删除的成功与否System.out.println(flag);}/*** 更新数据操作*/public static void updateUser() {// 从数据表中读取一条数据User user = userDao.findById(2);// 更改数据user.setIsVip(false);// 执行更新操作boolean flag = userDao.update(user);// 成功与否System.out.println(flag);}public static void retrieveAll() {// 获取所有记录的集合List<User> userList = userDao.findAll();// 输出所有对象信息for (User user : userList) {System.out.println(user);}}
}

然后给出测试的结果,这里仅仅给出前两个测试效果,所有的测试都是正确的,可以自己动手试试。

addUser()

控制台输出

true
数据库中的结果如图3所示:


图3

retrieveUser();

控制台输出:

用户信息: [年龄是23, 生日是2013-12-22 16:10:25.0, 用户编号是1, 用户名是steven, 是会员]

    到这里,轻量型的JDBC封装的实现和测试已经全部给出,下面就开始编写JavaSE的具体项目逻辑了,这时候可以在建一个包com.steven.business层(可以为其他的层次)进行业务逻辑的操作,这样一个简答的使用封装后的JDBC项目就可以实现了,当然这也可以用到web项目中,具体的项目编写,还是大家实现吧,这个封装仅仅是简单的实现,如果有需要扩展的,比如分页查找,搜索字段,都是可以实现的。

    在此恭祝大家学习愉快!


查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. 系统学习C语言

    大学四年学过C++(主修课程),学过java、android(自学),再回顾一下,感觉都学得不好,有很多东西都是借鉴网上的,说白了就是抄别人的博客,自己的独创性的东西真的很少。深感自身实践能力弱,独立解决问题的能力不强。究其原因,首先是长期实践不足,然后就是没有系统的学…...

    2024/4/21 9:26:05
  2. 十本Java网站开发必看书籍

    1:《java并发编程从入门到精通》推荐理由:从入门讲到精通的,网络安全,网络并发的好书。《Java并发编程从入门到精通》作者结合自己10多年Java并发编程经验,详细介绍了Java并发编程的基础概念、工作原理、编程技巧和注意事项,对Java高性能高并发编程有极大的参考价值。《J…...

    2024/4/21 9:26:06
  3. 记录一下Base64 在线编码解码

    现在很多地方都涉及到解码,以及编码,https://base64.us/ 如有需要请mark一下这个在线编码解码网站...

    2024/4/21 9:26:03
  4. c,c++小白到大神系列教程之一:C语言入门-王健伟-专题视频课程

    c,c++小白到大神系列教程之一:C语言入门—1127人已学习 课程介绍 本课程针对 有一点计算机基础比如知道二进制、八进制、十六进制数据的含义,对内存、堆、栈等有基本概念的计算机初学者,全面介绍C语言精华内容以及利用C语言进行程序设计的方法,您不需要有任何程序设…...

    2024/4/21 9:26:03
  5. 一个实际项目Java架构设计之总体设计

    1 总体架构模块图1.1 抽象架构模块图1.2 具体技术架构模块图如上图示所,框架主要包括了:l MVC开发框架l 工作流技术l 用户、权限、角色管理下面分别详细介绍。2 MVC方案2.1 视图层技术方案(view)在常用开发框架的应用中,常用于视图层的有:Jsp ,Jsf,F…...

    2024/4/21 9:26:01
  6. 将整数转换成字符串,在C51中你如何做?

    这个问题似乎很简单,keilC中也用sprintf()函数嘛,用就行了。但对于“寸土寸金”的单片机来说,问题可没那么简单。 看看我代码中这句弃之不用的代码吧: //sprintf(sFileLen,"%d",fileLen*128);print(sFileLen); //使用这个库函数,体积一下增加2563. 我的程序空间…...

    2024/4/19 19:22:58
  7. C语言程序设计实验教程 李丽娟pdf

    链接:https://pan.baidu.com/s/1NLxNh2gt4cGQi3bKiForrQ 密码:yr5f本书为完整版,以下为内容截图:...

    2024/4/20 18:11:47
  8. 【原】个人java项目经验总结

    写在前面的话 -“虽然我之前没做过xxx,不过用xxx应该很简单。” -“没做过就别说很简单!”目录一、运算符,基本类型和四则运算 1.1 负数的余数,如何优雅地避免数组下标越界 1.2 你确定你的if判断式里是==而不是=? 二、类,接口的设计 2.1 参数列表的设计 2.2 类的分类 2.3…...

    2024/4/20 18:11:46
  9. visual studio 2012进行C语言开发[图文]

    现在大家计算机大概都脱离XP了,so,之前蛮多可以用的编译器,可能放在我们现在的Win7,win8下面会出现一些比如不兼容了之类的问题。其实,用微软强大的IDE-visual studio系列,也是可以进行C语言的开发的。因为本人的本本目前是win8版本的系统,也安装了较为新版的visual stu…...

    2024/4/20 18:11:45
  10. Java实训项目:GUI学生信息管理系统(2017)

    Java实训项目:GUI学生信息管理系统(2017)实训目的:让学生综合运用J2SE有关知识开发【学生信息管理系统】。主要涉及程序控制结构、面向对象编程、图形用户界面、Java数据库应用、MySQL数据库这几个方面的内容。通过本项目的开发,让学生了解系统开发的一般流程,初步了解MV…...

    2024/4/21 9:26:02
  11. libxml2编程--C语言xml初使用(1)

    1、下载与安装LIBXML2Libxml2是一个C语言的XML程序库,可以简单方便的提供对XML文档的各种操作,并且支持XPATH查询,以及部分的支持XSLT转换等功能。Libxml2的下载地址是http://xmlsoft.org/,完全版的库是开源的,并且带有例子程序和说明文档。最好将这个库先下载下来,因为这…...

    2024/4/25 16:26:48
  12. Java Web 开发实战经典 基础篇(1)

    第2章 HTML、JavaScript简介 本章主要内容: (1)掌握HTML的基本语法 (2)掌握HTML表单的编写操作 (3)掌握JavaScript的基本语法、主要事件、主要对象的使用 (4)可以使用JavaScript完成表单的交互程序的开发2.1 服务器与浏览器 用户通过Web浏览器发送一个基于HTTP协议的请…...

    2024/4/21 9:25:58
  13. C语言模块化开发(多文件编程)

    1.main.c是程序的主模块,module.c是程序的一个模块,main中使用extern int m来声明变量,定义在module中,说明module中定义的全局变量的作用域是整个程序。 2.假如要使用printf函数的话就添加头文件stdio.h,头文件里面都是函数的声明,定义在系统库中。 3.函数的声明有无ext…...

    2024/5/1 19:30:00
  14. 《Java Web开发实战》Java工程师必备干货教材

    一年一度毕业季,又到了简历、offer漫天飞,失望与希望并存的时节。在IT行业,高校毕业生求职时,面临的第一道门槛就是技能与经验的考验,但学校往往更注重学生的理论知识,忽略了对学生实践能力的培养,因而导致很多求职者在面试中败下阵来。在毕业生所学知识普遍脱离职场实战…...

    2024/4/21 9:25:58
  15. JAVA项目中发布WebService服务—简单实例

    1,在Java项目中发布一个WebService服务:如何发布? JDK1.6中JAX-WS规范定义了如何发布一个WebService服务: (1)用jdk1.6.0_21以后的版本发布; (2)与Web服务相关的类,都位于Javax.jws.*包中:@WebService——此注解用在类上指定将此类发布成一个WebService; EndPoint—…...

    2024/4/21 9:25:56
  16. C语言编程入门——HelloWorld!

    将我的C语言学习过程记录下来,供大家学习交流,适合C语言入门者学习,希望能对大家有帮助。推荐学习教程:《C语言程序设计》 作者:谭浩强推荐学习视频:C语言教程 作者:郝斌(链接)推荐编程工具:VC++6.0我在学完之后,记下了自己的学习心得,大家可在我的博客中查看(…...

    2024/4/21 9:25:54
  17. JAVA初学者推荐《Java开发实战经典》李兴华著

    推荐等级:★★★★★ 顶级推荐,java初学者入门最经典、最好的书籍之一,具体理由请往下阅读: 内容简介:《Java开发实战经典(名师讲坛)》是一本综合讲解Java核心技术的书籍,在书中使用大量的代码及案例进行知识点的分析与运用,并且给出一些比较成熟的开发步骤,帮助读者更…...

    2024/4/21 9:25:54
  18. C语言网 1002: C语言程序设计教程(第三版)课后习题1.6

    问题 1002: C语言程序设计教程(第三版)课后习题1.6时间限制: 1Sec 内存限制: 128MB 提交: 9997 解决: 4775题目描述编写一个程序,输入a、b、c三个值,输出其中最大值。输入一行数组,分别为a b c输出a b c其中最大的数样例输入10 20 30样例输出30代码如下:#include <std…...

    2024/4/20 14:42:40
  19. C语言中的多线程编程

    C语言中的多线程编程#include<stdio.h> #define NUM 6 int main() {void print_msg(char*);print_msg("hello,");print_msg("world!"); } void print_msg(char* m) {int i;for(i=0;i<NUM;i++){printf("%s",m);fflush(stdout);sleep(1);…...

    2024/4/21 9:25:53
  20. Java算法之递归打破和在真实项目中的使用实例

    开心一笑刚才领导问开发:“你觉得这个项目的最大风险是什么”,开发说:”加班猝死” , 气氛尴尬了一分钟!!!视频教程大家好,我录制的视频《Java之优雅编程之道》已经在CSDN学院发布了,有兴趣的同学可以购买观看,相信大家一定会收获到很多知识的。谢谢大家的支持……视频地…...

    2024/4/23 3:08:22

最新文章

  1. 面试:Spring(IOC、AOP、事务失效、循环引用、SpringMVC、SpringBoot的自动配置原理、Spring框架常见注解)

    目录 一、Spring的单例Bean是否是线程安全的&#xff1f; 二、什么是AOP 1、介绍 &#xff08;1&#xff09;记录操作日志 &#xff08;2&#xff09;实现Spring中的事务 三、spring中事务失效的场景有哪些&#xff1f; 1、异常捕获处理 2、抛出检查异常 3、非public方…...

    2024/5/2 11:26:30
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 如何转行成为产品经理?

    转行NPDP也是很合适的一条发展路径&#xff0c;之后从事新产品开发相关工作~ 一、什么是NPDP&#xff1f; NPDP 是产品经理国际资格认证&#xff0c;美国产品开发与管理协会&#xff08;PDMA&#xff09;发起的&#xff0c;是目前国际公认的唯一的新产品开发专业认证&#xff…...

    2024/5/1 13:02:24
  4. 前端 js 经典:字符编码详解

    前言&#xff1a;计算机只能识别二进制&#xff0c;开发语言中数据类型还有数字&#xff0c;字母&#xff0c;中文&#xff0c;特殊符号等&#xff0c;都需要转化成二进制编码才能让技术机识别。 一. 编码方式 ACSLL、Unicode、utf-8、URL 编码、base64 等。 1. ACSLL 对英语…...

    2024/5/2 2:42:44
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/4/30 18:14:14
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/2 9:28:15
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/4/25 18:39:16
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57