开源 多进程 框架 c++_有哪些值得推荐的c/c++开源框架与库

c/c++的项目也是各种各样的都有,微电子,物联网,桌面客户端,游戏,服务器开发等等。开源框架种类繁多,有哪些值得推荐的c/c++开源框架与库

框架

d7f3916db73a1af0c48b09c444ca9852.png

Apache C++ Standard Library : 是一系列算法,容器,迭代器和其他基本组件的集合

ASL : Adobe源代码库提供了同行的评审和可移植的C++源代码库。

Boost : 大量通用C++库的集合。

BDE : 来自于彭博资讯实验室的开发环境。

Cinder : 提供专业品质创造性编码的开源开发社区。

Bxxomfort : 轻量级的,只包含头文件的库,将C++ 11的一些新特性移植到C++03中。

Dlib : 使用契约式编程和现代C++科技设计的通用的跨平台的C++库。

EASTL : EA-STL公共部分

e0fc25c47b8389d191cc14af7f0ecf56.png

ffead-cpp : 企业应用程序开发框架

Folly : 由Facebook开发和使用的开源C++库。

JUCE : 包罗万象的C++类库,用于开发跨平台软件

libphenom : 用于构建高性能和高度可扩展性系统的事件框架。

LibSourcey : 用于实时的视频流和高性能网络应用程序的C++11 evented IO

LibU : C语言写的多平台工具库

Loki : C++库的设计,包括常见的设计模式和习语的实现。

MiLi : 只含头文件的小型C++库

openFrameworks : 开发C++工具包,用于创意性编码。

Qt : 跨平台的应用程序和用户界面框架

Reason : 跨平台的框架,使开发者能够更容易地使用Java,.Net和Python,同时也满足了他们对C++性能和优势的需求。

ROOT : 具备所有功能的一系列面向对象的框架,能够非常高效地处理和分析大量的数据,为欧洲原子能研究机构所用。

STLport : 是STL具有代表性的版本

STXXL : 用于额外的大型数据集的标准模板库。

Ultimate++ : C++跨平台快速应用程序开发框架

Windows Template Library : 用于开发Windows应用程序和UI组件的C++库

Yomm11 : C++11的开放multi-methods.

异步事件循环

10fd203bda319551f0cdcc5cec7d5468.png

Boost.Asio : 用于网络和底层I/O编程的跨平台的C++库。

libev : 功能齐全,高性能的时间循环,轻微地仿效libevent,但是不再像libevent一样有局限性,也修复了它的一些bug。

libevent : 事件通知库

libuv : 跨平台异步I/O。

libco : 协程,微信支持8亿用户同时在线的底层IO库。功能强大

ntyco : 纯c版的协程框架,代码短小精悍,适合嵌入工程。

libgo : golang风格的并发框架,C++11实现协程库

网络库

f5ac5f77d7a5a5c3001505f4d062a10b.png

ACE : C++面向对象网络变成工具包

Casablanca : C++ REST SDK

cpp-netlib : 高级网络编程的开源库集合

Dyad.c : C语言的异步网络

libCurl : 多协议文件传输库

Mongoose : 非常轻量级的网络服务器

Muduo : 用于Linux多线程服务器的C++非阻塞网络库

net_skeleton : C/C++的TCP 客户端/服务器库

WAFer : 基于C语言的超轻型软件平台,用于可扩展的服务器端和网络应用。 对于C编程人员,可以考虑node.js

Onion : C语言HTTP服务器库,其设计为轻量级,易使用。

POCO : 用于构建网络和基于互联网应用程序的C++类库,可以运行在桌面,服务器,移动和嵌入式系统。

RakNet : 为游戏开发人员提供的跨平台的开源C++网络引擎。

Tufao : 用于Qt之上的C++构建的异步Web框架。

WebSocket++ : 基于C++/Boost Aiso的websocket 客户端/服务器库

