您的位置:首页 > 编程语言 > Java开发

java中的private static变量的小心得

2015-11-07 21:12 423 查看
package zz;

public class zz {

private static String z="12321";

public void set(String zz)

{

z=zz;//static修饰的变量不能用this.z=zz;因为它是类变量。不用static修饰的变量可以this,XX=xx;

}

public void get()

{

System.out.println(z);

}

}

package zz;

public class zzz {

public static void main(String[] args) {

// TODO Auto-generated method stub

zz z1= new zz();

z1.set("123");

z1.get();

zz z2= new zz();

z2.set("456");

z1.get();

z2.get();

}

}

123

456

456

这种方法在数据库连接类中可以使用,private static 声明变量,一次赋值就可以不用再改变。

package com.wgh.tools;

import java.io.InputStream; //导入java.io.InputStream类

import java.sql.*; //导入java.sql包中的所有类

import java.util.Properties; //导入java.util.Properties类

public class ConnDB {

public Connection conn = null; // 声明Connection对象的实例

public Statement stmt = null; // 声明Statement对象的实例

public ResultSet rs = null; // 声明ResultSet对象的实例

private static String propFileName = "connDB.properties"; // 指定资源文件保存的位置

private static Properties prop = new Properties(); // 创建并实例化Properties对象的实例

private static String dbClassName = null; // 定义保存数据库驱动的变量

private static String dbUrl = null;

public ConnDB() { // 构造方法

try { // 捕捉异常

// 将Properties文件读取到InputStream对象中

InputStream in = getClass().getResourceAsStream(propFileName);

prop.load(in); // 通过输入流对象加载Properties文件

dbClassName = prop.getProperty("DB_CLASS_NAME"); // 获取数据库驱动

// 获取连接的URL

dbUrl = prop.getProperty("DB_URL");

} catch (Exception e) {

e.printStackTrace(); // 输出异常信息

}

}

/**

* 功能:获取连接的语句

*

* @return

*/

public static Connection getConnection() {

Connection conn = null;

try { // 连接数据库时可能发生异常因此需要捕捉该异常

Class.forName(dbClassName).newInstance(); // 装载数据库驱动

conn = DriverManager.getConnection(dbUrl); // 建立与数据库URL中定义的数据库的连接

} catch (Exception ee) {

ee.printStackTrace(); // 输出异常信息

}

if (conn == null) {

System.err

.println("警告: DbConnectionManager.getConnection() 获得数据库链接失败.\r\n\r\n链接类型:"

+ dbClassName + "\r\n链接位置:" + dbUrl); // 在控制台上输出提示信息

}

return conn; // 返回数据库连接对象

}

/*

* 功能:执行查询语句

*/

public ResultSet executeQuery(String sql) {

try { // 捕捉异常

conn = getConnection(); // 调用getConnection()方法构造Connection对象的一个实例conn

stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,

ResultSet.CONCUR_READ_ONLY);

rs = stmt.executeQuery(sql);

} catch (SQLException ex) {

System.err.println(ex.getMessage()); // 输出异常信息

}

return rs; // 返回结果集对象

}

/*

* 功能:执行更新操作

*/

public int executeUpdate(String sql) {

int result = 0; // 定义保存返回值的变量

try { // 捕捉异常

conn = getConnection(); // 调用getConnection()方法构造Connection对象的一个实例conn

stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,

ResultSet.CONCUR_READ_ONLY);

result = stmt.executeUpdate(sql); // 执行更新操作

} catch (SQLException ex) {

result = 0; // 将保存返回值的变量赋值为0

}

return result; // 返回保存返回值的变量

}

/*

* 功能:关闭数据库的连接

*/

public void close() {

try { // 捕捉异常

if (rs != null) { // 当ResultSet对象的实例rs不为空时

rs.close(); // 关闭ResultSet对象

}

if (stmt != null) { // 当Statement对象的实例stmt不为空时

stmt.close(); // 关闭Statement对象

}

if (conn != null) { // 当Connection对象的实例conn不为空时

conn.close(); // 关闭Connection对象

}

} catch (Exception e) {

e.printStackTrace(System.err); // 输出异常信息

}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: