Java搶貨
『壹』 java搶購怎麼解決先後問題
實務未完成前拒絕其他請求。但是很明顯會影響效率並且有些請求可能永遠拿不到這個鎖。第一種方法:隊列桐腔、就是將所有請求放到隊列里,按照先來先處理,原則上這樣所有請求最後都會被處理。但是當你姿輪畢處理速度長時間跟不上請求訪問數,很可能會撐爆你的隊列跡芹內存。
『貳』 java多線程搶占資源問題
你可以把你的代碼貼出來鎮友山巧嗎?你前面描述的我能御唯槐看懂,但是你後面說我不知道你是如何一個寫法,寫法不同結果也會有不同的,所以你描述完最後最好把代碼也貼一下
『叄』 java怎麼解決兩個手機同時搶一個單
可以用不同的java軟體裝在同一部手機上!一個Java軟體不能同時裝在同一部手機兩次!
『肆』 Java如何解決超賣
一、人數閥門設計:進行用戶人群過濾。
商品數量只有100份,秒殺人數有10000人,那麼我們就設計1道閥門(根據情況,可以設計3道或者2道都可以的)。
在整點的時候,我們對點擊了「購買」按鈕後,我們只運行500人進入信息填寫頁面,信息填寫完成後提交訂單。效果如下:
①商品詳情點擊購買(秒殺)--》②輸入信息提交訂單--》③進行支付
10000人 500人 (這里也可以設計閥門,只允許多少人進入支付)
其他未進入的如何處理乃?顯示已搶完或者排隊等待(這就是後面要提到的排隊系統設計)。
二、會員排隊設計:對用戶進行排隊,排在前面的先購買
這相當於是消息隊列模式了,如果秒殺是立即知道結果,排隊可能會有點雞肋。
在第二步②輸入信息提交訂單後進行排隊,排在前面的先購買,排在後面的後購買
三、問答問題設計:過濾掉一些反應慢的用戶
在第一步①點擊購買後跳轉到問題頁面,用戶必須回答正確問題後,方可進入後面的流程
四、庫存緩存設計:緩存庫存,判斷用戶購買的商品是否還有,不讀取資料庫,速度快,也不會增加資料庫負擔,
經過前面的過濾,超賣的可能性比較低了提前將商品庫存緩存起來,到下單購買的時候,用戶購買了就減1,每次都通過庫存緩存判斷一下,如果為0就顯示已搶完。
五、頁面靜態設計:盡量靜態緩存化【CDN那些這里不做考慮】
第一步①商品詳情頁面,盡量進行緩存,減輕大批量用戶在訪問商品頁面的時候,大量查詢資料庫。
問答問題頁面:全靜態,載入快,無資料庫負擔。
排隊等待頁面:全靜態,載入快,無資料庫負擔。
排隊結束頁面:全靜態,載入快,無資料庫負擔。
『伍』 100個商品1000個人搶,java該怎麼做
可態數以將搶商品的請求放入一個操作list A中,然後按順序取出list中的請求去購買商品,購買成功後放入另一個list B中。每次接受到請求後查看listB中的信息,如果size等於100返回商品售帆腔首光的信息。每次放入B後檢查B的size,當圓卜size等於100,取出A中的所有請求,返回商品售光的信息
『陸』 java怎麼寫自動去搶雙十一程序
android中網路通信分為socket編程和http編程,這里只介紹htt方面。網路請求方式可分為get請求,post兩種請求方式,GET方式在進行數據請求時,會把數據附加到URL後面傳遞給伺服器,比如常見的:http://XXX.XXX.XXX/XX.aspx?id=1,POST方式則是將請求的數據放到HTTP請求頭中,作為請求頭的一部分傳入伺服器。
所以,在進行HTTP編程前,首先要明確究竟使用的哪種方式進行數據請求的。
android中Http編程有兩種:1、HttpURLConnection;2、HttpClient
首先介紹一下HttpURLConnection方式的get請求和post請求方法:
[java] view
plainprint?
private Map<String, String> paramsValue;
String urlPath=null;// 發送地http://192.168.100.91:8080/myweb/login?username=abc&password=123
public void initData(){urlPath="http://192.168.100.91:8080/myweb/login";
paramsValue=new HashMap<String, String>();
paramsValue.put("username", "111");
paramsValue.put("password", "222");
}
private Map<String, String> paramsValue;
String urlPath=null;
// 發送地http://192.168.100.91:8080/myweb/login?username=abc&password=123
public void initData(){
urlPath="http://192.168.100.91:8080/myweb/login";
paramsValue=new HashMap<String, String>();
paramsValue.put("username", "111");
paramsValue.put("password", "222");
}
get方式發起請求:
[java] view
plainprint?
private boolean sendGETRequest(String path, Map<String, String> params) throws Exception {
boolean success=false;// StringBuilder是用來組拼請求地址和參數
StringBuilder sb = new StringBuilder();
sb.append(path).append("?");
if (params != null && params.size() != 0) {
for (Map.Entry<String, String> entry : params.entrySet()) {
// 如果請求參數中有中文,需要進行URLEncoder編碼 gbk/utf8
sb.append(entry.getKey()).append("=").append(URLEncoder.encode(entry.getValue(), "utf-8"));
sb.append("&");
}
sb.deleteCharAt(sb.length() - 1);
}URL url = new URL(sb.toString());
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setConnectTimeout(20000);
conn.setRequestMethod("GET");
if (conn.getResponseCode() == 200) {
success= true;
}
if(conn!=null)
conn.disconnect();
return success;
}
private boolean sendGETRequest(String path, Map<String, String> params) throws Exception {
boolean success=false;
// StringBuilder是用來組拼請求地址和參數
StringBuilder sb = new StringBuilder();
sb.append(path).append("?");
if (params != null && params.size() != 0) {
for (Map.Entry<String, String> entry : params.entrySet()) {
// 如果請求參數中有中文,需要進行URLEncoder編碼 gbk/utf8
sb.append(entry.getKey()).append("=").append(URLEncoder.encode(entry.getValue(), "utf-8"));
sb.append("&");
}
sb.deleteCharAt(sb.length() - 1);
}
URL url = new URL(sb.toString());
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setConnectTimeout(20000);
conn.setRequestMethod("GET");
if (conn.getResponseCode() == 200) {
success= true;
}
if(conn!=null)
conn.disconnect();
return success;
}