首先建立线程池
ExecutorService pool = Executors.newFixedThreadPool(1000);
pool.submit(new HandlerSocket(client));
然后,实现多线程,
当一个线程出现异常时:如下
pool-1-thread-1
javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:913)
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:824)
at com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314)
at javax.crypto.Cipher.doFinal(Cipher.java:2165)
at EncryptOrDecrypt.decryptString(EncryptOrDecrypt.java:173)
at HandlerSocket.parseRequestHead(HandlerSocket.java:29)
at HandlerSocket.run(HandlerSocket.java:37)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
接入数据...
pool-2-thread-1
{"ECOrderId":"456789125","OrderList":[{"PID":"100000","Phones":"18064121114,18150123459"}]}
如上:pool-1-thread-1这个线程异常了,他还能正常结束,等待执行下次线程的分配么,还是一直占着这个线程卡死在那里?
其中pool-2-thread-1这个线程池中的线程被正常支行了 |