Fork me on GitHub

阅读源码反思基础

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 ('')");
     }
	
	
	
	

  

posted @ 2021-04-18 10:16  ZZZZW  阅读(76)  评论(0编辑  收藏  举报
AmazingCounters.com