Android,使用Json发送数据中,使用的Java转义字符 KanKan原创

Android,使用Json发送数据中,使用的Java转义字符 KanKan原创

大家好,又见面了,我是全栈君。

kankan原创

与php后台发送数据的时候。要求用到这样的格式。

private void sendJson(){

                //初始化自己定义的handler

CashHandler handler = new CashHandler(this);

                //请求主地址。写在自己定义Application中了,后面是接口名字
String url = MApplication.get().getAppServiceUrl() + “order/submit”;

                //自己定义的发送请求方法
LReqEntity entity = new LReqEntity();
entity.setUrl(url);
                 //Lreqentity中,post方法。传參数的格式是Map(String,String)

        Map<String, String> map = new HashMap<String, String>();

                 //拼接字符串

StringBuffer params = new StringBuffer();


// 从积分商城的提交 JUMPKEY是7,则是从积分商城购买

if (JUMPKEY.equals(“7”)) {

                 //dbmanager是自己定义数据库查询方法。查询的是购物车终于购买的订单

List<CarteEntity> cartList = DBManager.get().queryFinalCarte(

userEntity.id);

                 //拼接字符串

params.append(“[“);


for (int i = 0; i < cartList.size(); i++) {


CarteEntity scoreEntity = new CarteEntity();

scoreEntity = cartList.get(i);

                     //下一行就是转义字符。为了发送时候,拼接出来“这个字符,用了转义字符  \”

                      //这样发送效果就是       {“A”:54}

params.append(“{\”A\”:”);


params.append(scoreEntity.id + “”);


params.append(“,”);


params.append(“\”B\”:”);


params.append(scoreEntity.buyCount);


params.append(“,”);


params.append(“\”C\”:”);


params.append(“\”score\”}”);


if (i < cartList.size() – 1) {


params.append(“,”);


}


}


params.append(“]”);

        entity.setParams(map);
entity.setReqMode(ReqMothed.POST);

handler.startLoadingData(entity);

}

这样,达到了拼接要求的效果。http://192.168.100.180:85/service/order/submit?{A=[{“A”:95,”B”:3,”C”:”score”},{“A”:99,”B”:3,”C”:”score”}], B=89}

有关转义字符,内容非常多。

 JAVA中转义字符:

最多的就是第一条了

1.特殊字符:就3个 
\”:双引號 
\’:单引號 
\\:反斜线 




2.八进制转义序列:\ + 1到3位5数字。范围’\000’~’\377′ 
\0:空字符 
3.Unicode转义字符:\u + 四个十六进制数字;0~65535 
\u0000:空字符 

4.控制字符:5个

\’ 单引號字符

\\ 反斜杠字符

\r 回车

\n 换行

\f 走纸换页

\t 横向跳格

\b 退格

点的转义:. ==> u002E 
美元符号的转义:$ ==> u0024 
乘方符号的转义:^ ==> u005E 
左大括号的转义:{ ==> u007B 
左方括号的转义:[ ==> u005B 
左圆括号的转义:( ==> u0028 
竖线的转义:| ==> u007C 
右圆括号的转义:) ==> u0029 
星号的转义:* ==> u002A 
加号的转义:+ ==> u002B 
问号的转义:? ==> u003F 
反斜杠的转义: ==> u005C 
====================================================================== 
以下的程序使用了两个Unicode的转义字符,它们是用其十六进制代码来表示Unicode字符。

那么,这个程序会打印什么呢?
Java代码 
public class EscapeRout{   
public static void main(String[] args){   
// \u0022 是双引號的Unicode转义字符   
System.out.println(“a\u0022.length()   
+\u0022b”.length());   
}   

public class EscapeRout{ 
public static void main(String[] args){ 
// \u0022 是双引號的Unicode转义字符 
System.out.println(“a\u0022.length() 
+\u0022b”.length()); 

}

对该程序的一种非常肤浅的分析会觉得它应该打印出26,由于在由两个双引號”a\u0022.length()+\u0022b”标识的字符串之间总共同拥有26个字符。 
略微深入一点的分析会觉得该程序应该打印16,由于两个Unicode转义字符每个在源文件里都须要用6个字符来表示。可是它们仅仅表示字符串中 的一个字符。因此这个字符串应该比它的外表看其来要短10个字符。 假设你执行这个程序,就会发现事情远不是这么回事。

它打印的既不是26也不是16。而是2。

理解这个谜题的关键是要知道:Java对在字符串字面常量中的Unicode转义字符没有提供不论什么特殊处理。编译器在将程序解析成各种符号之前, 先将Unicode转义字符转换成为它们所表示的字符[JLS 3.2]。因此,程序中的第一个Unicode转义字符将作为一个单字符字符串字面常量(”a”)的结束引號。而第二个Unicode转义字符将作为还有一 个单字符字符串字面常量(”b”)的開始引號。

程序打印的是表达式”a”.length()+”b”.length(),即2。

假设该程序的作者确实希望得到这样的行为,那么以下的语句将要清楚得多:

Java代码 
System.out.println(“a”.length()+”b”.length()); 

更有可能的情况是该作者希望将两个双引號字符置于字符串字面常量的内部。

使用Unicode转义字符你是不能实现这一点的,可是你能够使用转义字 符序列来实现[JLS 3.10.6]。表示一个双引號的转义字符序列是一个反斜杠后面紧跟着一个双引號(\”)。假设将最初的程序中的Unicode转义字符用转义字符序列来 替换,那么它将打印出所期望的16(错误,应该是14。不知道是怎么会出来16):

Java代码 
System.out.println(“a\”.length()+\”b”.length());

很多字符都有对应的转义字符序列,包含单引號(\’)、换行(\n)、制表符(\t)和反斜线(\\)。你能够在字符字面常量和字符串字面常量中使用转义字符序列。

 
实际上。你能够通过使用被称为八进制转义字符的特殊类型的转义字符序列,将不论什么ASCII字符置于一个字符串字面常量或一个字符字面常量中,可是最好是尽可能地使用普通的转义字符序列。

普通的转义字符序列和八进制转义字符都比Unicode转义字符要好得多,由于与Unicode转义字符不同,转义字符序列是在程序被解析为各种符号之后被处理的。

ASCII是字符集的最小公共特性集。它仅仅有128个字符,可是Unicode有超过65,000个字符。一个Unicode转义字符能够被用来在仅仅使用ASCII字符的程序中插入一个Unicode字符。一个Unicode转义字符精确地等价于它所表示的字符。

Unicode转义字符被设计为用于在程序猿须要插入一个不能用源文件字符集表示的字符的情况。它们主要用于将非ASCII字符置于标识符、字符 串字面常量、字符字面常量以及凝视中。

偶尔地,Unicode转义字符也被用来在看起来颇为相似的数个字符中明白地标识当中的某一个。从而添加程序的清晰 度。

总之,在字符串和字符字面常量中要优先选择的是转义字符序列。而不是Unicode转义字符。Unicode转义字符可能会由于它们在编译序列中 被处理得过早而引起混乱。不要使用Unicode转义字符来表示ASCII字符。

在字符串和字符字面常量中。应该使用转义字符序列;对于除这些字面常量之 外的情况,应该直接将ASCII字符插入到源文件里。

 

 

 

转义序列 含义 
\n 回车(\u000a) 
\t 水平制表符(\u0009) 
\b 空格(\u0008) 
\r 换行(\u000d) 
\f 换页(\u000c) 
\’ 单引號(\u0027) 
\” 双引號(\u0022) 
\\ 反斜杠(\u005c) 
\ddd 三位八进制 
\udddd 四位十六进制 
JAVA中转义字符: 
1.八进制转义序列:
\ + 1到3位5数字;范围’\000’~’\377′ 
\0:空字符 
2.Unicode转义字符:
\u + 四个十六进制数字;0~65535 
\u0000:空字符 
八进制的是1到3个数字并且注意数值范围,假设超了范围也会编译错误的,而十六进制的转义必须是4个十六进制数字。并且有一些无法转义,如’\u000a’。无法转移,会出现编译错误,并且相当多的数字没有相应的字符,仅仅会转义成问号 而对于数字的转义,仅仅要不超过范围既能够了。

 
3.特殊字符:就3个 \”:双引號 \’:单引號 \\:反斜线 
4.控制字符:5个 \’ 单引號字符 \\ 反斜杠字符 \r 回车 \n 换行 \f 走纸换页 \t 横向跳格 \b 退格 
点的转义:. ==> u002E 
美元符号的转义:$ ==> u0024 
乘方符号的转义:^ ==> u005E 
左大括号的转义:{ ==> u007B 
左方括号的转义:[ ==> u005B 
左圆括号的转义:( ==> u0028 
竖线的转义:| ==> u007C 
右圆括号的转义:) ==> u0029 
星号的转义:* ==> u002A 
加号的转义:+ ==> u002B 
问号的转义:? ==> u003F 
反斜杠的转义: ==> u005C

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/115833.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Retrofit2.0 请求数据 一直出返回网络错误,错误代码 414

    Retrofit2.0 请求数据 一直出返回网络错误,错误代码 414今天使用rettorfit去请求数据一直不成功,请求逻辑上以及请求参数上都没有问题,后台也验证过是通的(我用xutils3请求也是成功的,后来意识到xutils3是将参数放在请求体里面),但是就是一直不能请求成功,后来终于发现还是参数的问题。由于使用的是retrofitPOST请求,查询字段用的是@QueryMap,而这个查询时是直接拼接在url的后面,但是url的请求接口是有长度限制的…

  • keypad 按键显示

    keypad 按键显示main.c#include”config.h”//矩阵按键扫描头文件#include”anjian.h”//1602显示头文件#include”1602.h”#include”music.h”sbitLED=P1^0;u8codekey[]={‘0′,’1′,’2′,’3′,’4′,’5′,’6′,’7′,’8′,’9′,’*’,’#’};//3*4手机拨号键盘号码u8

  • idea 2021 2.3 激活码_在线激活

    (idea 2021 2.3 激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html…

  • Navicat 连接MySQL数据库出现错误:2059

    Navicat 连接MySQL数据库出现错误:2059Navicat连接MySQL数据库出现错误:2059-authenticationplugin’caching_sha2_password’的解决方法

  • sigaction介绍

    sigaction介绍sigaction原型:intsigaction(intsigno,conststructsigaction*restrictact,structsigaction*restrictoact);@signo信号编号@act要注册的信号动作@oact原信号动作

  • 柯西变异和自适应权重优化的蝴蝶算法[通俗易懂]

    柯西变异和自适应权重优化的蝴蝶算法[通俗易懂]文章目录一、理论基础1、蝴蝶优化算法2、改进的蝴蝶优化算法(1)柯西变异(2)自适应权重(3)动态切换概率策略(4)算法描述二、函数测试与结果分析三、参考文献四、Matlab仿真程序一、理论基础1、蝴蝶优化算法请参考这里。2、改进的蝴蝶优化算法为了改进蝴蝶算法容易陷入局部最优和收敛精度低的问题,本文从三个方面对蝴蝶算法进行改进。首先通过引入柯西分布函数的方法对全局搜索的蝴蝶位置信息进行变异,提高蝴蝶的全局搜索能力;其次通过引入自适应权重因子来提高蝴蝶的局部搜索能力;最后采用动态切换概率ppp平衡算

    2022年10月26日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号