- Android 蓝牙音频audio-a2dp分析
短距WCN协议开发分享
Bluetooth手机平板穿戴知识分享hfpandroid蓝牙bluetoothaudio
同学,别退出呀,我可是全网最牛逼的Android蓝牙分析博主,我写了上百篇蓝牙文章,请点击下面了解本专栏,进入本博主主页看看再走呗,一定不会让你后悔的,记得一定要去看主页置顶文章哦。Android系统中,对音频设备进行管理的,主要为AudioFlinger与AudioPolicyService。从职能分布上来讲,AudioPolicyService是策略的制定者,比如什么时候打开音频接口设备、某种
- 【bluedroid】A2dp Source播放流程源码分析(1)
byte轻骑兵
解读Android通信协议蓝牙BluedroidC++
在蓝牙音频传输领域,A2DP(AdvancedAudioDistributionProfile,高级音频分发协议)扮演着关键角色,它能够实现高质量音频(如立体声音乐)通过蓝牙在不同设备间的传输。在Android系统所采用的Bluedroid蓝牙协议栈里,A2DPSource承担着音频流发送的重任,将音频数据传输至A2DPSink(像车载音响、蓝牙耳机等接收设备)。一、概述Bluedroid作为An
- Windows11下清理Docker Desktop与wsl的C盘空间占用_wsl清理缓存(1)
m0_60607675
2024年程序员学习docker缓存容器
//【数据卷的磁盘占用】//2-删除不再使用的数据卷dockervolumeprune或者dockervolumerm$(dockervolumels-q)//【BuildCache的磁盘占用】//3-删除buildcache磁盘占用dockerbuilderprune//【4-一键清理】dockersystemprune
步入烟尘
Python超入门指南全册pandas数据清洗开发语言python
本文已收录于《Python超入门指南全册》本专栏专门针对零基础和需要进阶提升的同学所准备的一套完整教学,从基础到精通不断进阶深入,后续还有实战项目,轻松应对面试,专栏订阅地址:https://blog.csdn.net/mrdeam/category_12647587.html优点:订阅限时19.9付费专栏,私信博主还可进入全栈VIP答疑群,作者优先解答机会(代码指导、远程服务),群里大佬众多可以
- macOS Sequoia 15.3.2 (24D81) Boot ISO 原版可引导镜像下载
macos
macOSSequoia15.3.2(24D81)BootISO原版可引导镜像下载iPhone镜像、Safari浏览器重大更新和AppleIntelligence等众多全新功能令Mac使用体验再升级请访问原文链接:https://sysin.org/blog/macOS-Sequoia-boot-iso/查看最新版。原创作品,转载请保留出处。作者主页:sysin.org2025年3月12发布的ma
- 融云 IM 干货丨如何确保私有云IMKit的跨平台兼容性?
融云im即时通讯
确保私有云IMKit的跨平台兼容性,可以参考以下方法和建议:1.适配不同操作系统和硬件平台统一接口封装:通过抽象出公共的功能模块,使得SDK能在多个平台无缝工作。例如,融云的IMKit通过适配不同操作系统和硬件平台,确保在Android、iOS、Web等多个平台上集成使用。适配层技术:采用适配层技术,为不同平台提供对应的实现。例如,Android与iOS的UI渲染机制与线程管理存在明显区别,通过适
- 基于Linux C应用的0.96寸OLED硬件监测器页面
plmm烟酒僧
#香橙派linuxc语言oled0.96应用开发UI设计
一、前言开发板:香橙派5Plus。librknnrt.so版本:2.3.0。rknndriver:0.9.8。本次的页面设计基于之前写的手写FrameBuffer驱动:Linux手写FrameBuffer任意引脚驱动spi屏幕_rk3588framebuffer-CSDN博客https://blog.csdn.net/plmm__/article/details/145193029?spm=100
- 利用Qt + OpenGL 渲染 YUV数据,播放视频 mac版
jake2012
OpenGLQtQt3DC/C++
最近利用Qt渲染YUV数据,折腾了很久,最开始使用FFmpeg将YUV数据转换成RGB数据后在用qt绘制,很快得到了成功,但是cpu占用率太大,最后放弃了。在这先感谢来自文章http://blog.csdn.net/su_vast/article/details/52214642的作者,使用他的代码我实现了Windows上的YUV数据渲染。但是移植到mac上渲染不出来,经过折腾及对OpenGL的了
- 使用HBuilderX高效开发微信小程序全流程指南
斯~内克
vue知识点开发记录微信小程序notepad++小程序
一、为什么选择HBuilderX开发微信小程序?1.1跨平台开发利器HBuilderX作为DCloud推出的前端开发工具,凭借其强大的uniapp框架支持,已成为多端开发的首选工具。通过一套代码即可编译生成微信小程序、H5、Android/iOS等多端应用,极大提升开发效率。1.2深度集成的小程序开发支持内置微信小程序语法提示和代码块实时预览与真机调试功能自动处理路径别名和文件引用支持条件编译实现
- android camera慢动作,关于android:这可能是全网关于Camera慢动作录像SlowMotion介绍最全的文章了...
weixin_42465953
androidcamera慢动作
这是一篇对于慢动作录像(slowmotion)的文章,看完后置信你对慢动作录像不会再感到生疏了~这篇文章针对上面几点来开展:1)写这篇文章的原由?2)什么是慢动作录像(SlowMotionRecord)?3)Android上如何实现慢动作录像?4)调试demo下载地址?5)调试遇到的问题及解决?一、写这篇文章的原由?2月份的时候,在一个音视频开发的学习交换群里,有位网友问到“Android相机有啥
- mt4j android,Brainstorming und Mind-Mapping im Multi-Device-Kontext. Konzeption und prototypische Im...
Oxygenfia
mt4jandroid
摘要:DievorliegendeArbeitbeschreibtdieKonzeptionundprototypischeImplementierungeinerAnwendungzurelektronischenUnterstützungvonBrainstorming-undMind-Mapping-SitzungenaneinemmultitouchfhigenTabletopmitSma
- 存储优化(protobuf与mmkv)
Ya-Jun
androidkotlin
存储优化(protobuf与mmkv)在Android应用开发中,数据存储是一个基础且关键的环节。随着应用功能的日益复杂,数据量的增加,传统的存储方式如SharedPreferences、SQLite等在性能上的局限性逐渐显现。本文将深入探讨两种高效的存储优化方案:ProtocolBuffers(protobuf)和MMKV,帮助开发者构建更高效、更可靠的数据存储系统。一、传统存储方式的局限性在讨
- 第29讲 Android Camera2 API SlowMotion实战
deepinout_camera
AndroidCamera2API详解androidhtml5
本讲是AndroidCamera专题系列的第29讲,我们介绍AndroidCamera2API专题的SlowMotion实战,包括如下内容:判断是否支持SlowMotionSlowMotion支持的Size和FPSCamera流程控制MediaRecorder流程控制视频在线观看:极客笔记:极客笔记在线课程判断是否支持SlowMotionCamera方面Capability是否支持REQUEST_
- android系统架构的前世今生,超强Android进阶路线知识图谱
m0_64319298
程序员面试android移动开发
4.Android专有的驱动程序除了上面这些不同点之外,最重要的是,为了突出android特性,支持android设备,Android还对Linux设备驱动进行了增强,主要如下所示。1)AndroidBinder基于OpenBinder框架的一个驱动,用于提供Android平台的进程间通信(InterProcessCommunication,IPC)功能。源代码位于drivers/staging/
- 谈谈Android项目框架的前世今生
积木zz
Android笔记javaandroid项目架构kotlin
嗨,大家好,今天出了大太阳,真是美好的开始。这篇文章和大家说说Android届流行的三大框架,了解下架构的前世今生,以及我对于这些框架的一些认识和看法。三大框架区别MVC架构介绍Model:数据模型,比如我们从数据库或者网络获取数据View:视图,也就是我们的xml布局文件Controller:控制器,也就是我们的Activity模型联系View-->Controller,也就是反应View的一些
- android系统架构的前世今生,事件分发机制面试题
code高级开源
Android经验分享面试
前言一位网友在职场论坛上发了一个帖子,他说自己今年三十七岁了,是一名Android老兵,因为和上家公司的领导闹矛盾有了嫌隙,一气之下就裸辞了,如今已经辞职四个月了,也失业了四个月。每天都在努力投简历,共投出去了五百封简历,但只有三家通知自己过去面试,其他的都石沉大海。自己很纳闷,就找了一个做猎头的朋友询问,朋友说自己已经超龄了,没有什么岗位可以给自己这个年龄的人了,只有少数的能放宽到四十岁,但也不
- [android_gallery_4.0]gallery主要类介绍(四)
buleideli
Android开发androidAndroidANDROIDgalleryGallery
3.1.6SlideshowPage处理幻灯片动画显示。其类图如下。1)SlideshowView负责处理幻灯片播放的view。1.1)SlideshowAnimation其继承自Animation,负责具体幻灯片切换的显示。这里用到两个对象,mPrevAnimation负责上一张图片动画显示,mCurrentAnimation负责当前图片动画显示,显示动画效果就是扩大,淡入淡出。Animatio
- [android_gallery_4.0]gallery主要类介绍(一)
buleideli
Android开发androidAndroidANDROIDgalleryGallery
继续上篇,本篇介绍gallery的主要类。3.1.1Gallerygallery的主程序类。其类图如下。相关类说明1)GalleryActionBar用于在相册主界面出现的排序下拉框,如下。3.1.2AbstractGalleryActivity实现基本的activity操作的类,作为某些类的基类。其类图如下。相关类说明1)GalleryActivity接口类,主要是一些获取AbstractGal
- Android官方架构组件ViewModel_从前世今生到追本溯源
2401_84519718
程序员android架构
对于开发者来讲,在开发过程中可以大幅减少UI层和Model层相互调用的代码,转而将更多的重心投入到业务代码的编写。ViewModel的概念就是这样被提出来的,我对它的形容类似一个状态存储器,它存储着UI中各种各样的状态,以登录界面为例,我们很容易想到最简单的两种状态:classLoginViewModel{valusername:String//用户名输入框中的内容valpassword:Stri
- udp2raw android,关于udpspeeder和udp2raw部署的一些补充,及使用体会
鱼吞舟
udp2rawandroid
本帖最后由zardon于2018-1-1915:12编辑首先还是感谢开发者@wangyu-提供这么好用的工具,也感谢ASUS固件及插件的作者,本人上海电信,起初使用koolgame,效果相当明显。但是使用一段时间后会莫名大量丢包,似乎是被运营商QOS了,并且koolgame时不时掉线,在高峰期几乎无法正常使用。使用udpspeederV2+udp2raw之后晚上9-10点高峰期能够正常玩战地,没有
- qt----实现模拟键盘
爱吃巧克力的程序媛
上位机qt
https://blog.csdn.net/ken2232/article/details/129803417https://blog.csdn.net/judgejames/article/details/93191524?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2%7Edefau
- Android定时任务:深入理解AlarmManager和PendingIntent
t0_54program
编程问题解决手册android个人开发
在Android应用开发中,定时任务是非常常见的一个需求,特别是对于需要定期执行某些操作的应用来说,如每天凌晨进行数据处理或者更新。今天,我们将深入探讨如何在Android中使用AlarmManager和PendingIntent来实现一个每天凌晨运行的任务,并解决常见的开发问题。背景介绍最近,我在开发一个Android应用时,遇到了一些关于AlarmManager和PendingIntent的问
- macOS Sequoia 15.3.2 (24D81 | 24D2082) 正式版 ISO、IPSW、PKG 下载
macos
macOSSequoia15.3.2(24D81|24D2082)正式版ISO、IPSW、PKG下载iPhone镜像、Safari浏览器重大更新和AppleIntelligence等众多全新功能令Mac使用体验再升级请访问原文链接:https://sysin.org/blog/macOS-Sequoia/查看最新版。原创作品,转载请保留出处。作者主页:sysin.org2025年3月12发布的ma
- Android Retrofit 框架适配器模块深入源码分析(五)
&有梦想的咸鱼&
AndroidRetrofit原理androidretrofit
AndroidRetrofit框架适配器模块深入源码分析一、引言在Android开发中,网络请求是一个常见且重要的功能。Retrofit作为一个强大的网络请求框架,以其简洁的API和高度的可定制性受到了广泛的欢迎。适配器模块(CallAdapter)是Retrofit框架中非常重要的一部分,它负责将Call对象转换为其他类型,如Observable、Completable、Single等,从而实现
- K8S 持久化之静态PV (nfs)
oToyix
K8SDevopsk8s静态PVpvcpv
K8S持久化之静态PV(NFS)K8S部署见上篇:https://blog.csdn.net/oToyix/article/details/117963839一、概念PersistentvolumePersistentVolume(持久存储卷)简称PV,是一个K8S资源对象,所以我们可以单独创建一个PV。它不和Pod直接发生关系,而是通过PersistentVolumeClaim(PV索取),简称
- 【脑洞小剧场】零帧起手创业小公司之 UI设计稿初稿
Foyo Designer
技术职场小剧产品经理改行学it经验分享程序人生前端ui
点击此处查看脑洞小剧场合集https://blog.csdn.net/foyodesigner/category_12896948.html阳光透过办公室的窗户,洒在吴艾(UI工程师)的桌上,映照出他那张略显疲惫但又充满期待的脸。今天,他终于完成了那份被无数次催促、无数次修改的UI设计稿初稿。他深吸一口气,像是要把这份成果深深烙印在心里,然后满怀信心地点开了与产品经理程立新和前端程序员段码的群聊窗
- 【脑洞小剧场】零帧起手创业小公司之 第一次项目团建
Foyo Designer
技术职场小剧职场和发展程序人生创业创新远程工作跳槽改行学it
点击查看小剧场合集https://blog.csdn.net/foyodesigner/category_12896948.html阳光明媚的周末,本应是睡懒觉、打游戏或者追剧的好时光,但对于这家小公司的员工们来说,却迎来了他们成立以来的第一次团建活动。全栈工程师全搞一脸无奈地站在公司门口,看着手里的团建通知,心里嘀咕着:“团建?不会是又要加班吧?还说是去爬山,这是要累死我们吗?”场景一:全栈工程
- 【算法】C++深度优先搜索(DFS)全解析
JhonKI
算法c++深度优先
博客主页:https://blog.csdn.net/2301_779549673欢迎点赞收藏⭐留言如有错误敬请指正!本文由JohnKi原创,首发于CSDN未来很长,值得我们全力奔赴更美好的生活✨文章目录️一、DFS的基础概念️二、DFS的实现方式
代码如下:
long num, num1=0;
- PHP:6种方法获取文件的扩展名
IT独行者
PHP扩展名
PHP:6种方法获取文件的扩展名
1、字符串查找和截取的方法
1
$extension
=
substr
(
strrchr
(
$file
,
'.'
), 1);
2、字符串查找和截取的方法二
1
$extension
=
substr
- 面试111
文强chu
面试
1事务隔离级别有那些 ,事务特性是什么(问到一次)
2 spring aop 如何管理事务的,如何实现的。动态代理如何实现,jdk怎么实现动态代理的,ioc是怎么实现的,spring是单例还是多例,有那些初始化bean的方式,各有什么区别(经常问)
3 struts默认提供了那些拦截器 (一次)
4 过滤器和拦截器的区别 (频率也挺高)
5 final,finally final
- XML的四种解析方式
小桔子
domjdomdom4jsax
在平时工作中,难免会遇到把 XML 作为数据存储格式。面对目前种类繁多的解决方案,哪个最适合我们呢?在这篇文章中,我对这四种主流方案做一个不完全评测,仅仅针对遍历 XML 这块来测试,因为遍历 XML 是工作中使用最多的(至少我认为)。 预 备 测试环境: AMD 毒龙1.4G OC 1.5G、256M DDR333、Windows2000 Server
- wordpress中常见的操作
aichenglong
中文注册wordpress移除菜单
1 wordpress中使用中文名注册解决办法
1)使用插件
2)修改wp源代码
进入到wp-include/formatting.php文件中找到
function sanitize_user( $username, $strict = false
- 小飞飞学管理-1
alafqq
管理
项目管理的下午题,其实就在提出问题(挑刺),分析问题,解决问题。
今天我随意看下10年上半年的第一题。主要就是项目经理的提拨和培养。
结合我自己经历写下心得
对于公司选拔和培养项目经理的制度有什么毛病呢?
1,公司考察,选拔项目经理,只关注技术能力,而很少或没有关注管理方面的经验,能力。
2,公司对项目经理缺乏必要的项目管理知识和技能方面的培训。
3,公司对项目经理的工作缺乏进行指
- IO输入输出部分探讨
百合不是茶
IO
//文件处理 在处理文件输入输出时要引入java.IO这个包;
/*
1,运用File类对文件目录和属性进行操作
2,理解流,理解输入输出流的概念
3,使用字节/符流对文件进行读/写操作
4,了解标准的I/O
5,了解对象序列化
*/
//1,运用File类对文件目录和属性进行操作
//在工程中线创建一个text.txt
- getElementById的用法
bijian1013
element
getElementById是通过Id来设置/返回HTML标签的属性及调用其事件与方法。用这个方法基本上可以控制页面所有标签,条件很简单,就是给每个标签分配一个ID号。
返回具有指定ID属性值的第一个对象的一个引用。
语法:
&n
- 励志经典语录
bijian1013
励志人生
经典语录1:
哈佛有一个著名的理论:人的差别在于业余时间,而一个人的命运决定于晚上8点到10点之间。每晚抽出2个小时的时间用来阅读、进修、思考或参加有意的演讲、讨论,你会发现,你的人生正在发生改变,坚持数年之后,成功会向你招手。不要每天抱着QQ/MSN/游戏/电影/肥皂剧……奋斗到12点都舍不得休息,看就看一些励志的影视或者文章,不要当作消遣;学会思考人生,学会感悟人生
- [MongoDB学习笔记三]MongoDB分片
bit1129
mongodb
MongoDB的副本集(Replica Set)一方面解决了数据的备份和数据的可靠性问题,另一方面也提升了数据的读写性能。MongoDB分片(Sharding)则解决了数据的扩容问题,MongoDB作为云计算时代的分布式数据库,大容量数据存储,高效并发的数据存取,自动容错等是MongoDB的关键指标。
本篇介绍MongoDB的切片(Sharding)
1.何时需要分片
&nbs
- 【Spark八十三】BlockManager在Spark中的使用场景
bit1129
manager
1. Broadcast变量的存储,在HttpBroadcast类中可以知道
2. RDD通过CacheManager存储RDD中的数据,CacheManager也是通过BlockManager进行存储的
3. ShuffleMapTask得到的结果数据,是通过FileShuffleBlockManager进行管理的,而FileShuffleBlockManager最终也是使用BlockMan
- yum方式部署zabbix
ronin47
yum方式部署zabbix
安装网络yum库#rpm -ivh http://repo.zabbix.com/zabbix/2.4/rhel/6/x86_64/zabbix-release-2.4-1.el6.noarch.rpm 通过yum装mysql和zabbix调用的插件还有agent代理#yum install zabbix-server-mysql zabbix-web-mysql mysql-
- Hibernate4和MySQL5.5自动创建表失败问题解决方法
byalias
J2EEHibernate4
今天初学Hibernate4,了解了使用Hibernate的过程。大体分为4个步骤:
①创建hibernate.cfg.xml文件
②创建持久化对象
③创建*.hbm.xml映射文件
④编写hibernate相应代码
在第四步中,进行了单元测试,测试预期结果是hibernate自动帮助在数据库中创建数据表,结果JUnit单元测试没有问题,在控制台打印了创建数据表的SQL语句,但在数据库中
- Netty源码学习-FrameDecoder
bylijinnan
javanetty
Netty 3.x的user guide里FrameDecoder的例子,有几个疑问:
1.文档说:FrameDecoder calls decode method with an internally maintained cumulative buffer whenever new data is received.
为什么每次有新数据到达时,都会调用decode方法?
2.Dec
- SQL行列转换方法
chicony
行列转换
create table tb(终端名称 varchar(10) , CEI分值 varchar(10) , 终端数量 int)
insert into tb values('三星' , '0-5' , 74)
insert into tb values('三星' , '10-15' , 83)
insert into tb values('苹果' , '0-5' , 93)
- 中文编码测试
ctrain
编码
循环打印转换编码
String[] codes = {
"iso-8859-1",
"utf-8",
"gbk",
"unicode"
};
for (int i = 0; i < codes.length; i++) {
for (int j
- hive 客户端查询报堆内存溢出解决方法
daizj
hive堆内存溢出
hive> select * from t_test where ds=20150323 limit 2;
OK
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
问题原因: hive堆内存默认为256M
这个问题的解决方法为:
修改/us
- 人有多大懒,才有多大闲 (评论『卓有成效的程序员』)
dcj3sjt126com
程序员
卓有成效的程序员给我的震撼很大,程序员作为特殊的群体,有的人可以这么懒, 懒到事情都交给机器去做 ,而有的人又可以那么勤奋,每天都孜孜不倦得做着重复单调的工作。
在看这本书之前,我属于勤奋的人,而看完这本书以后,我要努力变成懒惰的人。
不要在去庞大的开始菜单里面一项一项搜索自己的应用程序,也不要在自己的桌面上放置眼花缭乱的快捷图标
- Eclipse简单有用的配置
dcj3sjt126com
eclipse
1、显示行号 Window -- Prefences -- General -- Editors -- Text Editors -- show line numbers
2、代码提示字符 Window ->Perferences,并依次展开 Java -> Editor -> Content Assist,最下面一栏 auto-Activation
- 在tomcat上面安装solr4.8.0全过程
eksliang
Solrsolr4.0后的版本安装solr4.8.0安装
转载请出自出处:
http://eksliang.iteye.com/blog/2096478
首先solr是一个基于java的web的应用,所以安装solr之前必须先安装JDK和tomcat,我这里就先省略安装tomcat和jdk了
第一步:当然是下载去官网上下载最新的solr版本,下载地址
- Android APP通用型拒绝服务、漏洞分析报告
gg163
漏洞androidAPP分析
点评:记得曾经有段时间很多SRC平台被刷了大量APP本地拒绝服务漏洞,移动安全团队爱内测(ineice.com)发现了一个安卓客户端的通用型拒绝服务漏洞,来看看他们的详细分析吧。
0xr0ot和Xbalien交流所有可能导致应用拒绝服务的异常类型时,发现了一处通用的本地拒绝服务漏洞。该通用型本地拒绝服务可以造成大面积的app拒绝服务。
针对序列化对象而出现的拒绝服务主要
- HoverTree项目已经实现分层
hvt
编程.netWebC#ASP.ENT
HoverTree项目已经初步实现分层,源代码已经上传到 http://hovertree.codeplex.com请到SOURCE CODE查看。在本地用SQL Server 2008 数据库测试成功。数据库和表请参考:http://keleyi.com/a/bjae/ue6stb42.htmHoverTree是一个ASP.NET 开源项目,希望对你学习ASP.NET或者C#语言有帮助,如果你对
- Google Maps API v3: Remove Markers 移除标记
天梯梦
google maps api
Simply do the following:
I. Declare a global variable:
var markersArray = [];
II. Define a function:
function clearOverlays() {
for (var i = 0; i < markersArray.length; i++ )
- jQuery选择器总结
lq38366
jquery选择器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
- 基础数据结构和算法六:Quick sort
sunwinner
AlgorithmQuicksort
Quick sort is probably used more widely than any other. It is popular because it is not difficult to implement, works well for a variety of different kinds of input data, and is substantially faster t
- 如何让Flash不遮挡HTML div元素的技巧_HTML/Xhtml_网页制作
刘星宇
htmlWeb
今天在写一个flash广告代码的时候,因为flash自带的链接,容易被当成弹出广告,所以做了一个div层放到flash上面,这样链接都是a触发的不会被拦截,但发现flash一直处于div层上面,原来flash需要加个参数才可以。
让flash置于DIV层之下的方法,让flash不挡住飘浮层或下拉菜单,让Flash不档住浮动对象或层的关键参数:wmode=opaque。
方法如下:
- Mybatis实用Mapper SQL汇总示例
wdmcygah
sqlmysqlmybatis实用
Mybatis作为一个非常好用的持久层框架,相关资料真的是少得可怜,所幸的是官方文档还算详细。本博文主要列举一些个人感觉比较常用的场景及相应的Mapper SQL写法,希望能够对大家有所帮助。
不少持久层框架对动态SQL的支持不足,在SQL需要动态拼接时非常苦恼,而Mybatis很好地解决了这个问题,算是框架的一大亮点。对于常见的场景,例如:批量插入/更新/删除,模糊查询,多条件查询,联表查询,