Android SQLite获取数据库写入对象出错

图片说明

java.lang.RuntimeException: An error occured while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:304)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
Caused by: android.database.sqlite.SQLiteException: Failed to change locale for db '/data/data/com.howso.cqt/databases/cqt.db' to 'en_US'.
at android.database.sqlite.SQLiteConnection.setLocaleFromConfiguration(SQLiteConnection.java:393)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:218)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)
at android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)
at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:806)
at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:791)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)
at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:1163)
at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:278)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:223)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
at com.howso.cqt.db.cqt.CQTManager.writeDB(CQTManager.java:108)
at com.howso.cqt.db.cqt.CQTManager.addSignalEvents(CQTManager.java:491)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:3560)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:292)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
... 4 more
Caused by: android.database.sqlite.SQLiteDiskIOException: disk I/O error (code 3850)
at android.database.sqlite.SQLiteConnection.nativeExecute(Native Method)
at android.database.sqlite.SQLiteConnection.execute(SQLiteConnection.java:555)
at android.database.sqlite.SQLiteConnection.setLocaleFromConfiguration(SQLiteConnection.java:371)
... 22 more
android.database.sqlite.SQLiteException: Failed to change locale for db '/data/data/com.howso.cqt/databases/cqt.db' to 'en_US'.
at android.database.sqlite.SQLiteConnection.setLocaleFromConfiguration(SQLiteConnection.java:393)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:218)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)
at android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)
at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:806)
at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:791)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)
at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:1163)
at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:278)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:223)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
at com.howso.cqt.db.cqt.CQTManager.writeDB(CQTManager.java:108)
at com.howso.cqt.db.cqt.CQTManager.addSignalEvents(CQTManager.java:491)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:3560)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:292)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)
Caused by: android.database.sqlite.SQLiteDiskIOException: disk I/O error (code 3850)
at android.database.sqlite.SQLiteConnection.nativeExecute(Native Method)
at android.database.sqlite.SQLiteConnection.execute(SQLiteConnection.java:555)
at android.database.sqlite.SQLiteConnection.setLocaleFromConfiguration(SQLiteConnection.java:371)
... 22 more
android.database.sqlite.SQLiteDiskIOException: disk I/O error (code 3850)
at android.database.sqlite.SQLiteConnection.nativeExecute(Native Method)
at android.database.sqlite.SQLiteConnection.execute(SQLiteConnection.java:555)
at android.database.sqlite.SQLiteConnection.setLocaleFromConfiguration(SQLiteConnection.java:371)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:218)
at android.database.sqlite.SQLiteConnection.open(SQLiteConnection.java:193)
at android.database.sqlite.SQLiteConnectionPool.openConnectionLocked(SQLiteConnectionPool.java:463)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:185)
at android.database.sqlite.SQLiteConnectionPool.open(SQLiteConnectionPool.java:177)
at android.database.sqlite.SQLiteDatabase.openInner(SQLiteDatabase.java:806)
at android.database.sqlite.SQLiteDatabase.open(SQLiteDatabase.java:791)
at android.database.sqlite.SQLiteDatabase.openDatabase(SQLiteDatabase.java:694)
at android.app.ContextImpl.openOrCreateDatabase(ContextImpl.java:1163)
at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:278)
at android.database.sqlite.SQLiteOpenHelper.getDatabaseLocked(SQLiteOpenHelper.java:223)
at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:163)
at com.howso.cqt.db.cqt.CQTManager.writeDB(CQTManager.java:108)
at com.howso.cqt.db.cqt.CQTManager.addSignalEvents(CQTManager.java:491)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:3560)
at com.howso.cqt.activity.indoortest.oldIndoorDicActivity$SaveAsync.doInBackground(oldIndoorDicActivity.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:292)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:818)

