国产最新a级毛片无码专区_综合亚洲欧美日韩久久精品_日本成年片在线观看66_一本到九九av电影_一级毛片免费网站播放_国内精品久久人无码大片_国产人成视频99在线观看_欧美不卡在线一本二本_国产亚洲电影av_可以免费看黄色软件

知ing

Java2實用教程(第4版)

耿祥義、張躍平 / 清華大學出版社

頑張って! 上傳

查看本書

習題十一(第11章)

一、問答題

1.(1)添加數據源,(2)選擇驅動程序,(3)命名數據源名稱。

2.不必使用數據名稱。

3.減輕數據庫內部SQL語句解釋器的負擔。

4.事務由一組SQL語句組成,所謂事務處理是指:應用程序保證事務中的SQL語句要么全部都執(zhí)行,要么一個都不執(zhí)行。

5.(1)用setAutoCommit()方法關閉自動提交模式,(2)用commit()方法處理事務,(3)用rollback()方法處理事務失敗。

四、編程題

1.??import java.sql.*;

import java.util.*;

public class E {

???public static void main(String args[]) {

?????Query query=new Query();

?????String dataSource="myData";

?????String tableName="goods";

?????Scanner read=new Scanner(System.in);

?????System.out.print("輸入數據源名:");

?????dataSource = read.nextLine();

?????System.out.print("輸入表名:");

?????tableName = read.nextLine();

?????query.setDatasourceName(dataSource);

?????query.setTableName(tableName);

?????query.setSQL("SELECT * FROM "+tableName);

?????query.inputQueryResult();

???}

}

class Query {

???String datasourceName=""; ???????//數據源名

???String tableName=""; ???????????//表名

???String SQL; ???????????????????//SQL語句

???public Query() {

??????try{ ?Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

??????}

??????catch(ClassNotFoundException e) {

?????????System.out.print(e);

??????}

???}

???public void setDatasourceName(String s) {

??????datasourceName = s.trim();

???}

???public void setTableName(String s) {

??????tableName = s.trim();

???}

???public void setSQL(String SQL) {

??????this.SQL = SQL.trim();

???}

???public void inputQueryResult() {

??????Connection con;

??????Statement sql;

??????ResultSet rs;

??????try {

???????????String uri = "jdbc:odbc:"+datasourceName;

???????????String id = "";

???????????String password = "";

???????????con = DriverManager.getConnection(uri,id,password);

???????????DatabaseMetaData metadata = con.getMetaData();

???????????ResultSet rs1 = metadata.getColumns(null,null,tableName,null);

???????????int 字段個數 = 0;

???????????while(rs1.next()) {

??????????????字段個數++;

???????????}

???????????sql = con.createStatement();

???????????rs = sql.executeQuery(SQL);

???????????while(rs.next()) {

?????????????for(int k=1;k<=字段個數;k++) {

?????????????????System.out.print(" "+rs.getString(k)+" ");

?????????????}

?????????????System.out.println("");

???????????}

???????????con.close();

???????}

???????catch(SQLException e) {

???????????System.out.println("請輸入正確的表名"+e);

???????}

???} ???

}

2.???import java.sql.*;

import java.util.*;

public class E {

???public static void main(String args[]) {

?????Query query = new Query();

?????String dataSource = "myData";

?????String tableName = "goods";

?????query.setDatasourceName(dataSource);

?????query.setTableName(tableName);

?????String name = "";

?????Scanner read=new Scanner(System.in);

?????System.out.print("商品名:");

?????name = read.nextLine();

?????String str="'%["+name+"]%'";

?????String SQL = "SELECT * FROM "+tableName+" WHERE name LIKE "+str;

?????query.setSQL(SQL);

?????System.out.println(tableName+"表中商品名是"+name+"的記錄");

?????query.inputQueryResult();

???}

}

class Query {

???String datasourceName=""; ???????//數據源名

???String tableName=""; ???????????//表名

???String SQL; ???????????????????//SQL語句

???public Query() {

??????try{ ?Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

??????}

??????catch(ClassNotFoundException e) {

?????????System.out.print(e);

??????}

???}

???public void setDatasourceName(String s) {

??????datasourceName = s.trim();

???}

???public void setTableName(String s) {

??????tableName = s.trim();

???}

???public void setSQL(String SQL) {

??????this.SQL = SQL.trim();

???}

???public void inputQueryResult() {

??????Connection con;

??????Statement sql;

??????ResultSet rs;

??????try {

???????????String uri = "jdbc:odbc:"+datasourceName;

???????????String id = "";

???????????String password = "";

???????????con = DriverManager.getConnection(uri,id,password);

???????????DatabaseMetaData metadata = con.getMetaData();

???????????ResultSet rs1 = metadata.getColumns(null,null,tableName,null);

???????????int 字段個數 = 0;

???????????while(rs1.next()) {

??????????????字段個數++;

???????????}

???????????sql = con.createStatement();

???????????rs = sql.executeQuery(SQL);

???????????while(rs.next()) {

?????????????for(int k=1;k<=字段個數;k++) {

?????????????????System.out.print(" "+rs.getString(k)+" ");

?????????????}

?????????????System.out.println("");

???????????}

???????????con.close();

???????}

???????catch(SQLException e) {

???????????System.out.println("請輸入正確的表名"+e);

???????}

???} ???

}

