StringBuffer

private void pushLocData(List<MessageBean> coorList) {
	StringBuffer sbu = new StringBuffer();
	sbu.append(this.devicedatapushConfig.getHttpDevice());
	sbu.append("://").append(this.devicedatapushConfig.getHttpIp()).append(":");
	sbu.append(this.devicedatapushConfig.getHttpPort()).append("/");
	String deviceurl = new String(sbu);
	// httpclient 推送数据(http1.1, 支持keep-alive选项)
	try{
		if(coorList != null && coorList.size()>0){
			//String deviceurl = this.devicedatapushConfig.getHttpDevice()+"://"+this.devicedatapushConfig.getHttpIp()+":"+this.devicedatapushConfig.getHttpPort()+"/";
			String jsonData="";
			for(MessageBean messageBean : coorList){
				if(messageBean==null){
					continue;
				}
				int msgType = messageBean.getMsgType();
				if(msgType==0){
					jsonData = messageBean.getJsonData();
					deviceurl += this.devicedatapushConfig.getDevicebaseUrl();                                                        
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}else if(msgType==1){
					jsonData = messageBean.getJsonData();
					deviceurl += this.devicedatapushConfig.getDevicetestdataUrl();
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}else if(msgType==2){
					jsonData = messageBean.getJsonData();
					deviceurl += this.devicedatapushConfig.getDevicedatamodelUrl();
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}
				
			}
		}
				
	}catch(Exception e){
		logger.error("[*@@*]push coords failed: url=", e);
	}
}
private void pushLocData(List<MessageBean> coorList) {
	StringBuffer sbu = new StringBuffer();
	sbu.append(this.devicedatapushConfig.getHttpDevice());
	sbu.append("://").append(this.devicedatapushConfig.getHttpIp()).append(":");
	sbu.append(this.devicedatapushConfig.getHttpPort()).append("/");
	// httpclient 推送数据(http1.1, 支持keep-alive选项)
	try{
		if(coorList != null && coorList.size()>0){
			String jsonData="";
			for(MessageBean messageBean : coorList){
				if(messageBean==null){
					continue;
				}
				int msgType = messageBean.getMsgType();
				if(msgType==0){
					jsonData = messageBean.getJsonData();
					sbu.append(this.devicedatapushConfig.getDevicebaseUrl());
					String deviceurl = new String(sbu);                                                        
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}else if(msgType==1){
					jsonData = messageBean.getJsonData();
					sbu.append(this.devicedatapushConfig.getDevicetestdataUrl());
					String deviceurl = new String(sbu); 
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}else if(msgType==2){
					jsonData = messageBean.getJsonData();
					sbu.append(this.devicedatapushConfig.getDevicedatamodelUrl());
					String deviceurl = new String(sbu);
					HttpClientUtils.sendHttpPostJson(deviceurl, jsonData, null);
					logger.info("[*^_^*]Push locCoordiate data ok: url="+deviceurl+", coords="+jsonData);
				}
				
			}
		}
				
	}catch(Exception e){
		logger.error("[*@@*]push coords failed: url=", e);
	}
}

 

 

### StringBuffer 的基本概念 `StringBuffer` 是 Java 中的一个类,用于处理可变字符串。与 `String` 不同的是,`String` 类的对象一旦创建便不可更改(即它们是不可变的),而 `StringBuffer` 对象的内容可以随时修改[^3]。 以下是关于 `StringBuffer` 的一些重要特性: - 它是一个线程安全的可变字符序列。 - 所有操作都会同步执行,因此适合在多线程环境中使用。 - 提供了许多方法来操作字符串内容,比如追加、删除、替换以及反转等。 ### 创建和初始化 StringBuffer 可以通过多种方式创建一个 `StringBuffer` 实例: ```java // 使用无参构造函数创建空的 StringBuffer StringBuffer sb1 = new StringBuffer(); // 使用带有初始容量的构造函数 StringBuffer sb2 = new StringBuffer(16); // 使用指定字符串作为初始值 StringBuffer sb3 = new StringBuffer("Hello"); ``` 以上代码展示了如何通过不同的构造器来实例化 `StringBuffer` 对象[^4]。 ### 常见的操作方法 #### 追加数据 (`append`) `append()` 方法允许向现有的 `StringBuffer` 对象后面添加新的数据片段。 ```java StringBuffer buffer = new StringBuffer(); buffer.append("Java "); buffer.append("is "); buffer.append("fun!"); System.out.println(buffer); // 输出: Java is fun! ``` 此段代码演示了如何利用 `append()` 将多个部分连接成完整的句子[^5]。 #### 插入数据 (`insert`) 如果需要在一个特定位置插入新内容,则可以调用 `insert()` 方法。 ```java StringBuffer strBuf = new StringBuffer("Happy Birthday"); strBuf.insert(5, " New Year,"); System.out.println(strBuf.toString()); // Happy New Year, Birthday ``` 这里说明了怎样把 “New Year,” 放置到原字符串中间的位置上[^6]。 #### 删除子串 (`delete`) 当要移除某一段连续区域内的字符时,可以选择 `delete(startIndex,endIndex)` 函数实现这一目标。 ```java StringBuffer sbuf = new StringBuffer("0123456789"); sbuf.delete(3, 6); System.out.println(sbuf); // 结果为:0123789 ``` 上述例子清楚地表明从索引 3 到索引 5 被成功去除了[^7]。 #### 替换子串 (`replace`) 为了替换成另外一组字符集合,应该采用 `replace(indexStart,indexEnd,String)` 方式完成更新过程。 ```java StringBuffer sampleStrBuff = new StringBuffer("abcdefg"); sampleStrBuff.replace(2, 5, "XYZ"); System.out.println(sampleStrBuff); // abcXYZfg ``` 这段程序解释了如何将原始字符串中的某些字母更换成了其他符号[^8]。 #### 反转顺序 (`reverse`) 最后介绍一种非常实用的功能——翻转整个字符串的方向布局。 ```java StringBuffer reverseExample = new StringBuilder("hello world").reverse(); System.out.println(reverseExample); // dlrow olleh ``` 注意这里是用了 `StringBuilder`, 因为它也支持同样的功能而且性能更优如果没有考虑线程安全性的话[^9]. ### 性能考量 尽管 `StringBuffer` 非常强大并提供了丰富的 API 接口,但由于其内部实现了同步机制,在单线程环境下可能不如它的兄弟类 `StringBuilder` 效率高。所以在开发过程中需权衡两者之间的差异再做决定[^10]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZHOU_VIP

您的鼓励将是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值