線程阻塞了,開啟新線程執行你的操作。不要在主線程中執行耗時操作

創新互聯專注于中大型企業的成都網站建設、網站制作和網站改版、網站營銷服務,追求商業策劃與數據分析、創意藝術與技術開發的融合,累計客戶千余家,服務滿意度達97%。幫助廣大客戶順利對接上互聯網浪潮,準確優選出符合自己需要的互聯網運用,我們將一直專注成都品牌網站建設和互聯網程序開發,在前進的路上,與客戶一起成長!
代碼很有意思 我反而學到了不少
已經知道問題在于這個方法numCheck
實際上是考慮多了 既然用戶改變了textField才會觸發事件
那么 我們就沒必要去再次改變textField的內容了
因此textValueChanged事件中不需要去做setText的方法
你的程序在else中那一句注釋掉就行了
else中什么都不做的
private int numCheck(TextField tf_temp,String num) {
int i = 0;
while(num.matches("0+\\d+")){
num = num.substring(1);
}
try{
i = Integer.parseInt(num);
//tf_temp.setText(num);
if(i255){ //這個最多只會發生一次不會發生死循環;
i = 255;
num = "255";
tf_temp.setText(num);
System.out.println(i);
}else {
//tf_temp.setText(num); //死循環。setText觸發了TextvalueChanged()檢查發現小于255,這個else又成立,這樣死循環;
System.out.println(i);
}
}catch(NumberFormatException e){
alertDialog.setVisible(true);
tf_temp.setText("255");
e.printStackTrace();
}
return i;
}
代碼與你的電腦系統不兼容。
建議你用PHP的來做。
win7 64位。
你這個不是死鎖,就是flag的判斷有問題,每個線程都是自己把自己鎖住了,當flag為true時,看以下兩段代碼:
public synchronized void set(String name) {
if (flag)
try {
wait();
public synchronized void out() {
if (flag)
try {
wait();
兩個線程都在wait,當然卡住不動了。
看你的代碼,把set那段改成這樣應該就好了:
public synchronized void set(String name) {
if (!flag)
try {
wait();
jta1.append("服務器已為此客戶端建立線程:Client"+clientNo+"/n當前時間為"+ dd.format(new Dateand.old()));
當前名稱:java被碰到就死的代碼 java死代碼是什么意思
鏈接地址:http://www.yijiale78.com/article44/hihshe.html
成都網站建設公司_創新互聯,為您提供品牌網站設計、網頁設計公司、關鍵詞優化、微信小程序、網站導航、云服務器
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