为什么Java书中实现Java异常链时,在catch{}模块中已经用throw再次抛出了一个异常,却还要在方法定义时throws这个类的异常?

最近学习了Java的异常链机制,发现了一个问题,就是作者实现Java异常链的时候总是在方法定义处throws方法体中已经throw过实例的异常类,显得有些赘余,我想请问这是在干什么,throws和throw不配套使用也不会出错,这样做只是为了什么?以为了后能看得懂?

public class ExceptionList {

    public void firstStep() throws MyException{
        throw new MyException();
    }
    //这里又throws了catch子句里已经抛出的异常
    public void SecondStep() throws AutoDefinedRuntimeException{
        try {
            ExceptionList eList = new ExceptionList();
            eList.firstStep();
        }
        catch(MyException me1) {
            //me1.getMessage();
            me1.printStackTrace();
            throw new AutoDefinedRuntimeException(me1);//抛出更高级的异常
        }
    }


    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try{
            ExceptionList eList = new ExceptionList();
            eList.SecondStep();
        }
        catch(AutoDefinedRuntimeException me2) {
            //me2.getMessage();
            me2.printStackTrace();
        }
    }

}

2个回答

既然 catch 了但是不处理而往上层跑,那么就没有必要用 catch 直接抛就可以了。
Java 语法规定的代码中但凡使用 throws 抛出异常的都需要在方法定义的时候声明。

