zoukankan      html  css  js  c++  java
  • 阅读源码反思基础

    HttpServlet 
    IHttpServletAdaptor
    HttpServletRequest
    HttpServletResponse
    HttpURLConnection	
    
    IO流操作一般分为两类:字符流和字节流。以“Reader”结尾都是字符流,操作的都是字符型的数据;以“Stream”结尾的都是字节流,操作的都是byte数据
    Java IO流操作汇总: inputStream 和 outputStream
    
    OutputStreamWriter 
    FileInputStream extends InputStream
    InputStreamReader
    Properties
    
    Serializable  序列化  反序列化
    
    T 泛型
    
    private
    protected
    public
    static 
    final	 final来修饰类 方法 属性都表示其值不可变,也就是说类不可继承,方法不可重写,属性不可覆盖
    abstract 抽象类 抽象方法,不能用private,static 修饰;
    
    native  所以native关键字的函数都是操作系统实现的,java只能调用。
    
    PrintWriter
    
    synchronized
    
    Map
    
    Arrays.asList(pk_messages) 数组转为List
    
    Gson 是 Google 提供的用来在 Java 对象和 JSON 数据之间进行映射的 Java 类库。可以将一个 JSON 字符串转成一个 Java 对象,或者反过来
    
    Gson gson = new GsonBuilder().disableHtmlEscaping().create();
    
    启用了HR模块之后,不能用外部交换平台;
    
    现在微服务用dubbo,feign,resttemplate来通信多,但是底层基本是HttpURLConnection
    
    
    		------998一组,不足998的最后推送
    		List<String> arrays = new ArrayList<String>();
    		for (String s : lists) {
    			arrays.add(s);
    			if (arrays.size() > 998) {
    				Logger.error("InitMessage2OATask everytimes:" + arrays.size());
    				SendNCDealData sndd = new SendNCDealData();
    				sndd.sendNCDealData(arrays.toArray(new String[0]));
    
    				arrays = new ArrayList<String>();
    			}
    		}
    		// 循环结束但是最终数据不足998
    		if (arrays.size() > 0) {
    			SendNCDealData sndd = new SendNCDealData();
    			sndd.sendNCDealData(arrays.toArray(new String[0]));
    		}
    		
    		
    MessageServiceImpl.java
    	deleteMessageByPk();
    	deleteMessageByPk();
    	
    	JSONObject	
    		JSONObject只是一种数据结构,可以理解为JSON格式的数据结构(key-value 结构),
    		可以使用put方法给json对象添加元素。JSONObject可以很方便的转换成字符串,也可以很方便的把其他对象转换成JSONObject对象
    	JSONArray
    	
    	
    	
    	/**
         * <b>function:</b> 处理oracle sql 语句in子句中(where id  in (1, 2, ..., 1000, 1001)),
         * 如果子句中超过1000项就会报错。
         * 这主要是oracle考虑性能问题做的限制。
         * 如果要解决次问题,可以用 where id (1, 2, ..., 1000) or id  (1001, ...)
         * @author hoojo
         * @createDate 2012-8-31 下午02:36:03
         * @param ids in语句中的集合对象
         * @param count in语句中出现的条件个数
         * @param field in语句对应的数据库查询字段
         * @return 返回 field in (...) or field in (...) 字符串
         */
         private String getOracleSQLIn(List<String> ids, int  count, String field) {
               count = Math.min(count, 1000);
               int len = ids.size();
               int size = len % count;
               if (size == 0) {
                     size = len / count;
               } else {
                     size = (len / count) + 1;
               }
               StringBuilder builder = new StringBuilder();
               for (int i = 0; i < size; i++) {
                     int fromIndex = i * count;
                     int toIndex = Math.min(fromIndex + count,  len);
                     String productId =  StringUtils.defaultIfEmpty(StringUtils.join(ids.subList(fromIndex, toIndex), "','"), "");
                     if (i != 0) {
                           builder.append(" or ");
                     }
                     builder.append(field).append(" in  ('").append(productId).append("')");
               }
               return  StringUtils.defaultIfEmpty(builder.toString(), field + "  in ('')");
         }
    	
    	
    	
    	
    

      

    ---- 动动手指关注我!或许下次你又能在我这里找到你需要的答案!ZZZZW与你一起学习,一起进步!
  • 相关阅读:
    linux读写锁
    正则表达式
    C++原型模式和模板模式
    C++外观模式和组合模式
    C++代理模式
    c++桥接模式
    Linux常用命令history/tcpdump/awk/grep
    C++委托模式
    c++ 读写锁
    布衣客
  • 原文地址:https://www.cnblogs.com/zzzzw/p/14672923.html
Copyright © 2011-2022 走看看