ZeroMQ : 高速,模块化的异步通信库

TCP/IP协议栈

f-stack : 腾讯开源的协议栈,基于DPDK的高性能用户态协议栈。

NtyTcp : 单线程的协议栈的,基于netmap,DPDK,rawSocket的实现。

LWIP : 针对 RAM 平台的精简版的 TCP/IP 协议栈实现。

mTCP : 针对多核系统的高可扩展性的用户空间 TCP/IP 协议栈。

4.4BSD : * nix的协议栈是源于4.4BSD的。

WEB应用框架

713b39a39e2dafd0cbb32ca4989e6262.png

Nginx : 一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。

Lighttpd : 一款开源 Web 服务器软件,安全快速,符合行业标准,适配性强并且针对高配置环境进行了优化。

Libmicrohttpd : GNU软件下的简单c库的Web服务器。API简单,快速。

shttpd : 基于Mongoose的Web服务器框架。

CivetWeb : 提供易于使用,强大的,C/C++嵌入式Web服务器,带有可选的CGI,SSL和Lua支持。

CppCMS : 免费高性能的Web开发框架(不是 CMS).

Crow : 一个C++微型web框架(灵感来自于Python Flask)

Kore : 使用C语言开发的用于web应用程序的超快速和灵活的web服务器/框架。

libOnion : 轻量级的库,帮助你使用C编程语言创建web服务器。

QDjango : 使用C++编写的,基于Qt库的web框架,试图效仿Django API,因此得此名。

Wt : 开发Web应用的C++库。

标准库,算法与函数

C++ Standard Library : 是一系列类和函数的集合,使用核心语言编写,也是C++ISO自身标准的一部分。

Standard Template Library : 标准模板库, STL

C POSIX library : POSIX系统的C标准库规范

ISO C++ Standards Committee : C++标准委员会

音频库

FMOD : 易于使用的跨平台的音频引擎和音频内容的游戏创作工具。

Maximilian : C++音频和音乐数字信号处理库

OpenAL : 开源音频库—跨平台的音频API

Opus : 一个完全开放的,免版税的,高度通用的音频编解码器

Speex : 免费编解码器,为Opus所废弃

Tonic : C++易用和高效的音频合成

Vorbis : Ogg Vorbis是一种完全开放的,非专有的,免版税的通用压缩音频格式。

生态学

lisequence : 用于表示和分析群体遗传学数据的C++库。

SeqAn : 专注于生物数据序列分析的算法和数据结构。

Vcflib : 用于解析和处理VCF文件的C++库

Wham : 直接把联想测试应用到BAM文件的基因结构变异。

压缩

bzip2 : 一个完全免费,免费专利和高质量的数据压缩

doboz : 能够快速解压缩的压缩库

PhysicsFS : 对各种归档提供抽象访问的库,主要用于视频游戏,设计灵感部分来自于Quake3的文件子系统。

KArchive : 用于创建,读写和操作文件档案(例如zip和 tar)的库,它通过QIODevice的一系列子类,使用gzip格式,提供了透明的压缩和解压缩的数据。

LZ4 : 非常快速的压缩算法

LZHAM : 无损压缩数据库,压缩比率跟LZMA接近,但是解压缩速度却要快得多。

LZMA : 7z格式默认和通用的压缩方法。

LZMAT : 及其快速的实时无损数据压缩库

miniz : 单一的C源文件,紧缩/膨胀压缩库,使用zlib兼容API,ZIP归档读写,PNG写方式。

Minizip : Zlib最新bug修复,支持PKWARE磁盘跨越,AES加密和IO缓冲。

Snappy : 快速压缩和解压缩

ZLib : 非常紧凑的数据流压缩库

ZZIPlib : 提供ZIP归档的读权限。

并发性

Boost.Compute : 用于OpenCL的C++GPU计算库

Bolt : 针对GPU进行优化的C++模板库