如果不想在方法中进行捕获,可以在方法声明时利用throws声明进行抛出,将其交给自己的“上级”(调用此方法的程序)处理。在catch{}模块中用throw再次抛出了一个异常是为了监控异常是否被正常抛出(小白见解)

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java synchronized(this)模块中this参数的含义。
定义了如下3个类,大致情况的主进程同时启动两个test2和test3线程。 test2和test3的run方法内部都添加了synchronized模块,当两个模块中的参数互指或互不指,即test2种模块参数指向test3同时test3的参数指向test2,或test2和test3的参数都指向自己this时,运行结果为2个test2,test3线程互相等待但test2和test3线程同时运行: new test() t2 0 t3 0 t3 1 t2 1 t3 2 t2 2 t2 3 t3 3 t3 4 t2 4 t3 5 t2 5 t2 0 t3 6 t2 1 t3 7 t3 8 t2 2 t2 3 t3 9 t2 4 t3 10 t2 5 t3 0 t3 1 t3 2 t3 3 t3 4 t3 5 t3 6 t3 7 t3 8 t3 9 t3 10 当test2的参数指向test3,test3的参数指向自己this;或者test2的参数指自己,test3的参数指test2时,运行结果是4个test2,test3线程互相等待,同时只有一个线程运行: new test() t2 0 t2 1 t2 2 t2 3 t2 4 t2 5 t3 0 t3 1 t3 2 t3 3 t3 4 t3 5 t3 6 t3 7 t3 8 t3 9 t3 10 t2 0 t2 1 t2 2 t2 3 t2 4 t2 5 t3 0 t3 1 t3 2 t3 3 t3 4 t3 5 t3 6 t3 7 t3 8 t3 9 t3 10 并且不论synchronized块的参数是什么,同一个对象的运行是被锁住了,即两个test2和两个test3之间只能同时运行一个。 想问下高手jvm如何产生这个特性的原理是什么,这个参数又有什么方面的应用啊? public class test implements Runnable{ Thread t; Thread t1; test2 t2=new test2() ; test3 t3=new test3(); Thread T3; Thread TT3; test() { System.out.println("new test()"); t=new Thread(this); t1=new Thread(this); t2.t3=t3; t3.t2=t2; t.start(); t1.start(); T3=new Thread(t3); TT3=new Thread(t3); T3.start(); TT3.start(); } public void run() { t2.speak(); } public static void main(String[] args) { // TODO Auto-generated method stub new test( ); } } public class test2 { test3 t3; public void speak() { synchronized(t3){ //test2中参数指向test3线程 for(int i=0;i<=5;i++) { System.out.println("t2 "+i); try { Thread.sleep(1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } } public class test3 implements Runnable{ test2 t2; public void run() { synchronized(this){ //synchronized参数指向自己 for(int i=0;i<=10;i++) { System.out.println("t3 "+i); try { Thread.sleep(1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } }
java连接MYSQL数据库第一次可以,第二次报错
做项目在做一个用户首次登陆输入手机号码,发送随机密码的功能模块,首次点击完全没问题,系统会发送短信(中国移动的短信机的原理是连接它的数据库,插入一条数据即可)问题就出在连接数据库的问题上,再次发送,则后台报错ResultSet is from UPDATE. No Data.。 报错信息如下 ``` 严重: Exception occurred during processing request: ResultSet is from UPDATE. No Data. java.sql.SQLException: ResultSet is from UPDATE. No Data. at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:987) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:982) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:927) at com.mysql.jdbc.ResultSetImpl.next(ResultSetImpl.java:7152) at com.mysql.jdbc.ConnectionImpl.loadServerVariables(ConnectionImpl.java:3867) at com.mysql.jdbc.ConnectionImpl.initializePropsFromServer(ConnectionImpl.java:3404) at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2385) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2154) at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:792) at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) at java.lang.reflect.Constructor.newInstance(Constructor.java:513) at com.mysql.jdbc.Util.handleNewInstance(Util.java:411) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:381) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:305) at java.sql.DriverManager.getConnection(DriverManager.java:582) at java.sql.DriverManager.getConnection(DriverManager.java:185) at DAO.dbconnection2.<init>(dbconnection2.java:16) at action.testsendaction.execute(testsendaction.java:38) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) ``` dbconnection2.java 是创建连接,代码如下: ``` package DAO; import java.sql.Connection; import java.sql.DriverManager; public class dbconnection2 { private static final String DRIVER = "com.mysql.jdbc.Driver"; private static final String URL = "jdbc:mysql://*******:3306/mas?useUnicode=true&characterEncoding=gb2312"; private static final String USER = "ywz"; private static final String PASSWORD = "yw690"; private Connection con; public dbconnection2() throws Exception{ Class.forName(DRIVER); this.con = DriverManager.getConnection(URL, USER, PASSWORD); } public Connection getConnection() { return this.con; } public void closecon() throws Exception { if(this.con != null) { try { this.con.close(); } catch(Exception e) { throw e; } } } } ``` action代码: ``` public class testsendaction extends ActionSupport{ private String list; public String getList() { return list; } public void setList(String list) { this.list = list; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } private String content; public String execute() throws Exception{ dbconnection2 dbc2 = new dbconnection2(); Statement s1 = dbc2.getConnection().createStatement(); Random ran = new Random(); String pwd = ""; for(int i=0;i<6;i++) { pwd += ran.nextInt(10)+""; } System.out.println("ranpwd="+pwd); String mess = "本信息来自工资查询系统,用于用户的首次登陆,登陆密码为:"+pwd+" ,登陆成功后,请自行修改密码。"; String send = "insert into api_mt_6(mobiles,content) values('"+list+"','"+mess+"')"; s1.executeUpdate(send); System.out.println("send:"+send); s1.close(); dbc2.closecon(); return SUCCESS; } } ``` 报错是在数据库连接的new语句上。 连接最后也有关闭。但是就是不能进行二次访问数据库。只能重启下tomcat,然后又可以登录一次,第二次也无法连接了。 找了好久都没发现原因,希望大家帮帮忙 ,谢谢了!
java 3DES 解密时部分乱码
3DES 解密时,出现部分乱码,byte数组里有负值,不知道如何解决 ,求大神指导,代码如下: ``` import java.io.UnsupportedEncodingException; import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESedeKeySpec; import javax.crypto.spec.IvParameterSpec; /*字符串 DESede(3DES) 加密 * ECB模式/使用PKCS7方式填充不足位,目前给的密钥是192位 * 3DES(即Triple DES)是DES向AES过渡的加密算法(1999年,NIST将3-DES指定为过渡的 * 加密标准),是DES的一个更安全的变形。它以DES为基本模块,通过组合分组方法设计出分组加 * 密算法,其具体实现如下:设Ek()和Dk()代表DES算法的加密和解密过程,K代表DES算法使用的 * 密钥,P代表明文,C代表密表,这样, * 3DES加密过程为:C=Ek3(Dk2(Ek1(P))) * 3DES解密过程为:P=Dk1((EK2(Dk3(C))) * */ public class url { private static final String Algorithm = "DESede/CBC/NoPadding"; //定义加密算法,可用 DES,DESede,Blowfish private static final String key="CCBJF2014cowell20151118Y"; private static final String vi = "KW2015rj"; //keybyte为加密密钥,长度为24字节 //src为加密后的缓冲区 public static String decryptMode(String strMi){ try { //szSrc.getBytes("UTF-8"); byte[] src = com.sun.org.apache.xml.internal.security.utils.Base64.decode(strMi); //src = it.sauronsoftware.base64.Base64.encode(src); DESedeKeySpec dks = new DESedeKeySpec(key.getBytes()); SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede"); SecretKey securekey = keyFactory.generateSecret(dks); IvParameterSpec iv = new IvParameterSpec(vi.getBytes()); Cipher cipher = Cipher.getInstance(Algorithm); cipher.init(Cipher.DECRYPT_MODE, securekey,iv ); byte[] encoded = cipher.doFinal(src);//在单一方面的加密或解密 //Base64.encode(encoded); return new String(encoded); } catch (java.security.NoSuchAlgorithmException e1) { // TODO: handle exception e1.printStackTrace(); }catch(javax.crypto.NoSuchPaddingException e2){ e2.printStackTrace(); }catch(java.lang.Exception e3){ e3.printStackTrace(); } return null; } public static void main(String[] args) throws UnsupportedEncodingException { // TODO Auto-generated method stub //添加新安全算法,如果用JCE就要把它添加进去 String szSrc = "G6ZT+GxPq7JkGuLjVQ4TUAUyTcp+UnNpsoKGzy5FudtRNn6v9tSyWmxpcnFu01Rk8Th0NoV0E8TIhffliYQ4xQicG8ciVYWP2s+jk192tJrF6x6WV0ej2w=="; szSrc.getBytes("UTF-8"); System.out.println("jie密前的字符串:" + szSrc); System.out.println("jie密后的字符串:" + decryptMode(szSrc)); //byte[] srcBytes = decryptMode(keyBytes,encoded); //System.out.println("解密后的字符串:" + (new String(srcBytes))); } } ```
redis写入多条数据.排队列的时候有了异常.该怎么处理
如果 public void test2Trans() { long start = System.currentTimeMillis(); Transaction tx = jedis.multi(); try{ for (int i = 0; i < 100000; i++) { tx.set("t" + i, "t" + i); } }catch(Exception e){ tx.discard(); } List<Object> results = tx.exec(); long end = System.currentTimeMillis(); System.out.println("Transaction SET: " + ((end - start)/1000.0) + " seconds"); } 假设代码在try{}模块出现问题,那么catch{}模块直接取消事务的话.那么如何让这段代码实现rollback; 上面代码是个人猜想.求大神帮忙
mybatis 怎么实现 insert
package com.ciy_test.business.adress; import java.util.ArrayList; import java.util.List; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import com.alibaba.fastjson.JSONObject; import com.ciy_test.entity.Product; import com.ciy_test.entity.Purcase; import com.ciy_test.entity.WebResult; import com.ciy_test.service.ProductService; import com.ciy_test.service.PurcaseService; /** * 练习模块接口(练习使用) * @author admin * */ @Controller @RequestMapping("/business/test") @Api(tags = "练习模块") public class TestController { @Autowired private PurcaseService purcaseService ; @PostMapping("/getAddressDetail") @ResponseBody @ApiOperation(value="gg",notes="gg") @ApiImplicitParams({@ApiImplicitParam(name="id",value="id",paramType="query",required=false), @ApiImplicitParam(name="customerid",value="顾客号",paramType="query",required=false), @ApiImplicitParam(name="productid",value="商品号",paramType="query",required=false), @ApiImplicitParam(name="quantity",value="数量",paramType="query",required=false), }) public WebResult getpurcaselist( @RequestParam(value="id",defaultValue="") Integer id, @RequestParam(value="customerid",defaultValue="") String customerid, @RequestParam(value="productid",defaultValue="") String productid , @RequestParam(value="quantity",defaultValue="") Integer quantity ) { try{ // NyUserAddress nyUserAddressBean =nyUserAddressService.searchNyUseraddressByid(aid); Purcase bean =new Purcase(); List<Purcase> list = new ArrayList<>(); bean.setId(id); bean.setcustomerid(customerid); bean.setproductid(productid); bean.setquantity(quantity); list.add(bean); purcaseService.savepurcase(bean); JSONObject obj =new JSONObject(); //obj.put("nyUserAddressBean",nyUserAddressBean); obj.put("purcase",list); return WebResult.success(obj); } catch(Exception e){ e.printStackTrace(); } return WebResult.error(null); }
javaDao c3p0 mysql 服务器挂掉!
只有个页面,连接数据库的就是一个getSession(), 一个调用Dao实现类的方法; Dao实现类如下: ``` public class DptDaoImp implements DptDao { public List<Dpt> show_Dpt() { String sql ="SELECT * FROM dpt"; Connection conn=null; List<Dpt> dpt_List=null; ComboPooledDataSource dataSource =new ComboPooledDataSource(); try { conn = dataSource.getConnection(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } QueryRunner runner =new QueryRunner(); try { dpt_List = runner.query(conn, sql, new BeanListHandler<Dpt>(Dpt.class)); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } try { conn.close(); //此处已经释放连接 } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } return dpt_List; } } ``` c3p0的配置: ``` <c3p0-config> <default-config> <property name="jdbcUrl">jdbc:mysql://localhost:3306/rsp</property> <property name="driverClass">com.mysql.jdbc.Driver</property> <property name="user">root</property> <property name="password">root</property> <property name="initialPoolSize">10</property> <!--连接池中保留的最小连接数。--> <property name="minPoolSize">10</property> <!--连接池中保留的最大连接数。Default: 15 --> <property name="maxPoolSize">100</property>  <!--最大空闲时间,10秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 --> <property name="maxIdleTime">5</property> <property name="maxStatements">0</property> <property name="maxStatementsPerConnection">0</property> ``` 在mysql中my.ini 中最大连接 max_connections (已改为1000) 现状: 登录账号后,交替点那两个模块,60次左右就挂了,机器卡死,大大们求救啊! 出现下列提示: ``` 警告: com.mchange.v2.resourcepool.BasicResourcePool$AcquireTask@36e15d3f -- Acquisition Attempt Failed!!! Clearing pending acquires. While trying to acquire a needed new resource, we failed to succeed more than the maximum number of allowed acquisition attempts (30). Last acquisition attempt exception: com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Data source rejected establishment of connection, **message from server: "Too many connections"** at sun.reflect.GeneratedConstructorAccessor18.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) at java.lang.reflect.Constructor.newInstance(Constructor.java:513) at com.mysql.jdbc.Util.handleNewInstance(Util.java:409) at com.mysql.jdbc.Util.getInstance(Util.java:384) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1015) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:989) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:984) at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1105) at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2186) at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:787) at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:49) at sun.reflect.GeneratedConstructorAccessor14.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) at java.lang.reflect.Constructor.newInstance(Constructor.java:513) at com.mysql.jdbc.Util.handleNewInstance(Util.java:409) at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:357) at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:285) at com.mchange.v2.c3p0.DriverManagerDataSource.getConnection(DriverManagerDataSource.java:134) at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:182) at com.mchange.v2.c3p0.WrapperConnectionPoolDataSource.getPooledConnection(WrapperConnectionPoolDataSource.java:171) at com.mchange.v2.c3p0.impl.C3P0PooledConnectionPool$1PooledConnectionResourcePoolManager.acquireResource(C3P0PooledConnectionPool.java:137) at com.mchange.v2.resourcepool.BasicResourcePool.doAcquire(BasicResourcePool.java:1014) at com.mchange.v2.resourcepool.BasicResourcePool.access$800(BasicResourcePool.java:32) at com.mchange.v2.resourcepool.BasicResourcePool$AcquireTask.run(BasicResourcePool.java:1810) at com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread.run(ThreadPoolAsynchronousRunner.java:547) ```
java线程synchronized(this){}为何对其它synchronized方法产生影响。
直接上代码: public class NewThread implements Runnable{ String name; Thread t; static boolean suspendFlag; NewThread(String threadname) { name=threadname; t=new Thread(this,name); System.out.println("New thread:"+t); suspendFlag=false; t.start(); } public void run() { try { for(int i=15;i>0;i--) { System.out.println(name+":"+i); Thread.sleep(1000); synchronized(this){while(suspendFlag){this.wait();}} } }catch(InterruptedException e){} System.out.println(name+" exiting."); } synchronized void mysuspend(){suspendFlag=true;} synchronized void myresume(){suspendFlag=false;notify();} } public class SuspendResume { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub NewThread ob1=new NewThread("One"); try{ Thread.sleep(2000); ob1.mysuspend(); System.out.println("Suspending thread One"); Thread.sleep(2000); ob1.myresume(); System.out.println("Resuming thread One"); Thread.sleep(2000); }catch(InterruptedException e){} try{System.out.println("Waiting for threads to finiish."); ob1.t.join(); }catch(InterruptedException e){} System.out.println("Main thread exiting."); } } 运行结果: New thread:Thread[One,5,main] One:15 One:14 One:13 Suspending thread One One:12 Resuming thread One One:11 One:10 Waiting for threads to finiish. One:9 One:8 One:7 One:6 One:5 One:4 One:3 One:2 One:1 One exiting. Main thread exiting. 如预期一样,ob1.mysuspend();ob1.myresume();的调用在ob1线程运行中是正常时间控制挂起和重启。 但将run()方法中synchronized(this){}模块稍微修改: public void run() { try { synchronized(this){ for(int i=15;i>0;i--) { System.out.println(name+":"+i); Thread.sleep(1000); while(suspendFlag){this.wait();} } } }catch(InterruptedException e){} System.out.println(name+" exiting."); } 其余代码不变 结果是: New thread:Thread[One,5,main] One:15 One:14 One:13 One:12 One:11 One:10 One:9 One:8 One:7 One:6 One:5 One:4 One:3 One:2 One:1 Suspending thread One One exiting. Resuming thread One Waiting for threads to finiish. Main thread exiting. 结果是主线程对ob1.mysuspend();ob1.myresume();的调用没有按照预期的时间进行,而是卡在ob1线程运行结束后才开始调用,就好像ob1得运行将ob1.mysuspend();ob1.myresume();锁住一样,sychonized模块将循环体包围住,mysuspend()就像被锁住不能动了似的,为什么会有两次的运行结果差异?谢谢。
Java web报错。我换了个数据库就报错了
用以前的数据库是对的,换了个数据库他就报错了。![图片说明](https://img-ask.csdn.net/upload/201506/22/1434980064_991848.png) <%@ page language="java" import="java.util.*" pageEncoding="GB18030"%> <%@ page import="java.sql.*" %> <html> <head> <meta http-equiv="Content-Type" content="text/html;charset=gb2312"> <title>学生用户登录模块</title> </head> <body bgcolor="FFFFFF"> <h1 align="center"><b>学生信息系统学生用户登录</b></h1> <form action="xslogin.jsp" method="post"> <table width="52%" border="2" align="center"> <tr bgcolor="#FFFFCC"> <td align="center" width="43%"><div align="center">账号:</div> </td> <td width="57%"><div align="left"> <input type="text" name="account"> </div></td> </tr> <tr bgcolor="#CCFF99"> <td align="center" width="43%"><div align="center">密码:</div></td> <td width="57"><div align="left"> <input type="password" name="secret"> </div></td> </tr> </table> <p align="center"> <input type="reset" name="Reset" value="重置"> <input type="submit" name="Submit2" value="提交"> <% String account=request.getParameter("account"); if(account==null){account="";} byte b[]=account.getBytes("ISO-8859-1"); account=new String(b); String secret=request.getParameter("secret"); if(secret==null){secret="";} byte c[]=secret.getBytes("ISO-8859-1"); secret=new String(c); Connection con=null; Statement sql=null; ResultSet rs=null; try{ Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); } catch(ClassNotFoundException event){} try { con=DriverManager.getConnection("jdbc:odbc:manage","",""); sql=con.createStatement(); String condition="SELECT*FROM verify WHERE 账号="+"'"+account+"'"; rs=sql.executeQuery(condition); while(rs.next()) { String n=rs.getString("账号"); String s=rs.getString("密码"); if(account.equals(n)&&secret.equals(s)) { session.setAttribute("account",account); session.setAttribute("secret",secret); out.println("检测成功。"); String s1=response.encodeRedirectUrl("studentCX.jsp"); response.sendRedirect(s1); } } if(!(session.isNew())) { out.print("<BR>您输入的用户民或密码不正确"+account+":"+secret); } } catch(SQLException e1){} con.close(); %> <br><A HREF="main.jsp">返回主页</A>) </p> </body> </html>
jsp+jdbc登录模块问题
登录页面: <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'login.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <h1>用户登录</h1> <hr> <form action="dologin.jsp" method="post"> <table> <tr> <td>用户名</td> <td><input type="text" name="username" /></td> <td>密码</td> <td><input type="password" name="password" /></td> </tr> <tr> <td colspan="2"><input type="submit" value="登陆"></td> <td> <input type="button" value="注册" onclick="window.location.href='register.jsp';"/> </td> </table> </form> </body> </html> 检查页面: <%@ page language="java" import="java.util.*" page contentType="text/html; charset=GB2312"%> <%@page import="java.sql.*" %> <%@page import="java.io.*" %> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>JSP_JDBC_DEMO</title> </head> <body> <% Connection conn=null; Statement stmt=null; ResultSet res=null; boolean flag=false;//通过数据库匹配标识 String name_checked=null;//检查通过的用户名 %> <% try{ Class.forName("com.mysql.jdbc.Driver"); //加载驱动器 DriverManager.registerDriver(new com.mysql.jdbc.Driver()); //注册mysql驱动器 String dbURL="jdbc:mysql://localhost:3306/test"; String dbUser="root"; String dbPwd="5438027"; conn=java.sql.DriverManager.getConnection(dbURL,dbUser,dbPwd); //建立数据库连接 stmt=conn.createStatement(); String u=request.getParameter("username"); //从上级页面获得用户名 String p=request.getParameter("userpassword"); //从上级页面获得密码 String sql="SELECT name FROM pass WHERE ACCOUNT=u AND PASSWORD=p";//组装sql语句 System.out.println(sql);//执行上述sql语句 res=stmt.executeQuery(sql); if(true==res.next())//只有查询得到结果才可进入循环 { flag=true; name_checked=res.getString(1);//获得查询出的用户 %> <h3>Debug_数据库查询结果<%=name_checked %></h3> <% } }catch(Exception e){ System.out.println(e); }finally{ //关闭连接 try{ /* res.close();//依次关闭 stmt.close(); conn.close(); */ /* res.close(); stmt.close(); conn.close(); */ }catch(Exception e) { } } %> <!-- 根据状态跳转 --> <% if(true==flag)//登陆成功 { %> <jsp:forward page="loginsucess.jsp"> <% } else//登陆失败 { %> <jsp:forward page="loginfail.jsp"> <% } %> </body> </html> 数据库里定义的是ACCOUNT 和PASSWORD 每次运行都会出现如下结果 HTTP Status 500 - /dologin.jsp (line: 1, column: 53) equal symbol expected type Exception report message /dologin.jsp (line: 1, column: 53) equal symbol expected description The server encountered an internal error that prevented it from fulfilling this request. exception org.apache.jasper.JasperException: /dologin.jsp (line: 1, column: 53) equal symbol expected org.apache.jasper.compiler.DefaultErrorHandler.jspError(DefaultErrorHandler.java:42) org.apache.jasper.compiler.ErrorDispatcher.dispatch(ErrorDispatcher.java:408) org.apache.jasper.compiler.ErrorDispatcher.jspError(ErrorDispatcher.java:89) org.apache.jasper.compiler.Parser.parseAttribute(Parser.java:217) org.apache.jasper.compiler.Parser.parseAttributes(Parser.java:162) org.apache.jasper.compiler.Parser.parseAttributes(Parser.java:183) org.apache.jasper.compiler.ParserController.getPageEncodingForJspSyntax(ParserController.java:479) org.apache.jasper.compiler.ParserController.determineSyntaxAndEncoding(ParserController.java:420) org.apache.jasper.compiler.ParserController.doParse(ParserController.java:190) org.apache.jasper.compiler.ParserController.parseDirectives(ParserController.java:119) org.apache.jasper.compiler.Compiler.generateJava(Compiler.java:193) org.apache.jasper.compiler.Compiler.compile(Compiler.java:373) org.apache.jasper.compiler.Compiler.compile(Compiler.java:353) org.apache.jasper.compiler.Compiler.compile(Compiler.java:340) org.apache.jasper.JspCompilationContext.compile(JspCompilationContext.java:646) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:357) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:390) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:334) javax.servlet.http.HttpServlet.service(HttpServlet.java:722
一个Java小程序,复制文件的,有界面,为何运行没反应?没报错
程序分为界面和功能两个类,代码较长,我做了必要注释,请耐心看完,请大神指出运行没反应的原因(尽量不要写新代码给我,在原代码上修正,便于我理解) 实在没积分了,无法悬赏 界面部分 ``` /* * 界面 * @version 1.0 * 主要功能: 将查找目录内(含子目录)的指定后缀名文件复制到输出目录 */ package check; import java.io.*; import javax.swing.*; import java.awt.*; import java.awt.event.*; public class appearance { static File OldPath=null; //定义文件对象 static File NewPath=null; static String LastName=null; //定义后缀名对象 static int x=0; //用于对话框判断 public static void main(String[] args){ Frame f=new Frame("文件查找"); Panel p1=new Panel(); Panel p2=new Panel(); Panel p3=new Panel(); Label la1=new Label("查找目录:"); Label la2=new Label("输出目录:"); Label la3=new Label("后缀名:"); TextField t1=new TextField(50); TextField t2=new TextField(50); TextField t3=new TextField(20); Button b1=new Button("浏览"); Button b2=new Button("浏览"); Button b3=new Button("确定"); JFileChooser choose1=new JFileChooser(); JFileChooser choose2=new JFileChooser(); choose1.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY); choose2.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY); t1.setEditable(false); t2.setEditable(false); f.setBounds(200,150,520,200); p1.setLayout(new FlowLayout()); p2.setLayout(new FlowLayout()); p3.setLayout(new FlowLayout()); f.setLayout(new BorderLayout()); f.addWindowListener(new WindowAdapter(){ public void windowClosing(WindowEvent e){ f.setVisible(false); System.exit(0); } }); b1.addActionListener(new ActionListener(){ //按钮监听(文件选择器) public void actionPerformed(ActionEvent arg0) { choose1.showDialog(new JLabel(),"选择文件夹"); OldPath=choose1.getSelectedFile(); t1.setText(OldPath.getAbsolutePath()); } }); b2.addActionListener(new ActionListener(){ //按钮监听(文件选择器) public void actionPerformed(ActionEvent arg){ choose2.showDialog(new JLabel(),"选择文件夹"); NewPath=choose2.getSelectedFile(); t2.setText(NewPath.getAbsolutePath()); } }); b3.addActionListener(new ActionListener(){ //按钮监听(调用功能模块) public void actionPerformed(ActionEvent arg1){ LastName=t3.getText(); if(t1.getText().trim().length()<1||t2.getText().trim().length()<1||t3.getText().trim().length()<1){//对话框处理 x=JOptionPane.showConfirmDialog(f,"请输入完整","提示",JOptionPane.OK_CANCEL_OPTION,JOptionPane.ERROR_MESSAGE); if(x==JOptionPane.OK_OPTION) System.exit(0); } Function.cheek(OldPath, NewPath); //调用功能方法,传递文件对象参数 } }); f.add(p1,"North"); //添加组件 f.add(p2,"Center"); f.add(p3,"South"); p1.add(la1); p1.add(t1); p1.add(b1); p2.add(la2); p2.add(t2); p2.add(b2); p2.add(la3); p2.add(t3); p3.add(b3); f.setVisible(true); } } ``` 功能部分 ``` /* * 功能 * @version 1.0 */ package check; import java.io.*; class Function { static BufferedInputStream bis=null; //文件输入输出流,用于复制文件 static BufferedOutputStream bos=null; public static void cheek(File OldPath,File NewPath){ //功能方法 接受界面传值 if(!NewPath.exists()){ NewPath.mkdir(); } ergodic(OldPath,NewPath); //递归,扫描子目录内所有文件 } private static void ergodic(File oldPath, File newPath) { File[] files=oldPath.listFiles(); for(File f:files){ if(f.isDirectory()){ ergodic(f,newPath); } if(f.getName().endsWith(appearance.LastName)){ copy(f,newPath); //文件复制, } } } private static void copy(File f, File newPath) { //文件复制 String Name=newPath.getName(); File newfile=new File(f,Name); try{ bis=new BufferedInputStream(new FileInputStream(f)); bos=new BufferedOutputStream(new FileOutputStream(newfile)); byte[] by=new byte[1024]; int len=0; while((len=bis.read(by))!=-1){ bos.write(by,0,len); } bos.close(); bis.close(); }catch(IOException e){ } } } ```
学生成绩管理系统添加班级模块错误,下面是数据库的操作代码和控制台的代码,还有错误提示,求帮忙
//添加班级 public void addClass(int pid,String className) { String sql="insert into class (pid,classname) values(?,?)"; Connection connection=null; PreparedStatement p=null; try { connection=DbUtil.getConnection(); //手动提交事务 connection.setAutoCommit(false); p=(PreparedStatement) connection.prepareStatement(sql); p.setInt(1, pid); p.setString(2, className); p.executeUpdate(); //获取当前班级的父班级 Classes parentClass=findClassById(pid); //如果父班级为叶子 if (parentClass.getLeaf()==1) { modLeaf(connection, parentClass.getClassId(), 0); } //提交事务 connection.commit(); } catch (Exception e) { e.printStackTrace(); if (connection!=null) { try { connection.rollback(); } catch (Exception e1) { e1.printStackTrace(); } } } finally { DbUtil.colse(p); //恢复成自动提交 DbUtil.setAutoCommit(connection, true); DbUtil.colse(connection); } } /** * 修改叶子值如果为叶子 * @throws SQLException */ private void modLeaf(Connection connection,int classId,int leaf) throws SQLException{ String sql="update class set leaf=? where classid=?"; PreparedStatement p=null; try { p=(PreparedStatement) connection.prepareStatement(sql); p.setInt(1, leaf); p.setInt(2, classId); p.executeUpdate(); } finally { DbUtil.colse(p); } } /** * 根据ID查找班级 * 查询父班级是否为叶子 * 如果存在返回班级,不存在返回空 * @return */ public Classes findClassById(int classId) { String sql="select *form class where classid=?" ; Connection connection=null; PreparedStatement p=null; ResultSet rs=null; Classes classes=null; try { connection=DbUtil.getConnection(); p=(PreparedStatement) connection.prepareStatement(sql); rs=(ResultSet) p.executeQuery(); if(rs.next()) { classes=new Classes(); classes.setClassId(classId); classes.setClassName(rs.getString("classname")); classes.setPid(rs.getInt("pid")); classes.setLeaf(rs.getInt("leaf")); } } catch (Exception e) { e.printStackTrace(); } finally { DbUtil.colse(rs); DbUtil.colse(p); DbUtil.colse(connection); } return classes; } } 控制台代码,应该没错,s为输出的添加信息 int pid=Integer.parseInt(s.substring(s.indexOf("=")+1, s.indexOf(","))); String className=s.substring(s.lastIndexOf("=")+1, s.length()); ClassManage.getInstance().addClass(pid, className); 错误信息: 1-添加班级 2-删除班级 3-修改班级 4-查询班级 q-退出 1 请输入添加的班级名(classname=#): pid=3,classname=一年一班_01 java.sql.SQLException: Field 'leaf' doesn't have a default value at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:946) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723) at com.mysql.jdbc.Connection.execSQL(Connection.java:3256) at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1313) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1585) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1500) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1485) at com.coursemanage.lsq.ClassManage.addClass(ClassManage.java:67) at com.coursecontroller.lsq.ClassController.main(ClassController.java:47)
急!queryrunner查询时报“表或视图不存在”
//DAO层 public List<T> getForList(String sql, Object... args) { Connection connection = null; System.out.println(args); try { connection = JdbcUtils.getConnection(); return queryRunner.query(connection, sql, new BeanListHandler<T>(clazz), args); } catch (Exception e) { e.printStackTrace(); } finally { JdbcUtils.releaseConnection(connection); } return null; } //接口实现 public class BookListDaoImpl extends DAO<Book> implements BookListDao{ public List<Book> getByUserIdWithOrdered(String id) { // String sql = // "select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo " + // "where userInfo.id = ? and (userInfo.major = courseInfo.major or courseInfo.major is null) " + // "and courseInfo.TBkId = TBkinfo.Id " // + "and TBkinfo.Id in ( select orderlist.TBkId from orderlist where orderlist.userid = ? )"; String sql = "select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo,orderlist ol " + "where userInfo.id = ? and ol.userid = ? and userInfo.major = courseInfo.major " + "and courseInfo.TBkId = TBkinfo.Id and TBkinfo.Id = ol.TBkId"; return getForList(sql,id, id); } } 异常: java.sql.SQLException: ORA-00942: 表或视图不存在 Query: select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo,orderlist ol where userInfo.id = ? and ol.userid = ? and userInfo.major = courseInfo.major and courseInfo.TBkId = TBkinfo.Id and TBkinfo.Id = ol.TBkId Parameters: [2013215087, 2013215087] at org.apache.commons.dbutils.QueryRunner.rethrow(QueryRunner.java:542) at org.apache.commons.dbutils.QueryRunner.query(QueryRunner.java:399) at com.TBO.DAO.DAO.getForList(DAO.java:77) at com.TBO.DAOImpl.BookListDaoImpl.getByUserIdWithOrdered(BookListDaoImpl.java:20) at com.TBO.test.test.test(test.java:19) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 说明:select语句中的表都存在,sql语句在PLsql中能够得到正确结果。现将其写到java中,并使用通配符,出下一下情况: 情况一: String sql = "select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo " + "where userInfo.id = ? and (userInfo.major = courseInfo.major or courseInfo.major is null) " + "and courseInfo.TBkId = TBkinfo.Id " + "and TBkinfo.Id in ( select orderlist.TBkId from orderlist where orderlist.userid = ? )"; return getForList(sql,id, id); 结果:报上面提到的异常 情况二:将sql语句写实 String sql = "select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo " + "where userInfo.id = 2013215087 and (userInfo.major = courseInfo.major or courseInfo.major is null) " + "and courseInfo.TBkId = TBkinfo.Id " + "and TBkinfo.Id in ( select orderlist.TBkId from orderlist where orderlist.userid = 2013215087)"; return getForList(sql); 结果:可得到正确结果 情况三: public void test() { DAO < Order > dao = new DAO < Order>(); dao.getForList("select * from orderlist "); } 说明:Order是个bean,成员变量与数据库字段对应 结果: 信息: Initializing c3p0 pool... com.mchange.v2.c3p0.ComboPooledDataSource [ acquireIncrement -> 10, acquireRetryAttempts -> 30, acquireRetryDelay -> 1000, autoCommitOnClose -> false, automaticTestTable -> null, breakAfterAcquireFailure -> false, checkoutTimeout -> 0, connectionCustomizerClassName -> null, connectionTesterClassName -> com.mchange.v2.c3p0.impl.DefaultConnectionTester, dataSourceName -> mvcapp, debugUnreturnedConnectionStackTraces -> false, description -> null, driverClass -> oracle.jdbc.driver.OracleDriver, factoryClassLocation -> null, forceIgnoreUnresolvedTransactions -> false, identityToken -> 1br3s3l9n1dqtu2imjlrpx|427800ef, idleConnectionTestPeriod -> 0, initialPoolSize -> 20, jdbcUrl -> jdbc:oracle:thin:@127.0.0.1:1521:TBO, maxAdministrativeTaskTime -> 0, maxConnectionAge -> 0, maxIdleTime -> 0, maxIdleTimeExcessConnections -> 0, maxPoolSize -> 60, maxStatements -> 40, maxStatementsPerConnection -> 10, minPoolSize -> 20, numHelperThreads -> 3, numThreadsAwaitingCheckoutDefaultUser -> 0, preferredTestQuery -> null, properties -> {user=******, password=******}, propertyCycle -> 0, testConnectionOnCheckin -> false, testConnectionOnCheckout -> false, unreturnedConnectionTimeout -> 0, usesTraditionalReflectiveProxies -> false ] java.lang.NullPointerException at sun.reflect.misc.ReflectUtil.checkPackageAccess(ReflectUtil.java:164) at sun.reflect.misc.ReflectUtil.isPackageAccessible(ReflectUtil.java:195) at java.beans.Introspector.getBeanInfo(Introspector.java:154) at org.apache.commons.dbutils.BeanProcessor.propertyDescriptors(BeanProcessor.java:358) at org.apache.commons.dbutils.BeanProcessor.toBeanList(BeanProcessor.java:168) at org.apache.commons.dbutils.BasicRowProcessor.toBeanList(BasicRowProcessor.java:134) 情况四: public List<Book> getByUserIdWithOrdered(String id) { String sql = "select distinct TBkInfo.*,courseInfo.name coursename from userInfo,courseInfo,TBkInfo " + "where userInfo.id = ? and (userInfo.major = courseInfo.major or courseInfo.major is null) " + "and courseInfo.TBkId = TBkinfo.Id "; return getForList(sql,id); } 结果:得到正确结果 再次说明,以上的sql语句在PLsql中都能得到正确结果,getForList在多个模块中用到,也存在通配符,但只在当前情况下抛异常。数据库用户具有DAB权限
在java中,怎样通过点一个Button按钮取消Checkbox原有的选中状态,变为未选中?
运行时,先选中一个(A,B,C,D中任选一个,如A),此时在文件text.txt中读入了一个A,然后点按钮“下一个”,此时A的选中状态应该被取消了,然后可以再选A,文件里又读入一个A 最终目的是:连续的问题可以选同样的答案(文件中读入多个连续的相同的答案) 以下是改模块的代码。请指点指点该怎么修改,谢谢!! import java.awt.*; import java.awt.event.*; import java.io.*; public class TextCheckbox implements ItemListener{ Frame MyFrame=new Frame(); Button btn=new Button("下一个"); CheckboxGroup checkboxgroup=new CheckboxGroup(); Checkbox p1=new Checkbox("A",false,checkboxgroup); Checkbox p2=new Checkbox("B",false,checkboxgroup); Checkbox p3=new Checkbox("C",false,checkboxgroup); Checkbox p4=new Checkbox("D",false,checkboxgroup); TextCheckbox() { MyFrame.setLayout(new FlowLayout()); MyFrame.add(p1); MyFrame.add(p2); MyFrame.add(p3); MyFrame.add(p4); MyFrame.add(btn); p1.addItemListener(this); p2.addItemListener(this); p3.addItemListener(this); p4.addItemListener(this); MyFrame.setSize(300,300); MyFrame.setVisible(true); MyFrame.addWindowListener(new HandleAct()); } public void itemStateChanged(ItemEvent e) { String label=((Checkbox)e.getSource()).getLabel(); try{ if(e.getStateChange()==ItemEvent.SELECTED){ PrintWriter input=new PrintWriter(new FileWriter("key.txt",true)); input.println(label); input.close(); } }catch(IOException ioe){} } class HandleAct extends WindowAdapter { public void windowClosing(WindowEvent e) { (e.getWindow()).dispose(); System.exit(0); } } /** * @param args */ public static void main(String[] args) { new TextCheckbox(); // TODO 自动生成方法存根 } }
如何在某个顶层方便的捕获事件线程抛出的异常
&nbsp;&nbsp;&nbsp; 有一次看.NET平台的WinForm发现其有提供捕捉这样异常的方法,升至它有默认的异常处理。 <br />但是在Swing中,如果某事件处理函数抛出了一个异常,很可能导致事件线程挂掉,这时候界面点击无反应, <br />软件甚至要通过强行关闭才能退出。如果在某顶层做一个最后防御,这样哪个事件处理模块如果抛出未处理异常, <br />也不至于程序莫名的挂掉,顶多输出一个信息告知用户系统错误,我要挂了,然后退出。 <br />但是我找了一下不知Swing在什么地方可以捕获异常。不知道大家是如何处理这个问题的。<br /><strong>问题补充:</strong><br />是这样的&nbsp;&nbsp; swing你得自己写个异常&nbsp; 当抛出异常的时候 可以让异常形成一个joptionpane 点了确定之后 这样程序就不挂着了&nbsp; 可以给用户选择的余地 这样增加了程序的友好性 <br />你写个异常继承RuntimeException 在构造器里写段抛出对话框的代码 并把信息打印在抛出的对话框里 <br />_____________________________________ <br />你这里的想法是说,我专门定义一个异常,然后别人如果出现错误要抛出这个异常? <br />然后这个异常呢会弹出对话框? <br />可是这并没有解决真正的问题啊,我要做的本来就是一个最后防御,某个事件处理函数抛出什么异常这本更就是不可知的,我要的是在某个顶层能捕捉到事件线程抛出来的未处理异常,这里就是要为了程序不能不明不白的挂掉。<br /><strong>问题补充:</strong><br />我说的和你想的意思一样 我们现在就是这样处理的 而且程序运行了几年了也没问题啊&nbsp;&nbsp; 你在有可能抛出异常的地方try catch然后抛出你自己写的异常啊&nbsp; 编译时异常必须声明这不用咱们去操心JAVA机制自动处理&nbsp;&nbsp; 而只要有运行时异常抛出就一定是你代码的问题&nbsp; 或者用户的输入之类的不符合你的预期逻辑你刻意的抛出一个异常&nbsp; 异常是一层层向上抛的 你把事件可能出现问题的部分 try catch住不就行了么 <br />———————————————————————— <br />可是这样的话,那么和他自己捕捉了某个异常,然后弹出一个对话框又有多少区别呢?这是把防御交给了每个处理者自己。可是如果我不能假定他们都正确处理了这一切呢?这个时候我需要一张最后防御网,这个该如何处理呢?<br /><strong>问题补充:</strong><br />哦呵呵&nbsp; 你的意思是不是怕有遗漏 想来个最后有个系统的捕获是吧&nbsp; 一般的话 要是把项目配置在spring中都会在spring里配置一个最顶层的异常处理器 。。 你邮箱多少 我给你发个springrcp的文档&nbsp; 你进去看他的异常处理部分上面说的很清楚 呵呵 但是很长 在这里说不清楚 <br />__________________________________ <br />以现在的情况是不可能改用springrcp的,既然springrcp做到了,那么一定是有方法的,只是我奇怪为什么Swing没有提供一个简便的接口来捕获事件线程异常呢?这一点上 .net确实周到了一点。
数据库查询模块说参数缺失,全部前台JSP运行
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@page import="java.sql.*"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>信息查询</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <!-- <link rel="stylesheet" type="text/css" href="styles.css"> --> </head> <body> <h2 align="center">动物数据信息查询</h2> <form name="form1"method="post"action=""> <p align="center">输入动物编号: <input name="drugs" type="text" id="drugs"size="16"maxlength="16"/> <input type="submit"name="submit"value="提交"/> <input type="reset"name="reset"value="重置"/> </p> </form> <div align="center"> <% request.setCharacterEncoding("UTF-8"); try{ String drugs=request.getParameter("drugs"); if(drugs!=null) { if(!drugs.equals("")) { Class.forName("oracle.jdbc.driver.OracleDriver"); String username="SYSTEM"; String password="Zxy11111"; String url="jdbc:oracle:thin:@localhost:1521:ZXY"; Connection conn=DriverManager.getConnection(url, username, password); Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE); String sql="select*from adata where animal='"+drugs+"'"; ResultSet rs=stmt.executeQuery(sql); if(rs!=null) { while(rs.next()) { %> </div> <div align="center"> <hr> 动物编号:<%=rs.getString("animal")%><br/> 喂食量:<%=rs.getString("feed") %><br/> 瘤胃PH:<%=rs.getString("lwph") %><br/> 饮水量:<%=rs.getString("drink") %><br/> 体重:<%=rs.getString("weight") %><br/> 性别:<%=rs.getString("sex") %><br/> 饲养天数:<%=rs.getString("aday") %><br/> 数据采集时间:<%=rs.getString("atime") %><br/> <% } } else { %> <font color=red>没有该动物信息</font> <% } rs.close(); stmt.close(); conn.close(); } } } catch(ClassNotFoundException e) { out.println("驱动程序类异常!<br>"); out.println(e.getMessage()); } catch(SQLException e) { out.println("数据库连接或SQL查询异常!<br>"); out.println(e.getMessage()); } catch(Exception e) { out.println("其他异常!<br>"); out.println(e.getMessage()); }%> </div> </body> </html> 运行后出现问题: 数据库连接或SQL查询异常! ORA-01009: 必需的参数缺失 求大神解决
android 调用 webservice 返回字符串想在listview中显示。出现问题……
下文是 主查询模块 Query_xiaofeijilu.java, ``` package com.gongneng.chaxun; import java.io.IOException; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.StringTokenizer; import android.app.Activity; import android.content.Context; import android.os.Bundle; import android.os.Handler; import android.os.Looper; import android.view.View; import android.widget.Button; import android.widget.ListView; import android.widget.SimpleAdapter; import org.json.JSONException; import org.ksoap2.SoapEnvelope; import org.ksoap2.SoapFault; import org.ksoap2.serialization.SoapObject; import org.ksoap2.serialization.SoapSerializationEnvelope; import org.ksoap2.transport.HttpTransportSE; import org.xmlpull.v1.XmlPullParserException; import com.constant.Constant; import com.example.kehuduan.R; public class Query_xiaofeijilu extends Activity { private Button okButton; private ListView listview; private Handler handler = null; private SimpleAdapter adapter; private List<Map<String,Object>> muldata; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.query_xiaofeijilu); okButton = (Button) this.findViewById(R.id.xiaofeijiluchaxun); listview = (ListView) this.findViewById(R.id.listxiaofeijilu); handler = new Handler(); okButton.setOnClickListener(new Button.OnClickListener() { @Override public void onClick(View v) { new Thread() { @Override public void run() { try { try { getWebservice(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (XmlPullParserException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (JSONException e) { // TODO Auto-generated catch block e.printStackTrace(); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }.start(); } }); } public void getWebservice() throws InterruptedException, IOException, XmlPullParserException, JSONException { // 创建属于主线程的handler HttpTransportSE ht = new HttpTransportSE(Constant.SERVICE_URL); SoapSerializationEnvelope envelope = new SoapSerializationEnvelope(SoapEnvelope.VER11); SoapObject request = new SoapObject(Constant.SERVICE_NS,Constant.QueryAction_chaxunxiaofeijilu); request.addProperty("aac999", "2200000"); envelope.bodyOut = request;// 往出走的数据Out,也就是服务器的传入值 try { ht.call(null, envelope); Object object = (Object) envelope.getResponse();// 就用Object来取 muldata = new ArrayList<Map<String,Object>>(); if (envelope.getResponse() != null) { String a = object.toString(); String b = a.replace("[","");//变[为空 String c = b.replace("]",""); String d = c.replace("{",""); String e = d.replace("}",""); String f = e; // String[] arr = c.split(",");//将字符串转为数组,以,为分割 Map<String, Object> aa = transStringToMap(f); Iterator<?> iter = aa.entrySet().iterator(); while (iter.hasNext()) { Map<String,Object> map=new HashMap<String, Object>(); Map.Entry entry = (Map.Entry) iter.next(); Object key = entry.getKey(); Object val = entry.getValue(); map.put(key.toString(),val.toString()); // map.put("text", "测试文本:"); muldata.add(map); } adapter = buildListAdapter(this, muldata); new Thread() { public void run() { handler.post(runnableUi); } }.start(); return; } else { System.out.println("没有返回值"); return; } } catch (SoapFault e) { // TODO Auto-generated catch block e.printStackTrace(); } } // 构建adapter. public SimpleAdapter buildListAdapter(Context context,List<Map<String, Object>> data) { SimpleAdapter adapter = new SimpleAdapter(context, data, R.layout.chaxunxiaofeijilulist, new String[] { "AKB021","AKE038","KS","JS","ROWNUM" }, new int[] { R.id.akb021, R.id.ake038,R.id.ks,R.id.js ,R.id.rownum}); return adapter; } // 构建Runnable对象,在runnable中更新界面 // 更新页面list 需要单独写个线程 Runnable runnableUi = new Runnable() { @Override public void run() { // 更新界面 listview.setAdapter(adapter); Looper.loop(); } }; //=================================== //字符串转MAP public static Map<String, Object> transStringToMap(String mapString){ Map<String, Object> map = new HashMap<String, Object>(); java.util.StringTokenizer items; for(StringTokenizer entrys = new StringTokenizer(mapString, ","); entrys.hasMoreTokens(); map.put(items.nextToken(), items.hasMoreTokens() ? ((Object) (items.nextToken())).toString() : null)) items = new StringTokenizer(entrys.nextToken(), ":"); return map; } } ``` 下文是list页面 ``` <?xml version="1.0" encoding="UTF-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/child" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="horizontal" > <!-- 若想隐藏id加入此属性: android:visibility="gone",这样做有点类似于Html中hidden域 android:background="#E3D25E" --> <TextView android:id="@+id/akb021" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="#6633FF" android:text=" akb021 " /> <TextView android:id="@+id/ake038" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=" ake038 "/> <TextView android:id="@+id/ks" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=" ks "/> <TextView android:id="@+id/js" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=" js "/> <TextView android:id="@+id/rownum" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text=" rownum "/> </LinearLayout> ``` 主显示页面 ``` <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:paddingBottom="@dimen/activity_vertical_margin" android:paddingLeft="@dimen/activity_horizontal_margin" android:paddingRight="@dimen/activity_horizontal_margin" android:paddingTop="@dimen/activity_vertical_margin" tools:context=".MainActivity" > <EditText android:id="@+id/editTextShenfenzheng" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignLeft="@+id/listxiaofeijilu" android:layout_alignParentTop="true" android:layout_alignRight="@+id/listxiaofeijilu" android:ems="10" android:hint="@string/shenfenzheng" > </EditText> <Button android:id="@+id/chongzhi" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_alignParentRight="true" android:text="@string/chongzhi" /> <ListView android:id="@+id/listxiaofeijilu" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_above="@+id/xiaofeijiluchaxun" android:layout_alignRight="@+id/chongzhi" android:layout_below="@+id/editTextShenfenzheng" > </ListView> <Button android:id="@+id/xiaofeijiluchaxun" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBaseline="@+id/chongzhi" android:layout_alignBottom="@+id/chongzhi" android:layout_toLeftOf="@+id/chongzhi" android:text="@string/xiaofeijilu" /> </RelativeLayout> ``` 但是现在只把行数显示出来了,里边没有值,附图: ![图片说明](https://img-ask.csdn.net/upload/201504/18/1429357099_489390.png) 这个问题,困扰了我好几天了,烦请各位好友,帮忙出出招,在此写过了!!!
是抛出异常?还是返回错误字符串?
近日在做一个项目, 这个项目分为多个模块,包括前台tomcat,后台服务等等。 其中后台服务 是 使用spring 将调用的接口bean 发布成JMX服务。现在有一个问题,就是当某个方法执行出错的时候,是返回错误字符串?还是抛出系统异常? 是所有的方法都返回下面的固定结果? [code="java"] Class Result{ String errorString; Object result; Boolean success; [/code] 还是出错后 抛出系统异常? [code="java"] public void foo(){ try{ }catch(Exception e){ throw new AppException("..."); } } [/code] 不知这两种方法哪种好一些? 这个问题可能有些新手了,请各位见谅。。
maven 里模块拆分时, 我dao层的值传不进去service层
Running com.mycompany.app.service.UserServiceTest **********service 层testQueryPassword******开始****** Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 0.081 sec <<< FAILURE! testQueryPassword(com.mycompany.app.service.UserServiceTest) Time elapsed: 0.022 sec <<< ERROR! java.lang.NullPointerException ```//dao层实现代码 public String getUserPassword(String userName) { String name = ""; Session session = null; try { session = HibernateUtils.getSession(); session.beginTransaction(); List result = session.createQuery("select password from User where name = :name").setParameter("name", userName).list(); if(result !=null && result.size()>0) { name = (String) result.get(0); } else { name = "null"; } System.out.println("****************************"); System.out.println(name); session.getTransaction().commit(); }catch(Exception e) { e.printStackTrace(); session.getTransaction().rollback(); }finally { HibernateUtils.closeSession(session); } return "zhanshan"; } } //service层 package com.mycompany.app.service; import com.mycompany.app.dao.UserDao; public class UserServiceImpl implements UserService { private UserDao userdao; public String getUserPassword(String name) { // TODO Auto-generated method stub return userdao.getUserPassword(name); } } ```
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
相关热词 c#导入fbx c#中屏蔽键盘某个键 c#正态概率密度 c#和数据库登陆界面设计 c# 高斯消去法 c# codedom c#读取cad文件文本 c# 控制全局鼠标移动 c# temp 目录 bytes初始化 c#
立即提问