3.將例子5中的代碼:

String SQL = "SELECT * FROM "+tableName+" ORDER BY name";

更改為

String SQL = "SELECT * FROM "+tableName+" ORDER BY madeTime";

可達題目要求。

習題十二(第12章)

一、問答題

14狀態(tài):新建、運行、中斷和死亡。

24種原因的中斷:(1JVMCPU資源從當前線程切換給其他線程,使本線程讓出CPU的使用權處于中斷狀態(tài)。(2)線程使用CPU資源期間,執(zhí)行了sleep(int millsecond)方法,使當前線程進入休眠狀態(tài)。(3)線程使用CPU資源期間,執(zhí)行了wait()方法,使得當前線程進入等待狀態(tài)。(4)線程使用CPU資源期間,執(zhí)行某個操作進入阻塞狀態(tài),比如執(zhí)行讀/寫操作引起阻塞。

3死亡狀態(tài),不能再調用start()方法。

4.新建和死亡狀態(tài)。

5兩種方法:用Thread類或其子類。

6.使用 setPrority(int grade)方法。

7Java使我們可以創(chuàng)建多個線程,在處理多線程問題時,我們必須注意這樣一個問題:當兩個或多個線程同時訪問同一個變量,并且一個線程需要修改這個變量。我們應對這樣的問題作出處理,否則可能發(fā)生混亂

8當一個線程使用的同步方法中用到某個變量,而此變量又需要其它線程修改后才能符合本線程的需要,那么可以在同步方法中使用wait()方法。使用wait方法可以中斷方法的執(zhí)行,使本線程等待,暫時讓出CPU的使用權,并允許其它線程使用這個同步方法。其它線程如果在使用這個同步方法時不需要等待,那么它使用完這個同步方法的同時,應當用notifyAll()方法通知所有的由于使用這個同步方法而處于等待的線程結束等待。

9.不合理。

10“吵醒”休眠的線程。一個占有CPU資源的線程可以讓休眠的線程調用interrupt 方法“吵醒”自己,即導致休眠的線程發(fā)生InterruptedException異常,從而結束休眠,重新排隊等待CPU資源。

二、選擇題

1A2A。3B。

三、閱讀程序

1.屬于上機調試題目,解答略。

2.屬于上機調試題目,解答略。

3.屬于上機調試題目,解答略。

4.屬于上機調試題目,解答略。

5.屬于上機調試題目,解答略。

6.屬于上機調試題目,解答略

7.【代碼】:BA。

8.屬于上機調試題目,解答略

四、編寫程序

1. ?public class E?{

?public static void main(String args[])?{

???????Cinema a=new Cinema();

????????a.zhang.start();

????????a.sun.start();

????????a.zhao.start();

???}

}

class TicketSeller ???//負責賣票的類。

{ ?int fiveNumber=3,tenNumber=0,twentyNumber=0;

???public synchronized void ?sellTicket(int receiveMoney)

???{ ?if(receiveMoney==5)

???????{ ?fiveNumber=fiveNumber+1;

??????????System.out.println(Thread.currentThread().getName()+

"給我5元錢,這是您的1張入場卷");

???????}

???????else if(receiveMoney==10) ??????????

????????{ while(fiveNumber<1)

????????????{ ??try { ?System.out.println(Thread.currentThread().getName()+"靠邊等");

???????????????????????wait(); ??

???????????????????????System.out.println(Thread.currentThread().getName()+"結束等待");

????????????????????}

???????????????catch(InterruptedException e) {}

????????????}

???????????fiveNumber=fiveNumber-1;

???????????tenNumber=tenNumber+1;

???????????System.out.println(Thread.currentThread().getName()+

"給我10元錢,找您5,這是您的1張入場卷"); ?

????????}

???????else if(receiveMoney==20) ??????????

????????{ ?while(fiveNumber<1||tenNumber<1)

????????????{ ??try { ?System.out.println(Thread.currentThread().getName()+"靠邊等");

???????????????????????wait(); ??

???????????????????????System.out.println(Thread.currentThread().getName()+"結束等待");

????????????????????}

???????????????catch(InterruptedException e) {}

????????????}

???????????fiveNumber=fiveNumber-1;

???????????tenNumber=tenNumber-1;

???????????twentyNumber=twentyNumber+1; ??

???????????System.out.println(Thread.currentThread().getName()+

"20元錢,找您一張5元和一張10元,這是您的1張入場卷");

?????????????????????????????

????????}

???????notifyAll();

???}

}

class Cinema implements Runnable ?????????

{ ?Thread zhang,sun,zhao;

???TicketSeller seller;

???Cinema()

???{ ?zhang=new Thread(this);

??????sun=new Thread(this);

??????zhao=new Thread(this);

??????zhang.setName("張小有");

??????sun.setName("孫大名");

??????zhao.setName("趙中堂");

??????seller=new TicketSeller();

???}

???public void run()

???{ ?if(Thread.currentThread()==zhang)

???????{ ?seller.sellTicket(20);

???????}

???????else if(Thread.currentThread()==sun)

???????{ ?seller.sellTicket(10);

???????}

???????else if(Thread.currentThread()==zhao)

???????{ seller.sellTicket(5);

???????}

???}

}

2. ?參照本章例子6

3.參照本章例子9


查看更多