C++React : 用于C++11的反应性编程库

Intel TBB : Intel线程构件块

Libclsph : 基于OpenCL的GPU加速SPH流体仿真库

OpenCL : 并行编程的异构系统的开放标准

OpenMP : OpenMP API

Thrust : 类似于C++标准模板库的并行算法库

HPX : 用于任何规模的并行和分布式应用程序的通用C++运行时系统

VexCL : 用于OpenCL/CUDA 的C++向量表达式模板库。

密码学

fd3610e8c5d478d2e0fef1725703ea2b.png

Bcrypt : 一个跨平台的文件加密工具,加密文件可以移植到所有可支持的操作系统和处理器中。

BeeCrypt : 快速的加密图形库,功能强大,接口方便。

Botan : C++加密库

Crypto++ : 一个有关加密方案的免费的C++库

GnuPG : OpenPGP标准的完整实现

GnuTLS : 实现了SSL,TLS和DTLS协议的安全通信库

Libgcrypt : 基于GnuPG的加密图形库。

Libmcrypt : 线程安全,提供统一的API。

LibreSSL : 免费的SSL/TLS协议,属于2014 OpenSSL的一个分支

LibTomCrypt : 一个非常全面的,模块化的,可移植的加密工具

libsodium : 基于NaCI的加密库,固执己见,容易使用

Nettle : 底层的加密库

OpenSSL : 一个强大的,商用的,功能齐全的,开放源代码的加密库。

Tiny AES128 in C : 用C实现的一个小巧,可移植的实现了AES128ESB的加密算法

数据库

hiberlite : 用于Sqlite3的C++对象关系映射

hiredis : 用于Redis数据库的很简单的C客户端库

LevelDB : 快速键值存储库

LMDB : 符合数据库四大基本元素的嵌入键值存储

MySQL++ : 封装了MySql的C API的C++ 包装器

RocksDB : 来自Facebook的嵌入键值的快速存储

SQLite : 一个完全嵌入式的,功能齐全的关系数据库,只有几百KB,可以正确包含到你的项目中。

Redis : 一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库.

MongoDB : 一个基于分布式文件存储的数据库

调试

Boost.Test : Boost测试库

Catch : 一个很时尚的,C++原生的框架,只包含头文件,用于单元测试,测试驱动开发和行为驱动开发。

CppUnit : 由JUnit移植过来的C++测试框架

CTest : CMake测试驱动程序

GoogleTest : 谷歌C++测试框架

ig-debugheap : 用于跟踪内存错误的多平台调试堆

libtap : 用C语言编写测试

MemTrack : 用于C++跟踪内存分配

MicroProfile : 跨平台的网络试图分析器

minUnit : 使用C写的迷你单元测试框架,只使用了两个宏

Remotery : 用于web视图的单一C文件分析器

UnitTest++ : 轻量级的C++单元测试框架

容器

C++ B-Tree : 基于B树数据结构,实现命令内存容器的模板库

Hashmaps : C++中开放寻址哈希表算法的实现

游戏引擎

Cocos2d-x : 一个跨平台框架,用于构建2D游戏,互动图书,演示和其他图形应用程序。

Grit : 社区项目,用于构建一个免费的游戏引擎,实现开放的世界3D游戏。

lrrlicht : C++语言编写的开源高性能的实时#D引擎

PolyCode : C++实现的用于创建游戏的开源框架(与Lua绑定)。

图形库

bgfx : 跨平台的渲染库

Cairo : 支持多种输出设备的2D图形库

Horde3D : 一个小型的3D渲染和动画引擎

magnum : C++11和OpenGL 2D/3D 图形引擎

Ogre 3D : 用C++编写的一个面向场景,实时,灵活的3D渲染引擎(并非游戏引擎)

OpenSceneGraph : 具有高性能的开源3D图形工具包

Panda3D : 用于3D渲染和游戏开发的框架,用Python和C++编写。

