- Seata与DTF框架在微服务中的选型对比
策划加强小乔
微服务架构云原生
在微服务架构中,分布式事务管理是确保数据一致性的关键环节。Seata和DTF作为两款主流的分布式事务解决方案,各自具有独特的优势和适用场景。以下从核心原理、功能特性、适用场景和实战案例等维度进行详细对比分析,并提供选型建议。核心架构与工作原理Seata:采用经典的分布式事务模型,支持AT(自动补偿)、TCC(Try-Confirm-Cancel)、SAGA和XA四种模式。AT模式通过全局锁实现数据
- matlab a1处语法无效,MATLAB常见错误
桃子胖
matlaba1处语法无效
1.在GUI子程序的OpeningFcn函数的结尾加上uiwait(handles.figure1);figure1是subGUI的Tag;2.subGUI中控制程序结束(如"OK"和"Cancel"按钮)的callback末尾加上uiresume(handles.figure1),不要将delete命令放在这些callback中;3.在子GUI的OutputFcn中设置要传递出去的参数,如var
- windows dockerdesktop拉取镜像报错
lishijie135
windows
1.问题描述:运行docker-composeup-d启动容器报错:Errorresponsefromdaemon:Get"https://registry-1.docker.io/v2/":net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)如下图:问题分析:执行
- DelayQueue延迟队列用法
碟碟以碟以喋喋
java开发语言
1.创建Delayed实现类publicclassCancelDelayimplementsDelayed{//用户idprivateIntegeruserId;//过期时间privateDatetime;//用户状态privateIntegerstatus;publicCancelDelay(){}publicCancelDelay(IntegeruserId,Datetime,Integers
- docker更换国内加速器-更换华为加速器2025-717亲测可用docker 拉取镜像出错
longerxin2020
docker容器运维
[root@localhost~]#dockerpullnginxUsingdefaulttag:latestErrorresponsefromdaemon:Get"https://registry-1.docker.io/v2/":net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaiti
- Go语言Context详解:原理、使用场景与最佳实践
文章目录1.Context概述1.1什么是Context1.2为什么需要Context2.Context的核心接口3.Context的创建与派生3.1根Context3.2派生Context3.2.1WithCancel3.2.2WithDeadline3.2.3WithTimeout3.2.4WithValue4.Context的工作原理4.1Context的底层结构4.2取消传播机制4.3流程
- Linux 定时器应用示例
1.运行结果2.程序#include#include#includeintcount=0;structitimervalt;voidtimer_handler(intsig){printf("timer_handler:signal=%d,count=%d\n",sig,++count);if(count>=8){printf("canceltimer\n");t.it_value.tv_sec=
- 音频被动降噪技术
悟空胆好小
音频相关音视频
音频被动降噪技术音频被动降噪技术是一种通过物理结构和材料设计来减少或隔离外部噪声的降噪方式,其核心原理是通过物理屏障或吸声材料来阻断或吸收声波,从而降低环境噪声对听觉体验的影响。以下将从技术原理、应用场景、优缺点及与其他降噪技术的对比等方面进行详细分析。一、被动降噪技术的原理被动降噪技术(PassiveNoiseCancellation,PNC)主要依赖于耳机的物理结构和材料设计,通过以下几种方式
- vue动态挂载组件
寒墨茗殇
vueelementvue.jsjavascript前端
vue动态挂载组件,比如弹窗组件main.js:首先创建公共js,并引入importcommonfrom'@/utils/common'Vue.use(common)confirmDialog.vue:然后写组件的样式和方法{{cancelText}}{{confirmText}}exportdefault{data(){return{dialogFn:null,content:'',title:
- 取消短按power键做出对应的功能
frameworks/base/policy/src/com/android/internal/policy/impl/PhoneWindowManager.java@@publicbooleanisForegroundActivity(Stringpackage_name){cancelPendingScreenshotChordAction();if(interceptPowerKeyUp(c
- 基于MATLAB平台设计并实现自适应噪声抵消器(Adaptive Noise Canceller, ANC)
AI Dog
自动控制matlab自适应噪声抵消器ANC信号去噪
本课题旨在基于MATLAB平台设计并实现自适应噪声抵消器(AdaptiveNoiseCanceller,ANC),以有效去除信号中的背景噪声,提升语音、医疗或通信系统中的信噪比。系统采用自适应滤波算法,如最小均方误差(LMS)或归一化LMS(NLMS)算法,通过参考噪声信号估计并抵消主通道信号中的噪声成分,实现动态降噪。研究内容包括信号采集与仿真建模、自适应滤波器结构设计、算法参数调整及降噪性能评
- Redisson看门狗机制:分布式锁的可靠守护者
小韩学长yyds
Redisson分布式Redisson
个人主页:小韩学长yyds-CSDN博客⛺️欢迎关注:点赞留言收藏箴言:拥有耐心才是生活的关键目录一、引言二、Redisson简介三、看门狗机制原理剖析3.1自动续期核心逻辑3.2锁释放与取消续期3.3核心源码深度解读3.3.1scheduleExpirationRenewal方法3.3.2renewExpiration方法3.3.3cancelExpirationRenewal方法四、应用场景与
- C# Winform弹出确认窗口
richhsx
C#
C#Winform弹出确认窗口privatevoidbtn_Click(objectsender,EventArgse){MessageBoxButtonsmess=MessageBoxButtons.OKCancel;DialogResultd=MessageBox.Show("确定要关闭吗?","提示",mess);if(d==DialogResult.OK){MessageBox.Show(
- ElementPlus表格相关操作大全-2
朝阳 Melo
前端javascript开发语言
网址:一个Vue3UI框架|ElementPlus(element-plus.org)https://element-plus.org/zh-CN/例:组件——Form表单典型表单参考代码:-OnlineactivitiesPromotionactivitiesOfflineactivitiesSimplebrandexposureSponsorVenueCreateCancelimport{re
- TCC型分布式事务处理
蒋厚施
分布式
柔性事务解决方案:TCC实现一个完整的业务活动由一个主业务服务与若干从业务服务组成主业务服务负责发起并完成整个业务活动从业务服务提供TCC型业务操作业务活动管理器控制业务活动的一致性,它登记业务活动中的操作,并在业务活动提交时确认所有的TCC型操作的confirm操作,在业务活动取消时调用所有TCC型操作的cancel操作成本实现TCC操作的成本业务活动结束时confirm或cancel操作的执行
- 进程、线程和进程间通信课程 Day4学习要点总结
我在南山当吗喽 我在南山当吗喽
学习javajvm
本章是线程的取消、清理,互斥和同步,以及互斥锁、读写锁和死锁的内容一、线程取消机制(一)核心概念线程取消不是“立刻杀死”,而是一种协作式机制:发起方:主线程用pthread_cancel(tid)发送“取消请求”接收方:子线程需遇到取消点(或主动调用pthread_testcancel())才会响应结果:子线程响应后,会模拟执行pthread_exit(PTHREAD_CANCELED),主线程p
- U9C恢复终止的请购单sql
U9C恢复终止的请购单sqlSELECTCancel_Canceled,Cancel_CancelDate,Cancel_CancelUser,Cancel_CancelReason,*fromPR_PRWHEREdocnoin('PR2504100002');--更新生产订单作废UPDATEPR_PRSETCancel_Canceled=0,--1=关闭,0=打开Cancel_CancelDat
- 分布式事务:应用场景与解决方案详解
北辰alk
java分布式
文章目录一、分布式事务的应用场景1.1必须使用分布式事务的典型场景1.2判断是否需要分布式事务的标准二、分布式事务解决方案全景2.1强一致性方案2.1.12PC(两阶段提交)2.1.33PC(三阶段提交)2.2最终一致性方案2.2.1TCC(Try-Confirm-Cancel)2.2.2Saga模式2.2.3本地消息表2.3混合方案2.3.1Seata框架2.3.2消息队列+本地事务三、方案选型
- 用友uap开发nc65按钮配置
qq_31968809
用友ncuap用友用友ncxmlnc65
用友uap开发nc65按钮配置1.在xml文件中配置按钮2.新建一个java类与按钮相对应publicclassSelectOrCancelActionextendsNCAction{privateAbstractAppModelmodel;privatestaticfinallongserialVersionUID=1993918902236291721L;publicSelectOrCance
- picker 监听确定和取消事件
picker监听确定和取消事件{{multiArray[0][multiIndex[0]]}}/{{multiArray[1][multiIndex[1]]}}/{{multiArray[2][multiIndex[2]]}}@change----监听的就是确认事件@cancel----监听的就是取消事件
- 关于pthread_cancel()的运用,取消点的理解
ySh_ppp
网络编程pthread
关于pthread_cancel函数的运用一、相关简介1、取消点:2、cancelstate3、canceltype二、有关函数1、线程创建函数create2、线程终止函数cancel3、线程终止状态cancelstate4、线程终止类型canceltype三、实践1、全部默认(1)nocancel(2)cancel2、state设置state==PTHREAD_CANCEL_DISABLE3、t
- Milvus attu - docker 使用 及 版本兼容
丽英y
实践笔记milvusdockerattu数据库向量rag
文章目录版本查看attu和milvus的兼容性Docker加载attudocker合并到Milvus文件管理使用dockercompose挂在Milvus,登录attu出现报错:Error:FailedtoconnecttoMilvus:Error:1CANCELLED:Callcancelled于是检查兼容问题版本查看Milvus版本发布:https://github.com/milvus-io
- TongSearch任务管理
TongSearch
TongSearch任务管理东方通搜索引擎TongSearch
目录前言为什么需要关注任务管理?任务的分类与定义一、按持续时间分类:短任务vs长任务1.短任务(Short-livedTasks)2.长任务(Long-runningTasks)二、按任务执行方式分类:同步vs异步1.同步任务(SynchronousTasks)2.异步任务(AsynchronousTasks)三、按是否可取消分类:CancellablevsNon-Cancellable1.可取消
- Docker: Get “https://registry-1.docker.io/v2/“: net/http: request canceled while
杰哥技术分享
dockerhttp容器
WARN[0000]/Users/Allen/Env/AllenDocker/docker-compose.yml:theattribute`version`isobsolete,itwillbeignored,pleaseremoveittoavoidpotentialconfusion[+]Running8/10✘mysqlErrorcontextcanceled15.1s✘nginxErro
- EXCEL 页眉页脚生成脚本
weixin_44456861
自动化
Sub生成页眉页脚()DimgcmAsStringDimtmAsStringDimrqAsStringDimthAsStringrer=MsgBox("你要进行页眉页脚生成?",vbOKCancel,"提示")Ifrer=vbCancelThenEndUserForm4.Showss=ActiveSheet.IndexIfUserForm4.OptionButton1=TrueOrUserForm
- Java并发编程实战 Day 6:Future与异步编程模型
在未来等你
Java并发编程实战Java并发编程Future异步编程
【Java并发编程实战Day6】Future与异步编程模型在今天的课程中,我们将深入学习Java中的Future与异步编程模型。这是为期30天的"Java并发编程实战"系列的第6天。理论基础Future接口Future接口是Java提供的用于表示异步计算的结果。它提供了以下方法:get():阻塞直到任务完成并返回结果。isDone():判断任务是否已经完成。cancel(booleanmayInt
- 如何解决Docker网络请求问题:https://registry-1.docker.io/v2/ request canceled报错
运维&陈同学
运维小知识秘籍docker容器云计算运维安全
报错dockerpullnginxUsingdefaulttag:latestErrorresponsefromdaemon:Get"https://registry-1.docker.io/v2/":contextdeadlineexceeded(Client.Timeoutexceededwhileawaitingheaders)方法一:给docker配置一个代理Docker代理在执行dock
- vue axios 阻塞未完成请求
前端猎码人
vue.jsajax
import_from'lodash'importaxiosfrom'axios'const{CancelToken,Cancel}=axiosconsttokens={}/***请求前处理config(尽可能在最先注册的拦截器中调用)*@param{import('axios').AxiosRequestConfig}config*/exportconstsetConfig=function(c
- C# 异步编程详解(Task,async/await)
luxingyu329
.net相关的收集整理c#开发语言
文章目录1.什么是异步2.Task产生背景3.Thread(线程)和Task(异步)的区别3.1几个名词3.2Thread与Task的区别4.TaskAPI4.1创建和启动任务4.2Task等待、延续和组合4.3task.Result4.4Task.Delay()和Thread.Sleep()区别5.CancellationToken和CancellationTokenSource取消线程5.1C
- 成功解决:Error response from daemon: Get “https://registry-1.docker.io/v2/“: net/http: request canceled
NayNuhcIem
http网络协议网络python
Errorresponsefromdaemon:Get"https://registry-1.docker.io/v2/":net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)通常表示您的网络连接在尝试拉取镜像时超时了。解决方法配置镜像进行pull进入docker,
- PHP,安卓,UI,java,linux视频教程合集
cocos2d-x小菜
javaUIlinuxPHPandroid
╔-----------------------------------╗┆
- zookeeper admin 笔记
braveCS
zookeeper
Required Software
1) JDK>=1.6
2)推荐使用ensemble的ZooKeeper(至少3台),并run on separate machines
3)在Yahoo!,zk配置在特定的RHEL boxes里,2个cpu,2G内存,80G硬盘
数据和日志目录
1)数据目录里的文件是zk节点的持久化备份,包括快照和事务日
- Spring配置多个连接池
easterfly
spring
项目中需要同时连接多个数据库的时候,如何才能在需要用到哪个数据库就连接哪个数据库呢?
Spring中有关于dataSource的配置:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
&nb
- Mysql
171815164
mysql
例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%'IDENTIFIED BY 'mypassword' WI
TH GRANT OPTION;
如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作
- CommonDAO(公共/基础DAO)
g21121
DAO
好久没有更新博客了,最近一段时间工作比较忙,所以请见谅,无论你是爱看呢还是爱看呢还是爱看呢,总之或许对你有些帮助。
DAO(Data Access Object)是一个数据访问(顾名思义就是与数据库打交道)接口,DAO一般在业
- 直言有讳
永夜-极光
感悟随笔
1.转载地址:http://blog.csdn.net/jasonblog/article/details/10813313
精华:
“直言有讳”是阿里巴巴提倡的一种观念,而我在此之前并没有很深刻的认识。为什么呢?就好比是读书时候做阅读理解,我喜欢我自己的解读,并不喜欢老师给的意思。在这里也是。我自己坚持的原则是互相尊重,我觉得阿里巴巴很多价值观其实是基本的做人
- 安装CentOS 7 和Win 7后,Win7 引导丢失
随便小屋
centos
一般安装双系统的顺序是先装Win7,然后在安装CentOS,这样CentOS可以引导WIN 7启动。但安装CentOS7后,却找不到Win7 的引导,稍微修改一点东西即可。
一、首先具有root 的权限。
即进入Terminal后输入命令su,然后输入密码即可
二、利用vim编辑器打开/boot/grub2/grub.cfg文件进行修改
v
- Oracle备份与恢复案例
aijuans
oracle
Oracle备份与恢复案例
一. 理解什么是数据库恢复当我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(硬件故障、软件故障、网络故障、进程故障和系统故障)影响数据库系统的操作,影响数据库中数据的正确性,甚至破坏数据库,使数据库中全部或部分数据丢失。因此当发生上述故障后,希望能重构这个完整的数据库,该处理称为数据库恢复。恢复过程大致可以分为复原(Restore)与
- JavaEE开源快速开发平台G4Studio v5.0发布
無為子
我非常高兴地宣布,今天我们最新的JavaEE开源快速开发平台G4Studio_V5.0版本已经正式发布。
访问G4Studio网站
http://www.g4it.org
2013-04-06 发布G4Studio_V5.0版本
功能新增
(1). 新增了调用Oracle存储过程返回游标,并将游标映射为Java List集合对象的标
- Oracle显示根据高考分数模拟录取
百合不是茶
PL/SQL编程oracle例子模拟高考录取学习交流
题目要求:
1,创建student表和result表
2,pl/sql对学生的成绩数据进行处理
3,处理的逻辑是根据每门专业课的最低分线和总分的最低分数线自动的将录取和落选
1,创建student表,和result表
学生信息表;
create table student(
student_id number primary key,--学生id
- 优秀的领导与差劲的领导
bijian1013
领导管理团队
责任
优秀的领导:优秀的领导总是对他所负责的项目担负起责任。如果项目不幸失败了,那么他知道该受责备的人是他自己,并且敢于承认错误。
差劲的领导:差劲的领导觉得这不是他的问题,因此他会想方设法证明是他的团队不行,或是将责任归咎于团队中他不喜欢的那几个成员身上。
努力工作
优秀的领导:团队领导应该是团队成员的榜样。至少,他应该与团队中的其他成员一样努力工作。这仅仅因为他
- js函数在浏览器下的兼容
Bill_chen
jquery浏览器IEDWRext
做前端开发的工程师,少不了要用FF进行测试,纯js函数在不同浏览器下,名称也可能不同。对于IE6和FF,取得下一结点的函数就不尽相同:
IE6:node.nextSibling,对于FF是不能识别的;
FF:node.nextElementSibling,对于IE是不能识别的;
兼容解决方式:var Div = node.nextSibl
- 【JVM四】老年代垃圾回收:吞吐量垃圾收集器(Throughput GC)
bit1129
垃圾回收
吞吐量与用户线程暂停时间
衡量垃圾回收算法优劣的指标有两个:
吞吐量越高,则算法越好
暂停时间越短,则算法越好
首先说明吞吐量和暂停时间的含义。
垃圾回收时,JVM会启动几个特定的GC线程来完成垃圾回收的任务,这些GC线程与应用的用户线程产生竞争关系,共同竞争处理器资源以及CPU的执行时间。GC线程不会对用户带来的任何价值,因此,好的GC应该占
- J2EE监听器和过滤器基础
白糖_
J2EE
Servlet程序由Servlet,Filter和Listener组成,其中监听器用来监听Servlet容器上下文。
监听器通常分三类:基于Servlet上下文的ServletContex监听,基于会话的HttpSession监听和基于请求的ServletRequest监听。
ServletContex监听器
ServletContex又叫application
- 博弈AngularJS讲义(16) - 提供者
boyitech
jsAngularJSapiAngularProvider
Angular框架提供了强大的依赖注入机制,这一切都是有注入器(injector)完成. 注入器会自动实例化服务组件和符合Angular API规则的特殊对象,例如控制器,指令,过滤器动画等。
那注入器怎么知道如何去创建这些特殊的对象呢? Angular提供了5种方式让注入器创建对象,其中最基础的方式就是提供者(provider), 其余四种方式(Value, Fac
- java-写一函数f(a,b),它带有两个字符串参数并返回一串字符,该字符串只包含在两个串中都有的并按照在a中的顺序。
bylijinnan
java
public class CommonSubSequence {
/**
* 题目:写一函数f(a,b),它带有两个字符串参数并返回一串字符,该字符串只包含在两个串中都有的并按照在a中的顺序。
* 写一个版本算法复杂度O(N^2)和一个O(N) 。
*
* O(N^2):对于a中的每个字符,遍历b中的每个字符,如果相同,则拷贝到新字符串中。
* O(
- sqlserver 2000 无法验证产品密钥
Chen.H
sqlwindowsSQL ServerMicrosoft
在 Service Pack 4 (SP 4), 是运行 Microsoft Windows Server 2003、 Microsoft Windows Storage Server 2003 或 Microsoft Windows 2000 服务器上您尝试安装 Microsoft SQL Server 2000 通过卷许可协议 (VLA) 媒体。 这样做, 收到以下错误信息CD KEY的 SQ
- [新概念武器]气象战争
comsci
气象战争的发动者必须是拥有发射深空航天器能力的国家或者组织....
原因如下:
地球上的气候变化和大气层中的云层涡旋场有密切的关系,而维持一个在大气层某个层次
- oracle 中 rollup、cube、grouping 使用详解
daizj
oraclegroupingrollupcube
oracle 中 rollup、cube、grouping 使用详解 -- 使用oracle 样例表演示 转自namesliu
-- 使用oracle 的样列库,演示 rollup, cube, grouping 的用法与使用场景
--- ROLLUP , 为了理解分组的成员数量,我增加了 分组的计数 COUNT(SAL)
- 技术资料汇总分享
Dead_knight
技术资料汇总 分享
本人汇总的技术资料,分享出来,希望对大家有用。
http://pan.baidu.com/s/1jGr56uE
资料主要包含:
Workflow->工作流相关理论、框架(OSWorkflow、JBPM、Activiti、fireflow...)
Security->java安全相关资料(SSL、SSO、SpringSecurity、Shiro、JAAS...)
Ser
- 初一下学期难记忆单词背诵第一课
dcj3sjt126com
englishword
could 能够
minute 分钟
Tuesday 星期二
February 二月
eighteenth 第十八
listen 听
careful 小心的,仔细的
short 短的
heavy 重的
empty 空的
certainly 当然
carry 携带;搬运
tape 磁带
basket 蓝子
bottle 瓶
juice 汁,果汁
head 头;头部
- 截取视图的图片, 然后分享出去
dcj3sjt126com
OSObjective-C
OS 7 has a new method that allows you to draw a view hierarchy into the current graphics context. This can be used to get an UIImage very fast.
I implemented a category method on UIView to get the vi
- MySql重置密码
fanxiaolong
MySql重置密码
方法一:
在my.ini的[mysqld]字段加入:
skip-grant-tables
重启mysql服务,这时的mysql不需要密码即可登录数据库
然后进入mysql
mysql>use mysql;
mysql>更新 user set password=password('新密码') WHERE User='root';
mysq
- Ehcache(03)——Ehcache中储存缓存的方式
234390216
ehcacheMemoryStoreDiskStore存储驱除策略
Ehcache中储存缓存的方式
目录
1 堆内存(MemoryStore)
1.1 指定可用内存
1.2 驱除策略
1.3 元素过期
2 &nbs
- spring mvc中的@propertysource
jackyrong
spring mvc
在spring mvc中,在配置文件中的东西,可以在java代码中通过注解进行读取了:
@PropertySource 在spring 3.1中开始引入
比如有配置文件
config.properties
mongodb.url=1.2.3.4
mongodb.db=hello
则代码中
@PropertySource(&
- 重学单例模式
lanqiu17
单例Singleton模式
最近在重新学习设计模式,感觉对模式理解更加深刻。觉得有必要记下来。
第一个学的就是单例模式,单例模式估计是最好理解的模式了。它的作用就是防止外部创建实例,保证只有一个实例。
单例模式的常用实现方式有两种,就人们熟知的饱汉式与饥汉式,具体就不多说了。这里说下其他的实现方式
静态内部类方式:
package test.pattern.singleton.statics;
publ
- .NET开源核心运行时,且行且珍惜
netcome
java.net开源
背景
2014年11月12日,ASP.NET之父、微软云计算与企业级产品工程部执行副总裁Scott Guthrie,在Connect全球开发者在线会议上宣布,微软将开源全部.NET核心运行时,并将.NET 扩展为可在 Linux 和 Mac OS 平台上运行。.NET核心运行时将基于MIT开源许可协议发布,其中将包括执行.NET代码所需的一切项目——CLR、JIT编译器、垃圾收集器(GC)和核心
- 使用oscahe缓存技术减少与数据库的频繁交互
Everyday都不同
Web高并发oscahe缓存
此前一直不知道缓存的具体实现,只知道是把数据存储在内存中,以便下次直接从内存中读取。对于缓存的使用也没有概念,觉得缓存技术是一个比较”神秘陌生“的领域。但最近要用到缓存技术,发现还是很有必要一探究竟的。
缓存技术使用背景:一般来说,对于web项目,如果我们要什么数据直接jdbc查库好了,但是在遇到高并发的情形下,不可能每一次都是去查数据库,因为这样在高并发的情形下显得不太合理——
- Spring+Mybatis 手动控制事务
toknowme
mybatis
@Override
public boolean testDelete(String jobCode) throws Exception {
boolean flag = false;
&nbs
- 菜鸟级的android程序员面试时候需要掌握的知识点
xp9802
android
熟悉Android开发架构和API调用
掌握APP适应不同型号手机屏幕开发技巧
熟悉Android下的数据存储
熟练Android Debug Bridge Tool
熟练Eclipse/ADT及相关工具
熟悉Android框架原理及Activity生命周期
熟练进行Android UI布局
熟练使用SQLite数据库;
熟悉Android下网络通信机制,S