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); // 输出异常信息
}
}
}
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); // 输出异常信息
}
}
}
相关文章推荐
- Java重点基础巩固
- java中判断一个字符串是否“都为数字”和“是否包含数字”和“截取数字”
- java保留两位小数
- Jugiven-To-JAVA-01:toUpperCase(locale)的理解
- java反射机制模式
- JAVA继承与接口课后作业
- 【深入Java虚拟机】之四:类加载机制
- Java常用类库
- java提取字符串中的汉字
- Java多线程总结
- Java性能优化技巧及实战
- 推荐给大家一个十分实用的java日历控件
- java web 学习网址
- (转)java判断string变量是否是数字的六种方法小结
- java连接mongod抛java.net.SocketTimeoutException: connect timed out异常(2015-11-07 20:29:58)
- 不借用临时变量交换两个整数的值
- Java多线程的实现方法
- xml文件在JAVA读取过程中的解析
- Java根据模板创建excel文件
- myeclipse10.7安装git插件