Skia : 用于绘制文字,图形和图像的完整的2D图形库

urho3d : 跨平台的渲染和游戏引擎。

图像处理

ca29748ea2f425535dc194fc457be1b8.png

Boost.GIL : 通用图像库

CImg : 用于图像处理的小型开源C++工具包

FreeImage : 开源库,支持现在多媒体应用所需的通用图片格式和其他格式。

GDCM : Grassroots DICOM 库

ITK : 跨平台的开源图像分析系统

Magick++ : ImageMagick程序的C++接口

OpenCV : 开源计算机视觉类库

tesseract-ocr : OCR引擎

VIGRA : 用于图像分析通用C++计算机视觉库

VTK : 用于3D计算机图形学,图像处理和可视化的开源免费软件系统。

国际化

gettext : GNU gettext

IBM ICU : 提供Unicode 和全球化支持的C、C++ 和Java库

libiconv : 用于不同字符编码之间的编码转换库

Json库

frozen : C/C++的Jason解析生成器

Jansson : 进行编解码和处理Jason数据的C语言库

jbson : C++14中构建和迭代BSON data,和Json 文档的库

JeayeSON : 非常健全的C++ JSON库,只包含头文件

JSON++ : C++ JSON 解析器

json-parser : 用可移植的ANSI C编写的JSON解析器,占用内存非常少

json11 : 一个迷你的C++11 JSON库

jute : 非常简单的C++ JSON解析器

ibjson : C语言中的JSON解析和打印库,很容易和任何模型集成

libjson : 轻量级的JSON库

PicoJSON : C++中JSON解析序列化,只包含头文件

Qt-Json : 用于JSON数据和 QVariant层次间的相互解析的简单类

QJson : 将JSON数据映射到QVariant对象的基于Qt的库

RepidJSON : 用于C++的快速JSON 解析生成器,包含SAX和DOM两种风格的API

YAJL : C语言中快速流JSON解析库

日志

Boost.Log : 设计非常模块化,并且具有扩展性

easyloggingpp : C++日志库,只包含单一的头文件。

Log4cpp : 一系列C++类库,灵活添加日志到文件,系统日志,IDSA和其他地方。

templog : 轻量级C++库,可以添加日志到你的C++应用程序中

机器学习,人工智能

btsk : 游戏行为树启动器工具

Evolving Objects : 基于模板的,ANSI C++演化计算库,能够帮助你非常快速地编写出自己的随机优化算法。

Caffe : 快速的神经网络框架

CCV : 以C语言为核心的现代计算机视觉库

mlpack : 可扩展的C++机器学习库

OpenCV : 开源计算机视觉库

Recommender : 使用协同过滤进行产品推荐/建议的C语言库。

SHOGUN : Shogun 机器学习工具

sofia-ml : 用于机器学习的快速增量算法套件

数学库

Armadillo : 高质量的C++线性代数库,速度和易用性做到了很好的平衡。语法和MatlAB很相似

blaze : 高性能的C++数学库,用于密集和稀疏算法。

ceres-solver : 来自谷歌的C++库,用于建模和解决大型复杂非线性最小平方问题。

CGal : 高效,可靠的集合算法集合

CML : 用于游戏和图形的免费C++数学库

Eigen : 高级C++模板头文件库,包括线性代数,矩阵,向量操作,数值解决和其他相关的算法。

GMTL : 数学图形模板库是一组广泛实现基本图形的工具。

GMP : 用于个高精度计算的C/C++库,处理有符号整数,有理数和浮点数。

多媒体库

GStreamer : 构建媒体处理组件图形的库

LIVE555 Streaming Media : 使用开放标准协议(RTP/RTCP, RTSP, SIP) 的多媒体流库

libVLC : libVLC (VLC SDK)媒体框架

QtAV : 基于Qt和FFmpeg的多媒体播放框架,能够帮助你轻而易举地编写出一个播放器

