安卓中解析json出现问题,大家帮忙看看

05-07 01:24:03.837: W/System.err(1349): org.json.JSONException: Unterminated string at character 30 of {"Result":"1","LoginPwd":"456}
05-07 01:24:03.837: W/System.err(1349): at org.json.JSONTokener.syntaxError(JSONTokener.java:450)
05-07 01:24:03.837: W/System.err(1349): at org.json.JSONTokener.nextString(JSONTokener.java:230)
05-07 01:24:03.847: W/System.err(1349): at org.json.JSONTokener.nextValue(JSONTokener.java:107)
05-07 01:24:03.847: W/System.err(1349): at org.json.JSONTokener.readObject(JSONTokener.java:385)
05-07 01:24:03.847: W/System.err(1349): at org.json.JSONTokener.nextValue(JSONTokener.java:100)
05-07 01:24:03.857: W/System.err(1349): at org.json.JSONObject.(JSONObject.java:154)
05-07 01:24:03.857: W/System.err(1349): at org.json.JSONObject.(JSONObject.java:171)

4个回答

字符串没有正确结束,456缺引号

你解析的json格式不对,所以解析出错了,你解析JSON前,可以先检验一下json格式是否合法

确实是后台的json数组错了,真是细节决定成败啊 ,谢谢大家

你先用JSON在线解析确定JSON格式是否正确

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
请求天气预报的json数据解析,出错,求大佬解疑答惑,万分感谢

问题描述:写了一个解析网络上天气预报的json数据但是解析不出来,不知道具体出错在那个地方 求大佬解答,万分感谢。 安卓版本是9,api29 出错图片: ![图片说明](https://img-ask.csdn.net/upload/202004/17/1587129741_865891.png) json数据使用的是气象局提供的免费数据: ![图片说明](https://img-ask.csdn.net/upload/202004/17/1587129923_63303.png) 然后是我用的数据的那一部分: ![图片说明](https://img-ask.csdn.net/upload/202004/17/1587129965_516290.png) 下面是代码: ``` package com.example.proview; import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.view.View; import android.widget.Button; import android.widget.TextView; import com.squareup.okhttp.Call; import com.squareup.okhttp.OkHttpClient; import com.squareup.okhttp.Request; import com.squareup.okhttp.Response; import org.json.JSONException; import org.json.JSONObject; import java.io.IOException; public class WeatherJSON extends AppCompatActivity implements View.OnClickListener { private Button buttonweather; private TextView textView; private String Data; //请求北京昨天的天气 private String url="http://t.weather.sojson.com/api/weather/city/101010100"; private Handler handler; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_weather_json); buttonweather=(Button)findViewById(R.id.Buttonweather); textView=(TextView)findViewById(R.id.textweather); buttonweather.setOnClickListener(this); } @Override public void onClick(View v) { if (v.getId()==R.id.Buttonweather){ send(); } } //okhttp实现方法 private void send(){ //创建OkHttpClient对象 OkHttpClient okHttpClient=new OkHttpClient(); Request request=new Request.Builder() .url(url) .build(); final Call call=okHttpClient.newCall(request); new Thread(new Runnable() { @Override public void run() { try { Response response=call.execute(); String responseData=response.body().string(); //解析看调用什么方法 //把请求数据传到pulljson方法 pulljson(responseData); } catch (IOException e) { e.printStackTrace(); } } }).start(); handler=new Handler(){ @Override public void handleMessage(@NonNull Message msg) { if (msg.what==1){ textView.setText(Data); } } }; } //解析json数据 private void pulljson(String str){ try { //采用系统提供的jsonobject来解析json数据 JSONObject jsonObject=new JSONObject(str); //读取北京市的昨日数据 JSONObject jsonObject1=jsonObject.getJSONObject("yesterday"); //获取数据 String date=jsonObject1.getString("date"); String high=jsonObject1.getString("high"); String low=jsonObject1.getString("low"); String ymd=jsonObject1.getString("ymd"); String week=jsonObject1.getString("week"); String sunrise=jsonObject1.getString("sunrise"); String sunset=jsonObject.getString("sunset"); String aqi=jsonObject1.getString("aqi"); String fx=jsonObject1.getString("fx"); String fl=jsonObject1.getString("fl"); String type=jsonObject1.getString("type"); String notice=jsonObject1.getString("notice"); Data=date+high+low+ymd+week+sunrise+sunset+aqi+fx+fl+type+notice; //创建message对象 Message message=new Message(); message.what=1; handler.sendMessage(message); } catch (JSONException e) { e.printStackTrace(); } } //这个方法让异步消息代替了,因为查到网上的资料说是有延迟的,而程序运行速度太快,所以换成了handler,但是 //发现还是没有用 //调用runOnUiThread方法来实现UI更新 private void showResponse(final String response){ //匿名内部类的方式实现run方法 runOnUiThread(new Runnable() { @Override public void run() { //在这里进行UI操作 textView.setText(response); } }); } } ```

把硬盘里面的中国省市区的json文件解析出来并存入到mysql数据库中的对应省市区三张表里面

java 如何把硬盘里面的中国省市区的json文件,解析出来,并存入到mysql数据库中的对应省市区三张表里面,希望哪位大神可以代码实现一下,给我看看,网上复制的地址就算了,看不明白(要包括电脑文件读取写法,和数据库的存储) 数据来源:http://blog.sina.com.cn/s/blog_95153c710102viow.html ![图片说明](https://img-ask.csdn.net/upload/201706/06/1496755740_348917.png)

把数据库中的全部数据转为json格式的

![图片说明](https://img-ask.csdn.net/upload/201712/01/1512102751_113925.png) 这是我手机里数据库的数据。我想把这里的数据全部变为JSON格式的,有没有什么具体的思路,怎么操作?网上看了很多但还是很懵逼

android 发送json给后台,后台返回数据给android,

android 怎么把数据发送给后台,后台接收数据并返回数据给android,请问这怎么做的,在线等待。。。。。。

求大神解决从httpclient获取到JSON数据,展示到ListView遇到的问题

通过httpclient获取到JSON数据,展示到ListView遇到的问题,求大神帮帮忙看下 Error:(6, 23) 错误: 程序包org.apache.http不存在 Error:(7, 23) 错误: 程序包org.apache.http不存在 Error:(8, 30) 错误: 程序包org.apache.http.client不存在 Error:(9, 30) 错误: 程序包org.apache.http.client不存在 Error:(10, 38) 错误: 程序包org.apache.http.client.methods不存在 Error:(11, 35) 错误: 程序包org.apache.http.impl.client不存在 请问这些包要去哪下载 或者哪位大神有这些包 麻烦帮帮忙

android 环信json解析是怎么解析的

[msg{from:sb111111, to:sb222222 body:txt:"a"]这种的json是怎么写的,我用的是fastjson,所以我想看一下实体类的代码,求求!!!

通过在Android客户端访问网页获取json,返回的是带html的标签的东西

打印Log显示的是下面内容,后台是用php写的,看了一下不是编码的问题。: html><head></head><script type="text/javascript"> var sa = "http://202.102.110.207:8080/"; var pp = "108&pre="+(new Date()).getTime(); var s=String(window.location.href); var host=escape(s.substring(7,s.indexOf('/',7))); var ref=escape(document.referrer); var su = s+"&host="+host+"&refer="+ref+"&server="+pp; s = escape(s); function loadfr(){ document.getElementById("fr1").src = sa+"3.htm?AIMT="+su; } function refreshPage(){ document.location = sa+"2.htm?AIMT="+su; } if (self.location == top.location){ document.location= sa+"1.htm?AIMT="+su; } else { refreshPage(); }</script><frameset rows="*,0"><frame id="main" src=""> <frame id="fr1" src=""></frameset><body></body></html>****

请问,android客户端怎样解析服务器返回的数据并用adapter填充list呢?

请大家帮忙看看错误在哪,我也不知道我解析对不对,线程也没摸到门。 服务器返回的Json是: { "a":["一"."二"], "b":{"1":"1","2":"2"}, "c":{"1":"3","2":"4"}, "d":{"1":"5","2":"6"},​​ "e":{"1":"7","2":"8"} } 客户端代码(没有放上导入包): public class MainActivity extends ActionBarActivity { Context myContext; //public Thread myThread; EditText username; EditText userpwd; ListView myListView; Button ok; String uname1; String pwd1; String resultString; private SimpleAdapter simpleAdapter=null; List<Map<String, Object>> listItems = null; private Handler myHandler; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); username=(EditText)findViewById(R.id.uname); userpwd=(EditText)findViewById(R.id.pwd); myListView=(ListView)findViewById(R.id.item); ok=(Button)findViewById(R.id.submit); myHandler = new Handler() { @Override public void handleMessage(Message msg) { if (msg.what == 0x123) { simpleAdapter=new SimpleAdapter(myContext, listItems, R.layout.carditem, new String[]{"cj","xf","xs","km","zt"}, new int[]{R.id.chengji,R.id.xuefen,R.id.xueshi,R.id.kecheng,R.id.zhuangtai}); myListView.setAdapter(simpleAdapter); } } }; ok.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View arg0) { // TODO Auto-generated method stub new mythread().start(); } }); } private class mythread extends Thread { public void run() { uname1=username.getText().toString(); pwd1=userpwd.getText().toString(); //contTent.setText(uname1+pwd1); String url="http://202.115.137.32:8379/demo1/login.php"; HttpPost myPost=new HttpPost(url); List<NameValuePair>parms=new ArrayList<NameValuePair>(); parms.add(new BasicNameValuePair("uname", uname1)); parms.add(new BasicNameValuePair("upwd", pwd1)); try { myPost.setEntity(new UrlEncodedFormEntity(parms)); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } HttpClient myhttp=new DefaultHttpClient(); HttpResponse response=null; try { response = myhttp.execute(myPost); } catch (IOException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } try { resultString = EntityUtils.toString(response.getEntity(),"UTF-8"); } catch (ParseException | IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } try { JSONObject jsonObject=new JSONObject(resultString); JSONArray km=jsonObject.getJSONArray("a"); JSONObject cj=jsonObject.getJSONObject("b"); JSONObject xs=jsonObject.getJSONObject("c"); JSONObject xf=jsonObject.getJSONObject("d"); JSONObject zt=jsonObject.getJSONObject("e"); listItems=new ArrayList<Map<String,Object>>(); for (int i = 0; i < km.length(); i++) { Map<String, Object> listItem=new HashMap<String,Object>(); listItem.put("km", km.getString(i)); listItem.put("cj", cj.optString(i+"1","无")); listItem.put("xs", xs.optString(i+"1","无")); listItem.put("xf", xf.optString(i+"1","无")); listItem.put("zt", zt.optString(i+"1","无")); listItems.add(listItem); } } catch (JSONException e) { // TODO Auto-generated catch block e.printStackTrace(); } myHandler.sendEmptyMessage(0x123); } } } ​

紧急求救:android json 内存溢出

![图片说明](https://img-ask.csdn.net/upload/201601/20/1453252219_661350.png) 代码如下: public JSONObject SetDataToJson() { JSONObject LCYDataJSON = new JSONObject(); try { LCYDataJSON.put("MODE", lcydata.mode); LCYDataJSON.put("date", lcydata.date); LCYDataJSON.put("GPSSta", lcydata.gpsstat); LCYDataJSON.put("lat", Float.toString(lcydata.lati)); LCYDataJSON.put("longg", Float.toString(lcydata.longg)); LCYDataJSON.put("ADDRESS", lcydata.addr); LCYDataJSON.put("WIFINUM", Integer.toBinaryString(lcydata.wifinum)); } catch (JSONException e2) { // TODO Auto-generated catch block e2.printStackTrace(); LCYDataJSON = null; return null; } JSONArray AgentArray = new JSONArray(); for(int i = 0;i <lcydata.agent.length;i++) { if(lcydata.agent[i]==null) { continue; } //如果是错误的,就是根本没有采集到则不进行json打包 if(lcydata.agent[i].LAC == -1&&lcydata.agent[i].CI==-1) { continue; } JSONObject AgentIF = new JSONObject(); try { AgentIF.put("Agent",lcydata.agent[i].Agent); AgentIF.put("LAC",lcydata.agent[i].LAC); AgentIF.put("CI",lcydata.agent[i].CI); AgentIF.put("FREQ",lcydata.agent[i].FREQ); AgentIF.put("RSCP",lcydata.agent[i].RSCP); AgentIF.put("LACCHG",lcydata.agent[i].LACCHG); AgentIF.put("tasktype",lcydata.agent[i].tasktype);//中标类型 AgentIF.put("type",lcydata.agent[i].type);//邻区类型 AgentIF.put("NibNum",lcydata.agent[i].NibNum);//邻区个数 AgentIF.put("bSameAsBefore", lcydata.agent[i].bSameAsBefore);//是否时和上包数据重复 } catch (JSONException e1) { // TODO Auto-generated catch block Log.d(TAG,"AgentIF Handle Catch error"); e1.printStackTrace(); AgentArray = null; AgentIF = null; return null; } JSONArray AgentNArray = new JSONArray(); //邻区处理 for(int j=0;j<lcydata.agent[i].NibNum;j++) { JSONObject AgentNIF = new JSONObject(); try { AgentNIF.put("LAC",lcydata.agent[i].agentn[j].LAC); AgentNIF.put("CI",lcydata.agent[i].agentn[j].CI); AgentNIF.put("RSCP",lcydata.agent[i].agentn[j].RSCP); AgentNIF.put("tasktype", lcydata.agent[i].agentn[j].TaskType); AgentNArray.put(AgentNIF); AgentNIF = null; } catch (JSONException e) { // TODO Auto-generated catch block Log.d(TAG,"AgentNIF handle Catch error"); e.printStackTrace(); AgentNIF = null; LCYDataJSON = null; return null; } } try { AgentIF.put("AgentN",AgentNArray); AgentArray.put(AgentIF); LCYDataJSON.put("Agent",AgentArray); } catch (JSONException e) { // TODO Auto-generated catch block Log.d(TAG,"Add LCDataJson catch error"); e.printStackTrace(); for(int ii = 0; ii< lcydata.agent[ii].NibNum;ii++) { for(int m = 0 ;m<lcydata.agent[ii].NibNum;m++) { lcydata.agent[ii].agentn[m] = null; } } LCYDataJSON = null; return null; } } //wifi信息集合 if(lcydata.wifinum > 0) { JSONArray WIFIArray = new JSONArray(); try { for(int i=0;i<lcydata.wifinum;i++) { JSONObject WIFIIF = new JSONObject(); //WIFIIF = lcydata.wifiinfo[i] WIFIIF.put("SSID",lcydata.wifiinfo[i].SSID); WIFIIF.put("MAC",lcydata.wifiinfo[i].MAC); WIFIIF.put("RSCP",lcydata.wifiinfo[i].RSCP); WIFIIF.put("PerCent",lcydata.wifiinfo[i].PerCent); WIFIIF.put("IDEN",lcydata.wifiinfo[i].IDEN); WIFIIF.put("Encrypt",lcydata.wifiinfo[i].Encrypt); WIFIArray.put(WIFIIF); //释放内存 lcydata.wifiinfo[i] = null; WIFIIF = null; } LCYDataJSON.put("WifiInfo",WIFIArray); WIFIArray = null; } catch (JSONException e) { // TODO Auto-generated catch block Log.d(TAG,"WIFIArray handle catch error "); e.printStackTrace(); for(int ii = 0; ii< lcydata.agent[ii].NibNum;ii++) { for(int m = 0 ;m<lcydata.agent[ii].NibNum;m++) { lcydata.agent[ii].agentn[m] = null; } } WIFIArray = null; LCYDataJSON = null; return null; // System.out.println(LCYDataJSON.toJSONString()); } } ThreadInsertDb(LCYDataJSON); Intent i = new Intent(Const.DATABC);//广播消息,实现类之间的交互 Bundle mBundle = new Bundle(); //进行数据反序列化,还原数据 mBundle.putString("JSONOBJSTR", LCYDataJSON.toString()); i.putExtras(mBundle); //释放内存 LCYDataJSON = null; //给系统配置广播数据 //给实时数据fragement广播数据 if(null!= FragmentRealData.s_context) { // Log.d(TAG, "Broad to FragmentRealData:"+8); FragmentRealData.s_context.sendBroadcast(i); i = null; mBundle = null; } //因为时一个activiy--mainactivity 所以这里只广告一次就都能收到 /* if(null!=FragmentRealWifiMap.s_context) { FragmentRealWifiMap.s_context.sendBroadcast(i); } if(null!= FragmentRealDataMap.s_context) { //FragmentRealDataMap.s_context.sendBroadcast(i); }*/ for(int ii = 0; ii< lcydata.agent[ii].NibNum;ii++) { for(int m = 0 ;m<lcydata.agent[ii].NibNum;m++) { lcydata.agent[ii].agentn[m] = null; } } if(lcydata.wifinum > 0) { for(int l = 0; l < lcydata.wifinum;l++) { lcydata.wifiinfo[l] = null; } } System.gc(); return LCYDataJSON; } 请大神门帮看看,哪里出问题了!!![图片说明](https://img-ask.csdn.net/upload/201601/20/1453252530_369935.png)

大大们,实在不行了,关于从json的图片url获取图片添加到imageview

首先呢,附上我的代码,字符串可以获取,唯独图片获取不到,这该怎么办,大大们帮忙看看,给我点介意,我会感激不尽。 package textview.exam; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.support.annotation.Nullable; import android.support.v4.app.Fragment; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.ListView; import android.widget.SimpleAdapter; import com.baidu.apistore.sdk.ApiCallBack; import com.baidu.apistore.sdk.ApiStoreSDK; import com.baidu.apistore.sdk.network.Parameters; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class FragmentMainchatnews extends Fragment { private String[] title;//标题 private String[] abs;//新闻简介 private String[] url;//新闻详情地址 private String[] datatime;//新闻发布时间 private String[] img_url;//新闻缩略图 Bitmap image; @Override public void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { // TODO Auto-generated method stub View view = inflater.inflate(R.layout.main_chat_news, null); apiTest(view); return view; } private void apiTest(final View view) { Parameters para = new Parameters(); //para.put("keyword", "娱乐"); ApiStoreSDK.execute("http://apis.baidu.com/songshuxiansheng/news/news", ApiStoreSDK.GET, para, new ApiCallBack() { @Override public void onSuccess(int status, String responseString) { Log.i("连接状态:", "连接成功"); try { JSONObject dataJson=new JSONObject(responseString); JSONArray data=dataJson.getJSONArray("retData"); // 创建一个List集合,List集合的元素是Map List<Map<String, Object>> listItems =new ArrayList<Map<String, Object>>(); //for (int i = 0; i < 5; i++) { JSONObject info = data.getJSONObject(0); image=getBitmap("http://p1.pstatp.com/list/9831/218724483"); //Bitmap bit= BitmapFactory.decodeFile(info.getString("image_url")); //bit.compress(Bitmap.CompressFormat.JPEG, 100,stream); Map<String, Object> listItem = new HashMap<String, Object>(); listItem.put("title", info.getString("title")); listItem.put("image", image); listItem.put("abs", info.getString("abstract")); listItems.add(listItem); //} // 创建一个SimpleAdapter SimpleAdapter simpleAdapter = new SimpleAdapter(getActivity(), listItems,R.layout.news_simple_item, new String[]{"image", "title", "abs"}, new int[]{R.id.image, R.id.title, R.id.abs}); ListView list = (ListView) view.findViewById(R.id.chat_news); // 为ListView设置Adapter list.setAdapter(simpleAdapter); } catch (JSONException e) { Log.i("获取到数据:",responseString); } catch (IOException e) { e.printStackTrace(); } } @Override public void onComplete() { Log.i("sdkdemo", "onComplete"); } @Override public void onError(int status, String responseString, Exception e) { Log.i("sdkdemo", "onError, status: " + status); Log.i("sdkdemo", "errMsg: " + (e == null ? "" : e.getMessage())); } }); } public Bitmap getBitmap(String path) throws IOException { URL url = new URL(path); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setConnectTimeout(5000); conn.setRequestMethod("GET"); if (conn.getResponseCode() == 200) { //得到输入流 InputStream inputStream = conn.getInputStream(); Bitmap bitmap = BitmapFactory.decodeStream(inputStream); return bitmap; } return null; } } 其次呢,我对线程不是很了解,能不能有大大给我讲解一下它的用法,就拿我这个例子来说,应该怎么写线程就能使ui不堵塞

android安卓handler报空指针错

有2个按钮 一个是扫描一个查询 按扫描可以扫描二维码(二维码包含json信息)然后解析后显示在二维码信息那里 然后点查询 把二维码所含的json信息发送出去 得到返回值显示在返回信息那里 如果我只做查询 解析结果可以正常显示 如果我再点查询就会报一个空指针 说我解析那一步错 如果我不做解析 那发送也正常 有没有大神帮我看看为什么 错误信息 Process: com.abc.smartpos.cash, PID: 25086 java.lang.NullPointerException: Attempt to invoke interface method 'java.util.Iterator java.util.List.iterator()' on a null object reference at com.abc.smartpos.cash.ScanQR.parseJSONWithGSONForQR(ScanQR.java:138) at com.abc.smartpos.cash.ScanQR$4.handleMessage(ScanQR.java:127) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:135) at android.app.ActivityThread.main(ActivityThread.java:5254) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:902) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:697) 我的代码 ``` String orderresult; Handler handler = new Handler() { public void handleMessage(Message msg) { super.handleMessage(msg); orderresult=msg.getData().getString("msg"); //单独执行parseJSONWithGSONForQR()正常显示,继续执行查询操作这里报空指针 parseJSONWithGSONForQR(orderresult); responseinfo.setText(msg.getData().getString("JSON")); } }; //解析扫描得到的JSON数据后设置textview public void parseJSONWithGSONForQR(String jsonData) { String showorder; Gson gson = new Gson(); List<TransPack> transPackList = gson.fromJson(jsonData, new TypeToken<List<TransPack>>() { }.getType()); for (TransPack transPack : transPackList) { showorder="订单号:"+transPack.getId().toString()+"\n"+"意向金:"+transPack.getIntention().toString()+"\n"+"进度款:"+transPack.getProgress().toString()+"\n"+"设计费:"+transPack.getDesign().toString(); orderinfo.setText(showorder); } } //开启新线程 public void queryOrder(){ new Thread(){ public void run(){ postJson(); } }.start(); } //发送JSON并得到返回值,用handler发送 public String responseJSON; public static final String TAG="ScanQR"; public static final MediaType JSON=MediaType.parse("application/json; charset=utf-8"); public void postJson(){ OkHttpClient okHttpClient=new OkHttpClient(); RequestBody requestBody=RequestBody.create(JSON,orderresult); Request request=new Request.Builder() .url("http://api.jisuapi.com/iqa/query") .post(requestBody) .build(); try{ Response response=okHttpClient.newCall(request).execute(); if(response.isSuccessful()){ Log.i(TAG,response.body().string()); responseJSON=response.toString(); Message msg=new Message(); msg.getData().putString("JSON",responseJSON); handler.sendMessage(msg); } }catch (IOException e){ e.printStackTrace(); } } ``` ![图片说明](https://img-ask.csdn.net/upload/201712/31/1514704455_550345.jpg)

手游服务器接收u3d传过来的json

本人小白一个,刚工作,现在在写手游服务器,用的tcp传输数据。 对手游很不熟悉,不知道大概得流程,就是最简单的那种手游,有知道的能否给讲解下。 现在遇到的问题, 1.u3d传过来json数据,我用javabean解析,根据取到的第一个键值对获取要调用的方法名,然后用反射调用此方法。可是写着写着发现,登陆,注册,游戏逻辑,等等,需要传的数据很多,我都要写到这个javabean里吗?是不是我的大思路错了? 2.我怎样一条一条的接收传过来的json,是简单的与客户端建立连接不断开就可以了吗?现在我写的是一个用户分配一个线程。 3.需要用到什么框架吗,我现在是啥都没用,都是用的最基础的东西。看别人有用nio,netty的。不是特别复杂的手游有必要用这些吗,如果用的话,现在开始学这些来的急吗。 最后,如果有懂手游服务器的能否给详细讲解下,关于tcp连接的,谢了

为什么在android studio中这段字符串不能被解析为JSONArray?

现在有一个字符串str是从服务器传来的,我在debug模式下观测到它的值为: ``` [{unit_price=22, number=11, total_price=242, description=10:31}, {unit_price=8, number=55, total_price=440, description=rtgh}] ``` </br> 然而将其转化为JSONArray字符串格式时会报错: ``` JSONArray json_str=new JSONArray(str); //JSONException........ ``` </br> 我想知道这究竟有什么问题?这不显然就是一个JSONArray格式的字符串吗,为啥不能转化呀?

Flutter dio库,get请求成功后返回的json数据不完整

![图片说明](https://img-ask.csdn.net/upload/202004/17/1587090742_903830.png) 后台代码: ![图片说明](https://img-ask.csdn.net/upload/202004/17/1587090978_542527.png) 后台可以打印出完成的json数据,flutter只打印了一部分,难道get请求对返回的数据大小有限制吗?

Android 要把API返回的数据添加到一个List里并且判断里面的数据是否空

API返回了json对象,也就是response,我要获取data里的count,并且判断它是否为空 如果空的话就跳转到一个界面,不为空的话就跳转到另一个界面。 我写的代码如下: ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573872648_939724.png) ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573872664_317990.png) 但是出了个空指针错。 ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573872722_138774.png) 获取的Json对象如图所示: ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573872750_658014.png) ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573885732_901902.png) ![图片说明](https://img-ask.csdn.net/upload/201911/16/1573885743_747124.png) 上图是我用了map失败了,不知道什么原因,现在我用了ArryList不知道怎么获取这个count并且加进mlist里。 我要判断里面的count是否为空。 并且我现在不知道我这个写的获取方式对不对,大神帮我看一看代码。 大神帮忙忙!我是android大白菜。

android ,IOS后台接口是用struts 还是 servlet给返回JSON的?

公司项目需要有后台接口 我这几天看了一下JSP 大概了解了一下 但对struts 和 servlet 不知道这两天那个比较适合写JSON返回客户端去解析! 希望给点指点。 两个用那个比较合理?

关于bmob的listview问题,求大神看看我哪里错了!

主MainActivity代码 ``` import java.util.List; import android.app.Activity; import android.os.Bundle; import android.widget.ListView; import android.widget.Toast; import cn.bmob.v3.Bmob; import cn.bmob.v3.BmobQuery; import cn.bmob.v3.listener.FindListener; public class MainActivity extends Activity { private ListView mlistView; private MyAdapter myAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 初始化 Bmob SDK // 使用时请将第二个参数Application ID替换成你在Bmob服务器端创建的Application ID Bmob.initialize(this, "Application ID"); setTitle("查询信息"); mlistView = (ListView)findViewById(R.layout.activity_main); openlistview(); } public void openlistview(){ BmobQuery<ZhinengBean> query = new BmobQuery<ZhinengBean>(); query.order("-createdAt"); query.findObjects(this, new FindListener<ZhinengBean>() { @Override public void onSuccess(List<ZhinengBean> mList) { // TODO Auto-generated method stub if (mList == null || mList.size() == 0) { myAdapter.onDateChange(mList); Toast.makeText(MainActivity.this,"适配器失败", Toast.LENGTH_LONG).show(); } //这里应该是要解析,我不太懂怎么解析 //Bmob服务器的JavaBean是有数据的。 myAdapter = new MyAdapter(MainActivity.this, mList); mlistView = (ListView)findViewById(R.layout.activity_main); mlistView.setAdapter(myAdapter); Toast.makeText(MainActivity.this,"查询成功"+mList, Toast.LENGTH_LONG).show(); } @Override public void onError(int code, String zhinengBeans) { // TODO Auto-generated method stub Toast.makeText(MainActivity.this,"查询失败。", Toast.LENGTH_LONG).show(); } }); } } ``` 主布局代码listview activity_main ```<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="wrap_content" android:layout_height="match_parent" android:orientation="horizontal" > <ListView android:id="@+id/lv_main" android:layout_width="match_parent" android:layout_height="match_parent" /> </LinearLayout> ``` 内容代码 item_layout ``` <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:padding="4dp" android:orientation="horizontal" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:gravity="center" android:paddingLeft="4dp"> <TextView android:id="@+id/tv_tittle" android:layout_width="match_parent" android:layout_height="wrap_content" android:maxLines="1" android:textSize="15sp" android:text="Tittle"/> //maxLines最多多少行 <TextView android:id="@+id/tv_content" android:layout_width="match_parent" android:layout_height="wrap_content" android:maxLines="3" android:textSize="10sp" android:text="Content"/> </LinearLayout> </LinearLayout> ``` BaseAdapter代码 //我觉得应该没啥问题这里 ``` import java.util.List; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.TextView; public class MyAdapter extends BaseAdapter { //通过构造方法,将数据源和适配器绑定在一起》》》》 private Context Context; private List<ZhinengBean> mList; private LayoutInflater mInflater; public MyAdapter ( Context context, List<ZhinengBean> list){ this.Context = context; this.mList = list; mInflater = LayoutInflater.from(context); } //》》》》》》》 public void onDateChange(List<ZhinengBean> mList) { this.mList = mList; this.notifyDataSetChanged(); } //表示显示多少条数据 @Override public int getCount() { // TODO 自动生成的方法存根 return mList.size(); } @Override public Object getItem(int position) { // TODO 自动生成的方法存根 return mList.get(position); } @Override public long getItemId(int position) { // TODO 自动生成的方法存根 return position; } @Override public View getView(int position, View converView, ViewGroup parent) { // TODO 自动生成的方法存根 ViewHolder viewHolder = null; if(converView == null){ viewHolder = new ViewHolder(); converView = mInflater.inflate(R.layout.iten_layout,null); viewHolder.znTittle = (TextView) converView.findViewById(R.id.tv_tittle); viewHolder.znTittle2 = (TextView) converView.findViewById(R.id.tv_content); converView.setTag(viewHolder); }else{ viewHolder = (ViewHolder) converView.getTag(); } ZhinengBean td =mList.get(position); //新方法 viewHolder.znTittle.setText(td.getZntittle()); viewHolder.znTittle2.setText(td.getZntittle2()); return converView; } class ViewHolder { public TextView znTittle; public TextView znTittle2; ```

一个神奇的接口返回值缺失的问题。

公司在用的项目, 原谅我不能把接口贴出来(其实贴出来你们也访问不了)。 就是有一个对外的接口,作用是对外提供用户的信息,有三个参数,start_time,end_time,department_id, _最近发现返回的用户信息有缺失的情况,缺失的都是 用户的 导师和主管 的 email , 就是说 有导师和主管的 id, 但是 导师和主管的 email 返回的 json 里面都是 null , 然后我做了一些测试发现以下几个问题: 1. 接口获取的数据,今天的和昨天的不一样, 例如那个 “用户1”,昨天是导师和主管的email 都缺失,今天只有导师的缺失,主管的正常,“用户2”昨天的时候是正常的今天的导师的email 缺失了, 2. 接口的3个参数start_time, end_time 和 department_id 三个参数发生变化,查到的相同的人员的信息两个email 的缺失情况会有所不同 3.用这个接口访问本地的,测试环境的,查询了2900 + 条数据, 和各类情况,得到的接口的数据都是正常的,没有缺失的请况发生。 4.在代码中,查询的结果没有经过逻辑处理,一直 return 到最后的。 5. 我用这个接口用到的SQL 去生产的数据库查, 查询的结果是完全正常的,没有发生缺失的情况。 求助各位大大, 这个会是哪里出现问题,造成这种缺失的问题。

关于安卓内存泄露的问题

小弟最近在做一个小项目,基本上功能完成了,但发现在程序运行了几分钟后会自动退出,打印的日志信息如下: ![图片说明](https://img-ask.csdn.net/upload/201907/22/1563795606_231565.png) 然后又通过对程序进行注释后发现在将从服务器获取数据的功能注释掉后这个问题解决了,所以觉得问题应该是出在这一块,在这个功能中循环调用的函数有关于对象以及线程,不知是否是这一块的问题,现将整个程序贴上求大神帮忙看看: MainActivity中: ``` package com.example.gsontest; import android.Manifest; import android.content.pm.PackageManager; import android.os.Bundle; import android.support.v4.app.ActivityCompat; import android.support.v4.content.ContextCompat; import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.widget.Toast; import com.baidu.location.BDLocation; import com.baidu.location.BDLocationListener; import com.baidu.location.LocationClient; import com.baidu.location.LocationClientOption; import com.baidu.mapapi.SDKInitializer; import com.baidu.mapapi.map.BaiduMap; import com.baidu.mapapi.map.BitmapDescriptor; import com.baidu.mapapi.map.BitmapDescriptorFactory; import com.baidu.mapapi.map.MapStatusUpdate; import com.baidu.mapapi.map.MapStatusUpdateFactory; import com.baidu.mapapi.map.MapView; import com.baidu.mapapi.map.MarkerOptions; import com.baidu.mapapi.map.MyLocationConfiguration; import com.baidu.mapapi.map.MyLocationData; import com.baidu.mapapi.map.OverlayOptions; import com.baidu.mapapi.model.LatLng; import com.baidu.mapapi.utils.CoordinateConverter; import org.json.JSONObject; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import okhttp3.OkHttpClient; import okhttp3.Request; import okhttp3.Response; public class MainActivity extends AppCompatActivity { private MapView mapView; private BaiduMap baiduMap; public LocationClient mLocationClient; public static String responseData; public double dvalueX; public double dvalueY; private boolean isFirstLocate = true; public int mXDirection; //方向类的对象 public MyOrientationListener myOrientationListener; @Override //该函数主要是进行Activity初始化 protected void onCreate(Bundle savedInstanceState) { Log.i("MainActivity","进入到onCreate函数中进行初始化"); super.onCreate(savedInstanceState); //实例化对象 mLocationClient = new LocationClient(getApplicationContext()); //注册监听器 mLocationClient.registerLocationListener(new MyLocationListener()); //初始化SDK SDKInitializer.initialize(getApplicationContext()); setContentView(R.layout.activity_main); mapView = (MapView) findViewById(R.id.bmpView); baiduMap = mapView.getMap(); baiduMap.setMyLocationEnabled(true); //尝试在监听按钮之前进行权限的允许 List<String> permissionList = new ArrayList<>(); if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.ACCESS_FINE_LOCATION); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.READ_PHONE_STATE) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.READ_PHONE_STATE); } if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) { permissionList.add(Manifest.permission.WRITE_EXTERNAL_STORAGE); } if (!permissionList.isEmpty()) { String[] permission = permissionList.toArray(new String[permissionList.size()]); ActivityCompat.requestPermissions(MainActivity.this, permission, 1); requestLocation(); } else { requestLocation(); } } private void requestLocation() { Log.i("MainActivity", "进入到requestLocation函数中"); initLocation(); //定位开始 initOrientationListener(); myOrientationListener.start(); mLocationClient.start(); } private void initLocation() { Log.i("MainActivity", "跳进了initLocation定位初始化函数中"); LocationClientOption option = new LocationClientOption(); option.setCoorType("bd09ll"); option.setScanSpan(1000); mLocationClient.setLocOption(option); } private void initOrientationListener() { Log.i("MainActivity", "跳进了initOrientationListener方向初始化函数中"); myOrientationListener = new MyOrientationListener(getApplicationContext()); myOrientationListener.setOnOrientationListener(new MyOrientationListener.OnOrientationListener() { @Override public void onOrientationChanged(float x) { mXDirection = (int) x; } }); } @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { Log.i("MainActivityActivity","进入onRequestPermissionResult函数中"); switch (requestCode) { case 1: if (grantResults.length > 0) { for (int result : grantResults) { if (result != PackageManager.PERMISSION_GRANTED) { Toast.makeText(this, "必须同意所有权限", Toast.LENGTH_LONG).show(); finish(); return; } } // sendRequestWithOkHttp(); } else { Toast.makeText(this, "发生未知错误", Toast.LENGTH_LONG).show(); finish(); } break; default: } } //定位监听器的类 public class MyLocationListener implements BDLocationListener { @Override public void onReceiveLocation(BDLocation location) { Log.i("MainActivity", "跳进了onReceiveLocation函数中"); if (location.getLocType() == BDLocation.TypeGpsLocation || location.getLocType() == BDLocation.TypeNetWorkLocation) { navigateTo(location); } } } private void navigateTo(BDLocation location) { Log.i("MainActivity", "跳进了navigateTo函数中"); //从服务器上获取实时的硬件位置 sendRequestWithOkHttp(); //将获取到的数据进行解析 ObjectJson(responseData); //将获取到的经纬度信息在地图上进行显示 displayLocation(dvalueX, dvalueY); //初次定位确定缩放尺寸,后面不改变便于手动伸缩 if (isFirstLocate) { BitmapDescriptor myBitMap = BitmapDescriptorFactory.fromResource(R.drawable.icon_reddirection); MyLocationConfiguration myLocationConfiguration = new MyLocationConfiguration(MyLocationConfiguration.LocationMode.NORMAL, true, myBitMap); baiduMap.setMyLocationConfiguration(myLocationConfiguration); LatLng la = new LatLng(location.getLatitude(), location.getLongitude()); MapStatusUpdate update = MapStatusUpdateFactory.newLatLng(la); baiduMap.animateMapStatus(update); update = MapStatusUpdateFactory.zoomTo(18f); baiduMap.animateMapStatus(update); isFirstLocate = false; } //将手机当前位置的小蓝点显示在屏幕上 MyLocationData.Builder locationBuilder = new MyLocationData.Builder(); locationBuilder.latitude(location.getLatitude()); locationBuilder.longitude(location.getLongitude()); //将要执行获取方向方法 locationBuilder.direction(mXDirection); MyLocationData locationData = locationBuilder.build(); baiduMap.setMyLocationData(locationData); } //重写三个方法以对mapView进行管理,保证资源可以及时释放 @Override protected void onResume() { Log.i("MainActivity", "进入到onResume函数中"); super.onResume(); mapView.onResume(); } @Override protected void onPause() { Log.i("MainActivity", "进入到onPause函数中"); super.onPause(); mapView.onPause(); } @Override protected void onDestroy() { Log.i("MainActivity", "进入到onDestroy函数中"); super.onDestroy(); mapView.onDestroy(); baiduMap.setMyLocationEnabled(false); mLocationClient.stop(); //停止方向监听 myOrientationListener.stop(); } private void sendRequestWithOkHttp() { Log.i("MainActivity", "跳进了sendRequestWithOkHttp方法中"); new Thread(new Runnable() { @Override //重写run方法,run方法规定了该线程的具体使命 public void run() { Log.i("MainActivity","跳进OkHttp的子线程中"); try { OkHttpClient client = new OkHttpClient(); Request request = new Request.Builder() .url("https://huadiheal.cn/animal/latest_data") .build(); Response response = client.newCall(request).execute(); responseData = response.body().string(); // ObjectJson(responseData); } catch (Exception e) { e.printStackTrace(); } } //创建后线程仅是占有内存资源,在JVM管理的线程中还没有这个资源,要调用父类的start方法通知JVM }).start(); } private void ObjectJson(String responseData) { Log.i("MainActivity", "跳进了ObjectJson函数中"); try { JSONObject jsonObject = new JSONObject(responseData); JSONObject valueX = jsonObject.getJSONObject("value_x"); JSONObject valueY = jsonObject.getJSONObject("value_y"); Iterator<String> iteratorX = valueX.keys(); while (iteratorX.hasNext()) { String valueXkey = iteratorX.next(); String valueXValue = valueX.getString(valueXkey); String valueYValue = valueY.getString(valueXkey); dvalueX = Double.parseDouble(valueXValue); dvalueY = Double.parseDouble(valueYValue); } } catch (Exception e) { e.printStackTrace(); } } public void displayLocation(double dvalueX, double dvalueY) { Log.i("MainActivity", "进入displayLocation中"); LatLng latLng = new LatLng(dvalueY, dvalueX); //进行坐标转换 CoordinateConverter converter = new CoordinateConverter() .from(CoordinateConverter.CoordType.GPS) .coord(latLng); LatLng dLatlng = converter.convert(); //进行刷新时,先清除上一次的overlay baiduMap.clear(); //现添加Marker将位置在地图上标出来 BitmapDescriptor bitmap = BitmapDescriptorFactory.fromResource(R.drawable.icon_niu32); OverlayOptions option = new MarkerOptions() .position(dLatlng) .icon(bitmap); baiduMap.addOverlay(option); } } ``` 方向传感器的监听类如下: ``` package com.example.gsontest; import android.content.Context; import android.hardware.Sensor; import android.hardware.SensorEvent; import android.hardware.SensorEventListener; import android.hardware.SensorManager; import android.util.Log; //方向监听器的类 public class MyOrientationListener implements SensorEventListener { private SensorManager mySensorManager; private Sensor mySensor; private Context myContext; private float lastX; private OnOrientationListener myOnOrientationListener; public void start(){ Log.i("MainActivity", "跳进了方向类的start函数中"); mySensorManager = (SensorManager) myContext.getSystemService(Context.SENSOR_SERVICE); if(mySensorManager!=null){ mySensor = mySensorManager.getDefaultSensor(Sensor.TYPE_ORIENTATION); } if(mySensor!=null){ //SENSOR_UI可能会出现数据滞后现象,若后期数据滞后则改成别的类型 mySensorManager.registerListener(this,mySensor,SensorManager.SENSOR_DELAY_NORMAL); } } //接触注册方向传感器监听事件,即对onDestroy中所引方法的实现 public void stop(){ Log.i("MainActivity","跳进方向类的stop函数中"); mySensorManager.unregisterListener(this); } //方向传感器的一个构造函数 public MyOrientationListener(Context myContext){ this.myContext = myContext; } @Override public void onAccuracyChanged(Sensor sensor,int accuracy){} //监听方向变化 @Override public void onSensorChanged(SensorEvent event){ Log.i("MainActivity","跳进了onSensorChanged函数中"); if(event.sensor.getType()==Sensor.TYPE_ORIENTATION){ float x = event.values[SensorManager.DATA_X]; if (Math.abs(x-lastX)>1.0){ if(myOnOrientationListener!=null){ myOnOrientationListener.onOrientationChanged(lastX); } } lastX = x; } } public void setOnOrientationListener(OnOrientationListener myOrientationListener){ this.myOnOrientationListener = myOrientationListener; } public interface OnOrientationListener{ void onOrientationChanged(float x); } } ``` 恳请大神帮忙看下程序谢谢!!

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

String s = new String(" a ") 到底产生几个对象?

老生常谈的一个梗,到2020了还在争论,你们一天天的,哎哎哎,我不是针对你一个,我是说在座的各位都是人才! 上图红色的这3个箭头,对于通过new产生一个字符串(”宜春”)时,会先去常量池中查找是否已经有了”宜春”对象,如果没有则在常量池中创建一个此字符串对象,然后堆中再创建一个常量池中此”宜春”对象的拷贝对象。 也就是说准确答案是产生了一个或两个对象,如果常量池中原来没有 ”宜春” ,就是两个。...

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

Linux面试题(2020最新版)

文章目录Linux 概述什么是LinuxUnix和Linux有什么区别?什么是 Linux 内核?Linux的基本组件是什么?Linux 的体系结构BASH和DOS之间的基本区别是什么?Linux 开机启动过程?Linux系统缺省的运行级别?Linux 使用的进程间通信方式?Linux 有哪些系统日志文件?Linux系统安装多个桌面环境有帮助吗?什么是交换空间?什么是root帐户什么是LILO?什...

将一个接口响应时间从2s优化到 200ms以内的一个案例

一、背景 在开发联调阶段发现一个接口的响应时间特别长,经常超时,囧… 本文讲讲是如何定位到性能瓶颈以及修改的思路,将该接口从 2 s 左右优化到 200ms 以内 。 二、步骤 2.1 定位 定位性能瓶颈有两个思路,一个是通过工具去监控,一个是通过经验去猜想。 2.1.1 工具监控 就工具而言,推荐使用 arthas ,用到的是 trace 命令 具体安装步骤很简单,大家自行研究。 我的使用步骤是...

学历低,无法胜任工作,大佬告诉你应该怎么做

微信上收到一位读者小涛的留言,大致的意思是自己只有高中学历,经过培训后找到了一份工作,但很难胜任,考虑要不要辞职找一份他能力可以胜任的实习工作。下面是他留言的一部分内容: 二哥,我是 2016 年高中毕业的,考上了大学但没去成,主要是因为当时家里经济条件不太允许。 打工了三年后想学一门技术,就去培训了。培训的学校比较垃圾,现在非常后悔没去正规一点的机构培训。 去年 11 月份来北京找到了一份工...

JVM内存结构和Java内存模型别再傻傻分不清了

JVM内存结构和Java内存模型都是面试的热点问题,名字看感觉都差不多,网上有些博客也都把这两个概念混着用,实际上他们之间差别还是挺大的。 通俗点说,JVM内存结构是与JVM的内部存储结构相关,而Java内存模型是与多线程编程相关,本文针对这两个总是被混用的概念展开讲解。 JVM内存结构 JVM构成 说到JVM内存结构,就不会只是说内存结构的5个分区,而是会延展到整个JVM相关的问题,所以先了解下

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

Google 与微软的浏览器之争

浏览器再现“神仙打架”。整理 | 屠敏头图 | CSDN 下载自东方 IC出品 | CSDN(ID:CSDNnews)从 IE 到 Chrome,再从 Chrome 到 Edge,微软与...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

85后蒋凡:28岁实现财务自由、34岁成为阿里万亿电商帝国双掌门,他的人生底层逻辑是什么?...

蒋凡是何许人也? 2017年12月27日,在入职4年时间里,蒋凡开挂般坐上了淘宝总裁位置。 为此,时任阿里CEO张勇在任命书中力赞: 蒋凡加入阿里,始终保持创业者的冲劲,有敏锐的...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

什么时候跳槽,为什么离职,你想好了么?

都是出来打工的,多为自己着想

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

终于懂了TCP和UDP协议区别

终于懂了TCP和UDP协议区别

立即提问
相关内容推荐