1个回答

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
android sqlite 数据库问题
我想将Android应用中的数据库进行修改,导出后,修改完毕,导入。但是,导入后数据并没有变化,求解。。(我用的sqlitestudio工具),求具体的步骤,谁能指导下
Android开发中与Sqlite数据库相似的数据库
目前Android开发中本地数据库只能用Sqlite数据库嘛?有没有其他数据库可选?(本人知道Sqlite这个很好,但是新手想知道都有什么选择)
Android APP怎么获取sqlite3数据库数据
Android APP怎么获取sqlite3数据库数据,哪位大神教教我
Android sqlite数据库,条件筛选问题。
我想要筛选出表中status大于0的记录,但似乎这个条件一直没起作用, 得到的结果还是有status=0的记录,筛选小于0的又可以, 困扰我很久了,有知道的大神麻烦告知一下什么原因。 ![测试方法](https://img-ask.csdn.net/upload/201612/12/1481505922_532002.png) ![筛选结果](https://img-ask.csdn.net/upload/201612/12/1481505949_32079.png)
android sqlite效率问题
我本地用到的sqlite数据库中有大概10W条数据左右,会经常需要根据不同的条件来查询 由于查询比较频繁,用到了greenDao这个框架,查询确实很快,但是一排序就很慢了 我又将数据生成一个视图来再查询,但是sqlite每次查询都需要去创建视图(不知道怎么表达,大概就是这个意思);这样一来又很慢了 大家有没有什么比较好的办法?
Android sqlite 数据库sh: sqlite3: not found
![图片说明](https://img-ask.csdn.net/upload/201704/15/1492231363_703513.png) 求大神解救
sqlite数据库怎么循环update 语句
android sqlite数据库有一给字段,这个字段里面是null没有值,点击某些操作后我现在需要在代码中循环给这个字段写入数字序号0,1,2,3,4,5,6这样的顺序 ,我的update 语句怎么写,循环是不是直接 for里面直接i就可以了 谢谢
使用Android中的SQLite建立一个数据库,加了一张Book表,增加一个表,升级数据库失败
使用Android中的SQLite建立一个数据库BookStore,加了一张Book表,然后我要增加一个Category表,按照《第一行代码》中的6.4.2所示代码写完后,点击App后直接闪退。(我用的是Andro Studio3.1版本,使用真机开发,系统Androi8.1)。代码如下 主活动代码: public class MainActivity extends AppCompatActivity { private MyDatabaseHelper dbHelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dbHelper=new MyDatabaseHelper(this,"BookStore.db",null,2); Button createDatabase=(Button)findViewById(R.id.create_database); createDatabase.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { dbHelper.getWritableDatabase(); } }); } } 定义一个数据库类MyDatabaseHelper继承SQLiteOpenHelper public class MyDatabaseHelper extends SQLiteOpenHelper { public static final String CREATE_BOOK="create table Book(" +"id integer primary key autoincrement," +"author text" +"price real" +"pages integer" +"name text)"; public static final String CREATE_CATEGORY="create table Category(" +"id integer primary key autoincrement" +"category_name text" +"category_code integer)"; private Context mContext; public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory,int version){ super(context,name,factory,version); mContext=context; } @Override public void onCreate(SQLiteDatabase db){ db.execSQL(CREATE_BOOK); db.execSQL(CREATE_CATEGORY); Toast.makeText(mContext,"Create succeeded",Toast.LENGTH_SHORT).show(); } @Override public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){ db.execSQL("drop table if exists Book"); db.execSQL("drop table if exists Category"); onCreate(db); } }
android sqlite搞不太清除
不太清楚sqlite,在网上搜了一下,看别人写的sqlite是用代码写的,创建数据库也是在代码执行的,那么这个程序退出了之后,这个创建的数据库还有吗?。 我想用android做一个简易的图书管理系统,其实就是连接数据库进行一些增删改查,老师要求要用c#和android做,我想用android做,但是电脑上sql server有点问题,听别人说android用sqlite可以做。但是在网上查了一下,不太清楚sqlite到底怎么用?求大神指点下
android SQLite数据库做完了以后程序运行不了,把有关数据库所有东西删了以后就可以运行
``` package com.test.mark4; import java.util.regex.Matcher; import java.util.regex.Pattern; import android.app.Activity; import android.app.AlertDialog; import android.content.ContentValues; import android.content.SharedPreferences; import android.content.SharedPreferences.Editor; import android.database.sqlite.SQLiteDatabase; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.view.Window; import android.widget.Button; import android.widget.EditText; import android.widget.LinearLayout; import android.widget.TextView; public class function31 extends Activity{ private MyDatabaseHelper dbHelper; EditText cs,dh,hsds,qsds; TextView gcc,t1,t2,t3,t4,t5,t6,t7; Button btn1,btn2,btn3,btn4,btn6,btn7; int num=0,v1=0,s=1; Button back; Button btn[]=new Button[25]; double j,x;//平均高程差 double[]d=new double[25]; @Override protected void onCreate(Bundle savedInstanceState){ super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE);//去掉标题栏 setContentView(R.layout.function31_layout); dbHelper=new MyDatabaseHelper(this,"data.db",null,1); back=(Button)findViewById(R.id.head_TitleBackBtn);//返回按钮 back.setOnClickListener(new OnClickListener(){ public void onClick(View v){ finish(); } }); cs=(EditText)findViewById(R.id.editText1); dh=(EditText)findViewById(R.id.editText2); hsds=(EditText)findViewById(R.id.editText3); qsds=(EditText)findViewById(R.id.editText4); btn1=(Button)findViewById(R.id.button1); btn2=(Button)findViewById(R.id.button2); btn6=(Button)findViewById(R.id.button5); btn7=(Button)findViewById(R.id.button6); gcc=(TextView)findViewById(R.id.textView8); btn3=(Button)findViewById(R.id.button3); btn4=(Button)findViewById(R.id.button4); t1=(TextView)findViewById(R.id.textView1); t2=(TextView)findViewById(R.id.textView2); t3=(TextView)findViewById(R.id.textView3); t4=(TextView)findViewById(R.id.textView4); t5=(TextView)findViewById(R.id.textView5); t6=(TextView)findViewById(R.id.textView6); t7=(TextView)findViewById(R.id.textView7); final LinearLayout l=(LinearLayout)findViewById(R.id.view); btn4.setVisibility(View.INVISIBLE); cs.setVisibility(View.INVISIBLE); dh.setVisibility(View.INVISIBLE); hsds.setVisibility(View.INVISIBLE); qsds.setVisibility(View.INVISIBLE); btn1.setVisibility(View.INVISIBLE); btn2.setVisibility(View.INVISIBLE); btn6.setVisibility(View.INVISIBLE); btn7.setVisibility(View.INVISIBLE); gcc.setVisibility(View.INVISIBLE); t1.setVisibility(View.INVISIBLE); t2.setVisibility(View.INVISIBLE); t3.setVisibility(View.INVISIBLE); t4.setVisibility(View.INVISIBLE); t5.setVisibility(View.INVISIBLE); t6.setVisibility(View.INVISIBLE); t7.setVisibility(View.INVISIBLE); btn3.setOnClickListener(new OnClickListener(){//+ public void onClick(View v){ num+=1; btn[num]=new Button(function31.this); btn[num].setId(num); btn[num].setText(String.valueOf(num)); l.addView(btn[num]); if(num!=0) { btn4.setVisibility(View.VISIBLE); cs.setVisibility(View.VISIBLE); dh.setVisibility(View.VISIBLE); hsds.setVisibility(View.VISIBLE); qsds.setVisibility(View.VISIBLE); btn1.setVisibility(View.VISIBLE); btn2.setVisibility(View.VISIBLE); btn6.setVisibility(View.VISIBLE); btn7.setVisibility(View.VISIBLE); gcc.setVisibility(View.VISIBLE); t1.setVisibility(View.VISIBLE); t2.setVisibility(View.VISIBLE); t3.setVisibility(View.VISIBLE); t4.setVisibility(View.VISIBLE); t5.setVisibility(View.VISIBLE); t6.setVisibility(View.VISIBLE); t7.setVisibility(View.VISIBLE); } btn[num].setOnClickListener(new OnClickListener(){//监视新建button @Override public void onClick(View v) { // TODO Auto-generated method stub s=v.getId(); SharedPreferences sj = getSharedPreferences(String.valueOf(s),0);//SharedPreferences输出信息 String Str1=sj.getString("cs", ""); String Str2=sj.getString("dh", ""); String Str3=sj.getString("hsds", ""); String Str4=sj.getString("qsds", ""); String Str5=sj.getString("gcc", ""); cs.setText(Str1); dh.setText(Str2); hsds.setText(Str3); qsds.setText(Str4); gcc.setText(Str5); } }); } }); btn4.setOnClickListener(new OnClickListener(){//+ public void onClick(View v){ l.removeView(btn[num]);; num-=1; if(num==0){ btn4.setVisibility(View.INVISIBLE); cs.setVisibility(View.INVISIBLE); dh.setVisibility(View.INVISIBLE); hsds.setVisibility(View.INVISIBLE); qsds.setVisibility(View.INVISIBLE); btn1.setVisibility(View.INVISIBLE); btn2.setVisibility(View.INVISIBLE); btn6.setVisibility(View.INVISIBLE); btn7.setVisibility(View.INVISIBLE); gcc.setVisibility(View.INVISIBLE); t1.setVisibility(View.INVISIBLE); t2.setVisibility(View.INVISIBLE); t3.setVisibility(View.INVISIBLE); t4.setVisibility(View.INVISIBLE); t5.setVisibility(View.INVISIBLE); t6.setVisibility(View.INVISIBLE); t7.setVisibility(View.INVISIBLE); } } }); btn1.setOnClickListener(new OnClickListener(){//计算 public void onClick(View v){ String Str1=cs.getText().toString(); String Str2=dh.getText().toString(); String numStr1=hsds.getText().toString(); String numStr2=qsds.getText().toString(); Pattern p = Pattern.compile("\\d+\\.\\d+$|-\\d+\\.\\d+$|^\\d+$|-\\d+$"); Matcher n=p.matcher(numStr1); Matcher m=p.matcher(numStr2); if(n.matches()&m.matches()){ double a=Double.parseDouble(numStr1); double b=Double.parseDouble(numStr2); double c=(a-b)/2; d[s]=c; gcc.setText(String.valueOf(c)); String Str3=gcc.getText().toString(); SharedPreferences sj = getSharedPreferences(String.valueOf(s),0);//SharedPreferences记录信息 sj.edit().clear().commit(); Editor editor=sj.edit(); editor.putString("cs", Str1); editor.putString("dh", Str2); editor.putString("hsds", numStr1); editor.putString("qsds", numStr2); editor.putString("gcc", Str3); editor.commit(); //SQLite SQLiteDatabase db=dbHelper.getWritableDatabase(); ContentValues values=new ContentValues(); values.put("cs", Str1); values.put("dh", Str2); values.put("hsds", numStr1); values.put("qsds", numStr2); values.put("gcc", Str3); db.insert("f31", null, values); values.clear(); } else { AlertDialog.Builder dialog=new AlertDialog.Builder(function31.this); dialog.setTitle("提示"); dialog.setMessage("请输入正确数值"); dialog.setCancelable(false); dialog.setPositiveButton("OK", null); dialog.show(); } } }); btn2.setOnClickListener(new OnClickListener(){//清空 public void onClick(View v){ cs.setText(""); dh.setText(""); hsds.setText(""); qsds.setText(""); gcc.setText(""); } }); btn6.setOnClickListener(new OnClickListener(){ @Override public void onClick(View v) { // TODO Auto-generated method stub for(int y=1;y<=num;y++){ j+=d[y]; } x=j/num; //SharedPreferences pj = getSharedPreferences("data",0);//SharedPreferences记录信息 //Editor editor=pj.edit(); //editor.putInt("chs", num); //editor.putFloat("pj", (float) x); } }); } } ``` MyDatabaseHelper ``` package com.test.mark4; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; public class MyDatabaseHelper extends SQLiteOpenHelper{ public static final String CREATE_F31="creat table f31(" +"cs text primary key autoincrement," +"chs integer," +"dh text," +"hsds text," +"qsds text," +"gcc text," +"pj real)"; public MyDatabaseHelper(Context context,String name,CursorFactory factory,int version){ super(context,name,factory,version); } @Override public void onCreate(SQLiteDatabase db) { // TODO Auto-generated method stub db.execSQL(CREATE_F31); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO Auto-generated method stub } } ```
android sqlite数据写入数据的时候,主界面会卡主,怎么解决?
android 使用xutils访问网络获取json串,然后解析插入android本地的sqlite数据库, 在执行写入数据库的时候 ,主界面会卡主,做其他操作会报错ANR,怎么解决,sqlitexu 要写入的数据6万条左右,大概要40分钟,主界面就卡40分钟。
使用android的SQLite数据库能存储多大数据
看到网上说SQLite数据库的大小是2TB,但是我觉得这个数据库不应该跟手机内存相联系吗? android上的SQLite数据库真的能容纳下2TB的数据吗???
修改sqlite数据库的某一列
我是用eclipse的,android开发,sqlite数据库 我想更改sqlite数据库中某一列的所有数据,比如我的table表中有一列是date,全是sssss,我想修改date这一列中所有的数据,变成ppp
Android程序中的db文件是如何导入的?db文件是sqlite数据库写的。
Android程序中的db文件是如何导入的?db文件是sqlite数据库写的。
AndroidStudio 如何查看sqlite数据库在哪个文件下面
我用sqlite创建的数据库,要怎么查看我建的数据库文件在哪呢
Android 读取Excel并输出到sqlite数据库
Android如何读取Excel并输出到sqlite数据库中?哪位大佬能发个示例程序DEMO? 万分感激
android sqlite数据库表字段更新
android sqlite数据库表字段更新,调用onUpgrade方法出现了Can't upgrade read-only database from version 3 to 4: 异常,有哪个大神碰到过或者知道怎么解决。 代码: public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = " alter table person modify phone varchar(100)"; db.execSQL(sql); } ``` ``` ``` ```
Android sqlite更新,本人新手菜鸟
本人看“第一行代码”这本书,看到sqlite升级数据库这个地方,发现比如要新增一张表,可以通过onUpgrade()方法中添加db.execSQL(**)语句完成,那么,为什么onCreate()方法也要添加这条语句?
电脑创建的sqlite3数据库为什么android读不了
但是andoird创建好的数据库移动到电脑上做插入数据再放到andoird上却可以运行
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
相关热词 c#导入fbx c#中屏蔽键盘某个键 c#正态概率密度 c#和数据库登陆界面设计 c# 高斯消去法 c# codedom c#读取cad文件文本 c# 控制全局鼠标移动 c# temp 目录 bytes初始化 c#
立即提问