SDL : 简单直控媒体层

SFML : 快速,简单的多媒体库

物理学

Box2D : 2D的游戏物理引擎。

Bullet : 3D的游戏物理引擎。

Chipmunk : 快速,轻量级的2D游戏物理库

LiquidFun : 2D的游戏物理引擎

ODE : 开放动力学引擎-开源,高性能库,模拟刚体动力学。

ofxBox2D : Box2D开源框架包装器。

Simbody : 高性能C++多体动力学/物理库,模拟关节生物力学和机械系统,像车辆,机器人和人体骨骼。

机器人学

MOOS-Ivp : 一组开源C++模块,提供机器人平台的自主权,尤其是自主的海洋车辆。

MRPT : 移动机器人编程工具包

PCL : 点云库是一个独立的,大规模的开放项目,用于2D/3D图像和点云处理。

Robotics Library : 一个独立的C++库,包括机器人动力学,运动规划和控制。

RobWork : 一组C++库的集合,用于机器人系统的仿真和控制。

ROS : 机器人操作系统,提供了一些库和工具帮助软件开发人员创建机器人应用程序。

科学计算

FFTW : 用一维或者多维计算DFT的C语言库。

GSL : GNU科学库。

脚本

ChaiScript : 用于C++的易于使用的嵌入式脚本语言。

Lua : 用于配置文件和基本应用程序脚本的小型快速脚本引擎。

luacxx : 用于创建Lua绑定的C++ 11 API

SWIG : 一个可以让你的C++代码链接到JavaScript,Perl,PHP,Python,Tcl和Ruby的包装器/接口生成器

V7 : 嵌入式的JavaScript 引擎。

V8 : 谷歌的快速JavaScript引擎,可以被嵌入到任何C++应用程序中。

序列化

Cap'n Proto : 快速数据交换格式和RPC系统。

cereal : C++11 序列化库

FlatBuffers : 内存高效的序列化库

MessagePack : C/C++的高效二进制序列化库,例如 JSON

ProtoBuf : 协议缓冲,谷歌的数据交换格式。

ProtoBuf-c : C语言的协议缓冲实现

SimpleBinaryEncoding : 用于低延迟应用程序的对二进制格式的应用程序信息的编码和解码。

Thrift : 高效的跨语言IPC/RPC,用于C++,Java,Python,PHP,C#和其它多种语言中,最初由Facebook开发。

视频库

libvpx : VP8/VP9编码解码SDK

FFMpeg : 一个完整的,跨平台的解决方案,用于记录,转换视频和音频流。

libde265 : 开放的h.265视频编解码器的实现。

OpenH264 : 开源H.364 编解码器。

Theora : 免费开源的视频压缩格式。

XML库

Expat : 用C语言编写的xml解析库

LibXml2 : Gnome的xml C解析器和工具包

LibXml++ : C++的xml解析器

PugiXML : 用于C++的,支持XPath的轻量级,简单快速的XML解析器。

RapidXML : 试图创建最快速的XML解析器,同时保持易用性,可移植性和合理的W3C兼容性。

TinyXML : 简单小型的C++XML解析器,可以很容易地集成到其它项目中。

TinyXML2 : 简单快速的C++CML解析器,可以很容易集成到其它项目中。

TinyXML++ : TinyXML的一个全新的接口,使用了C++的许多许多优势,模板,异常和更好的异常处理。需要在的后台私信;资料’MF送

Xerces-C++ : 用可移植的C++的子集编写的XML验证解析器。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
https://blog.csdn.net/qq_44036990/article/details/104330168?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522162458824716780264041251%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=162458824716780264041251&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_v2~rank_v29-1-104330168.pc_search_result_control_group&utm_term=C%2B%2B%E5%8D%95%E9%93%BE%E8%A1%A8%E6%98%AF%E4%B8%80%E7%A7%8D%E9%93%BE%E5%BC%8F%E5%AD%98%E5%8F%96%E7%9A%84%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%EF%BC%8C%E7%94%A8%E4%B8%80%E7%BB%84%E5%9C%B0%E5%9D%80%E4%BB%BB%E6%84%8F%E7%9A%84%E5%AD%98%E5%82%A8%E5%8D%95%E5%85%83%E5%AD%98%E6%94%BE%E7%BA%BF%E6%80%A7%E8%A1%A8%E4%B8%AD%E7%9A%84%E6%95%B0%E6%8D%AE%E5%85%83%E7%B4%A0%E3%80%82%E9%93%BE%E8%A1%A8%E4%B8%AD%E7%9A%84%E6%95%B0%E6%8D%AE%E6%98%AF%E4%BB%A5%E7%BB%93%E7%82%B9%E6%9D%A5%E8%A1%A8%E7%A4%BA%E7%9A%84%EF%BC%8C%E6%AF%8F%E4%B8%AA%E7%BB%93%E7%82%B9%E7%9A%84%E6%9E%84%E6%88%90%EF%BC%9A%E5%85%83%E7%B4%A0%28%E6%95%B0%E6%8D%AE%E5%85%83%E7%B4%A0%E7%9A%84%E6%98%A0%E8%B1%A1%29%2B%E6%8C%87%E9%92%88%28%E6%8C%87%E7%A4%BA%E5%90%8E%E7%BB%A7%E5%85%83%E7%B4%A0%E5%AD%98%E5%82%A8%E4%BD%8D%E7%BD%AE%29%EF%BC%8C%E5%85%83%E7%B4%A0%E5%B0%B1%E6%98%AF%E5%AD%98%E5%82%A8%E6%95%B0%E6%8D%AE%E7%9A%84%E5%AD%98%E5%82%A8%E5%8D%95%E5%85%83%EF%BC%8C%E6%8C%87%E9%92%88%E5%B0%B1%E6%98%AF%E8%BF%9E%E6%8E%A5%E6%AF%8F%E4%B8%AA%E7%BB%93%E7%82%B9%E7%9A%84%E5%9C%B0%E5%9D%80%E6%95%B0%E6%8D%AE%E3%80%82%E5%A6%82%E4%B8%8B%E5%9B%BE%E6%89%80%E7%A4%BA%EF%BC%9A&spm=1018.2226.3001.4187
package com.example.tigongzhe; import android.R.integer; import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues; import android.content.Context; import android.content.UriMatcher; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.net.Uri; import android.provider.SyncStateContract.Helpers; import android.text.Selection; import android.util.Log; public class provider extends ContentProvider { private MyOpenHelper myOpenHelper; private SQLiteDatabase sqLiteDatabase; private static final UriMatcher URI_MATCHER=new UriMatcher(UriMatcher.NO_MATCH); private final String TAG="provider"; private static final String authority="com.example.tigongzhe.provider"; static { URI_MATCHER.addURI(authority, "contacter", 1); URI_MATCHER.addURI(authority, "contacter/#", 2); } private static final String _id="id"; private static final String name="name"; private static final String num="num"; @Override public boolean onCreate() { // TODO Auto-generated method stub myOpenHelper=new MyOpenHelper(getContext(), DB_Name, null, version_1); return true; } @Override public String getType(Uri uri) { // TODO Auto-generated method stub int flag=URI_MATCHER.match(uri); switch (flag) { case 2: return "vnd.android.cursor.item/contacter"; case 1: return "vnd.android.dir.item/contacter"; default: throw new IllegalArgumentException("异常参数"); } } @Override public Uri insert(Uri uri, ContentValues values) { // TODO Auto-generated method stub sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: sqLiteDatabase.insert(Table_Name, name, values); break; case 2: long id=sqLiteDatabase.insert(Table_Name, name, values); ContentUris.withAppendedId(uri, id); default: break; } return uri; } @Override public Cursor query(Uri uri, String[] arg1, String arg2, String[] arg3, String arg4) { // TODO Auto-generated method stub Cursor cursor; sqLiteDatabase=myOpenHelper.getReadableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); break; case 2: long id=ContentUris.parseId(uri); arg2=(arg2==null||"".equals(arg2.trim()))? _id+"="+id:arg2+"and"+_id+"="+id; cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); default: throw new IllegalArgumentException("参数错误"); } return cursor; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))? _id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); default: break; } return num; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))?_id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); default: throw new IllegalArgumentException("异常参数"); } return num; } private final String DB_Name = "mydb.db"; private final String Table_Name="contacter"; private final int version_1=1; private class MyOpenHelper extends SQLiteOpenHelper { public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } /** * @description 当数据表无连接时创建新的表 */ @Override public void onCreate(SQLiteDatabase db) { String sql = " create table if not exists " + Table_Name + "(id INTEGER PRIMARY KEY AUTOINCREMENT," + "name varchar(64),num varchar(64))"; db.execSQL(sql); } /** * @description 当版本更新时触发的方法 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = " drop table if exists " + Table_Name; db.execSQL(sql); onCreate(db); } } } +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ <?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.tigongzhe" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="8" android:targetSdkVersion="18" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.tigongzhe.MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <provider android:name=".provider" android:authorities="com.example.tigongzhe.provider" android:multiprocess="true" android:exported="true" android:permission="com.example.tigongzhe.permission" ></provider> </application> <permission android:name="com.example.tigongzhe.permission" android:protectionLevel="normal"></permission> </manifest> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++package com.example.tigongzhe; import android.R.integer; import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues; import android.content.Context; import android.content.UriMatcher; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.net.Uri; import android.provider.SyncStateContract.Helpers; import android.text.Selection; import android.util.Log; public class provider extends ContentProvider { private MyOpenHelper myOpenHelper; private SQLiteDatabase sqLiteDatabase; private static final UriMatcher URI_MATCHER=new UriMatcher(UriMatcher.NO_MATCH); private final String TAG="provider"; private static final String authority="com.example.tigongzhe.provider"; static { URI_MATCHER.addURI(authority, "contacter", 1); URI_MATCHER.addURI(authority, "contacter/#", 2); } private static final String _id="id"; private static final String name="name"; private static final String num="num"; @Override public boolean onCreate() { // TODO Auto-generated method stub myOpenHelper=new MyOpenHelper(getContext(), DB_Name, null, version_1); return true; } @Override public String getType(Uri uri) { // TODO Auto-generated method stub int flag=URI_MATCHER.match(uri); switch (flag) { case 2: return "vnd.android.cursor.item/contacter"; case 1: return "vnd.android.dir.item/contacter"; default: throw new IllegalArgumentException("异常参数"); } } @Override public Uri insert(Uri uri, ContentValues values) { // TODO Auto-generated method stub sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: sqLiteDatabase.insert(Table_Name, name, values); break; case 2: long id=sqLiteDatabase.insert(Table_Name, name, values); ContentUris.withAppendedId(uri, id); default: break; } return uri; } @Override public Cursor query(Uri uri, String[] arg1, String arg2, String[] arg3, String arg4) { // TODO Auto-generated method stub Cursor cursor; sqLiteDatabase=myOpenHelper.getReadableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); break; case 2: long id=ContentUris.parseId(uri); arg2=(arg2==null||"".equals(arg2.trim()))? _id+"="+id:arg2+"and"+_id+"="+id; cursor=sqLiteDatabase.query(Table_Name, arg1, arg2, arg3, null, null,arg4); default: throw new IllegalArgumentException("参数错误"); } return cursor; } @Override public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))? _id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.update(Table_Name, values,selection, selectionArgs); default: break; } return num; } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { // TODO Auto-generated method stub int num=0; sqLiteDatabase=myOpenHelper.getWritableDatabase(); int flag=URI_MATCHER.match(uri); switch (flag) { case 1: num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); break; case 2: long id=ContentUris.parseId(uri); selection=(selection==null||"".equals(selection.trim()))?_id+"="+id:selection+"and"+_id+"="+id; num=sqLiteDatabase.delete(Table_Name, selection, selectionArgs); default: throw new IllegalArgumentException("异常参数"); } return num; } private final String DB_Name = "mydb.db"; private final String Table_Name="contacter"; private final int version_1=1; private class MyOpenHelper extends SQLiteOpenHelper { public MyOpenHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } /** * @description 当数据表无连接时创建新的表 */ @Override public void onCreate(SQLiteDatabase db) { String sql = " create table if not exists " + Table_Name + "(id INTEGER PRIMARY KEY AUTOINCREMENT," + "name varchar(64),num varchar(64))"; db.execSQL(sql); } /** * @description 当版本更新时触发的方法 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = " drop table if exists " + Table_Name; db.execSQL(sql); onCreate(db); } } }
发现还是好多人没有找到C#Builder个人版的KEY,这时上传一个,放在Home目录就好(- Home directory: The location of the home directory varies by platform. Windows 95/98 (single-user): C:Windows Windows 95/98 (multi-user): C:WindowsProfiles Windows NT: C:WINNTProfiles Windows 2000/XP: C:Documents and Settings)//---------文件内容--------------------------THIS IS AN AUTO-GENERATED MESSAGE - PLEASE DO NOT REPLY TO THIS MESSAGEBDN Login Name: faming2002The attached file (reg299.txt) activates C#Builder 1 Personal Non-Commercial.To complete product registration, save the attached file intoyour home directory before starting C#Builder.NOTES:- The contents of this e-mail and the attached file are for yourexclusive use and should not be shared with others.- Save the file to your home directory, and it will be loadedautomatically the next time you start C#Builder.- Home directory: The location of the home directory varies by platform. Windows 95/98 (single-user): C:Windows Windows 95/98 (multi-user): C:WindowsProfiles Windows NT: C:WINNTProfiles Windows 2000/XP: C:Documents and Settings- In case this e-mail has no attachments, save this e-mail as a textfile named (reg299.txt) (Netscape: File | SaveAs | File) or (reg299.eml)(Outlook: File | SaveAs ) into your home directory.Additional C# Builder information is available at: http://www.borland.com/csharpbuilder/-----BEGIN BLOCK-----%AA1%B0%D0%00%00%02%8F%DE%DAL%2C%B2%F7%9DE%89%22%02%B3%81%90h%DD%0AK%E0%92%9C%11%CE%5DM%D4%80%F0%03%A0%3F%10%DD%F0%C6H%C3%12%3A%E8%D3%97T%86d%60%8D%B9%85P%CC%01y%BA%F9%ADa%BCJ3%82%D4%CFY%B4%06m%EC%85%96%0A%DEgY%E3%C5%A1X%E7i%3D%91%93%A7y%A7%10%11%FC%FD%E4I%D4%11%7E%DB%C5%9B%7C%DCT%2B%93%8D%93R%82%07%5D%EE%EE%8C%00%C1%0A%7C%8F%D9%89Z%D0cD%D4%8D%C4%06%8Ahj%82%A2%C9R%92%0Es%CC%C2%8C%5E%E9%0F%3B%BE%EE%AE%3D%C0M%0B%BD%E8%A2P%F4D%13%BC%F1%BEY%BA*%5E%8C%9D%ECl%8Bjf%B9%FD%E88%F0%082%AE%AC%A1%7B%9E_J%E7%DB%ECS%837%40%C6%F3%9Ap%D6o%7E%9B%90%D4E%88Gi%CA%A1%AD9%EB%18j%A0%98%98I%AFt_%E2%A2%EC%

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值