游戏电视苹果数码历史美丽
投稿投诉
美丽时装
彩妆资讯
历史明星
乐活安卓
数码常识
驾车健康
苹果问答
网络发型
电视车载
室内电影
游戏科学
音乐整形

(新手勿进,全是代码)ComponentScanCompon

  灵魂拷问ComponentScan注解是做什么的?basePackages的方式和basePackageClasses的方式有什么区别?你建议用哪个?为什么?useDefaultFilters有什么用?常见的过滤器有哪些类型?说说你知道的几个ComponentScan是在哪个类中处理的?说一下大概的解析过程?
  这些问题如果都ok,恭喜你,太优秀了,不知道没关系,一起来看看。背景介绍
  到目前为止,介绍了2种注册bean的方式:xml中bean元素的方式Bean注解标注方法的方式
  通常情况下,项目中大部分类都需要交给spring去管理,按照上面这2种方式,代码量还是挺大的。
  为了更方便bean的注册,Spring提供了批量的方式注册bean,方便大量bean批量注册,spring中的ComponentScan就是干这个事情的。ComponentScan
  ComponentScan用于批量注册bean。
  这个注解会让spring去扫描某些包及其子包中所有的类,然后将满足一定条件的类作为bean注册到spring容器容器中。
  具体需要扫描哪些包?以及这些包中的类满足什么条件时被注册到容器中,这些都可以通过这个注解中的参数动态配置。
  先来看一下这个注解的定义:Retention(RetentionPolicy。RUNTIME)Target(ElementType。TYPE)DocumentedRepeatable(ComponentScans。class)1publicinterfaceComponentScan{AliasFor(basePackages)String〔〕value()default{};AliasFor(value)String〔〕basePackages()default{};Classlt;?〔〕basePackageClasses()default{};Classlt;?extendsBeanNameGeneratornameGenerator()defaultBeanNameGenerator。class;Classlt;?extendsScopeMetadataResolverscopeResolver()defaultAnnotationScopeMetadataResolver。class;ScopedProxyModescopedProxy()defaultScopedProxyMode。DEFAULT;StringresourcePattern()default。class;booleanuseDefaultFilters()defaulttrue;Filter〔〕includeFilters()default{};Filter〔〕excludeFilters()default{};booleanlazyInit()defaultfalse;}定义上可以看出此注解可以用在任何类型上面,不过我们通常将其用在类上面。
  常用参数:
  value:指定需要扫描的包,如:com。javacode2018
  basePackages:作用同value;value和basePackages不能同时存在设置,可二选一
  basePackageClasses:指定一些类,spring容器会扫描这些类所在的包及其子包中的类
  nameGenerator:自定义bean名称生成器
  resourcePattern:需要扫描包中的那些资源,默认是:。class,即会扫描指定包中所有的class文件
  useDefaultFilters:对扫描的类是否启用默认过滤器,默认为true
  includeFilters:过滤器:用来配置被扫描出来的那些类会被作为组件注册到容器中
  excludeFilters:过滤器,和includeFilters作用刚好相反,用来对扫描的类进行排除的,被排除的类不会被注册到容器中
  lazyInit:是否延迟初始化被注册的bean
  1:Repeatable(ComponentScans。class),这个注解可以同时使用多个。
  ComponentScan工作的过程:
  1。Spring会扫描指定的包,且会递归下面子包,得到一批类的数组
  2。然后这些类会经过上面的各种过滤器,最后剩下的类会被注册到容器中
  所以玩这个注解,主要关注2个问题:
  第一个:需要扫描哪些包?通过value、backPackages、basePackageClasses这3个参数来控制
  第二:过滤器有哪些?通过useDefaultFilters、includeFilters、excludeFilters这3个参数来控制过滤器
  这两个问题搞清楚了,就可以确定哪些类会被注册到容器中。
  默认情况下,任何参数都不设置的情况下,此时,会将ComponentScan修饰的类所在的包作为扫描包;默认情况下useDefaultFilters为true,这个为true的时候,spring容器内部会使用默认过滤器,规则是:凡是类上有Repository、Service、Controller、Component这几个注解中的任何一个的,那么这个类就会被作为bean注册到spring容器中,所以默认情况下,只需在类上加上这几个注解中的任何一个,这些类就会自动交给spring容器来管理了。Component、Repository、Service、Controller
  这几个注解都是spring提供的。
  先说一下Component这个注解,看一下其定义:Target(ElementType。TYPE)Retention(RetentionPolicy。RUNTIME)DocumentedIndexedpublicinterfaceComponent{Stringvalue()default;}从定义中可以看出,这个注解可以用在任何类型上面。
  通常情况下将这个注解用在类上面,标注这个类为一个组件,默认情况下,被扫描的时候会被作为bean注册到容器中。
  value参数:被注册为bean的时候,用来指定bean的名称,如果不指定,默认为类名首字母小写。如:类UserService对应的beanname为userService
  再来看看Repository源码如下:Target({ElementType。TYPE})Retention(RetentionPolicy。RUNTIME)DocumentedComponentpublicinterfaceRepository{AliasFor(annotationComponent。class)Stringvalue()default;}Repository上面有Component注解。
  value参数上面有AliasFor(annotationComponent。class),设置value参数的时候,也相当于给Component注解中的value设置值。
  其他两个注解Service、Controller源码和Repository源码类似。
  这4个注解本质上是没有任何差别,都可以用在类上面,表示这个类被spring容器扫描的时候,可以作为一个bean组件注册到spring容器中。
  spring容器中对这4个注解的解析并没有进行区分,统一采用Component注解的方式进行解析,所以这几个注解之间可以相互替换。
  spring提供这4个注解,是为了让系统更清晰,通常情况下,系统是分层结构的,多数系统一般分为controller层、service层、dao层。
  controller通常用来标注controller层组件,service注解标注service层的组件,Repository标注dao层的组件,这样可以让整个系统的结构更清晰,当看到这些注解的时候,会和清晰的知道属于哪个层,对于spring来说,将这3个注解替换成Component注解,对系统没有任何影响,产生的效果是一样的。
  下面通过案例来感受ComponentScan各种用法。案例1:任何参数未设置UserControllerpackagecom。javacode2018。lesson001。demo22。test1。controller;importorg。springframework。stereotype。Controller;ControllerpublicclassUserController{}UserServicepackagecom。javacode2018。lesson001。demo22。test1。service;importorg。springframework。stereotype。Service;ServicepublicclassUserService{}UserDaopackagecom。javacode2018。lesson001。demo22。test1。dao;importorg。springframework。stereotype。Repository;RepositorypublicclassUserDao{}UserModelpackagecom。javacode2018。lesson001。demo22。test1;importorg。springframework。stereotype。Component;ComponentpublicclassUserModel{}
  上面几个类中,分别使用了4种注解。CompontentScan修饰的类packagecom。javacode2018。lesson001。demo22。test1;importorg。springframework。context。annotation。ComponentScan;ComponentScanpublicclassScanBean1{}上面几个类的结构图
  测试用例packagecom。javacode2018。lesson001。demo22;importcom。javacode2018。lesson001。demo22。test1。ScanBean1;importorg。junit。Test;importorg。springframework。context。annotation。AnnotationConfigApplicationContext;publicclassComponentScanTest{Testpublicvoidtest1(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean1。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}}1:使用AnnotationConfigApplicationContext作为ioc容器,将ScanBean作为参数传入。
  默认会扫描ScanBean类所在的包中的所有类,类上有Component、Repository、Service、Controller任何一个注解的都会被注册到容器中运行输出
  部分输出如下:userModelcom。javacode2018。lesson001。demo22。test1。UserModel595b007duserControllercom。javacode2018。lesson001。demo22。test1。controller。UserController72d1ad2euserDaocom。javacode2018。lesson001。demo22。test1。dao。UserDao2d7275fcuserServicecom。javacode2018。lesson001。demo22。test1。service。UserService399f45b1
  注意最后4行这几个bean,都被注册成功了。案例2:指定需要扫描的包
  指定需要扫毛哪些包,可以通过value或者basePackage来配置,二者选其一,都配置运行会报错,下面我们通过value来配置。ScanBean2packagecom。javacode2018。lesson001。demo22。test2;importorg。springframework。context。annotation。ComponentScan;ComponentScan({com。javacode2018。lesson001。demo22。test1。controller,com。javacode2018。lesson001。demo22。test1。service})publicclassScanBean2{}
  上面指定了2需要扫描的包,这两个包中有2个类。测试用例
  ComponentScanTest中新增个方法Testpublicvoidtest2(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean2。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}运行输出
  截取了关键几行如下:userControllercom。javacode2018。lesson001。demo22。test1。controller。UserControllerdd8ba08userServicecom。javacode2018。lesson001。demo22。test1。service。UserService245b4bdc
  可以看出只有controller包和service包中的2个类被注册为bean了。注意
  指定包名的方式扫描存在的一个隐患,若包被重名了,会导致扫描会失效,一般情况下面我们使用basePackageClasses的方式来指定需要扫描的包,这个参数可以指定一些类型,默认会扫描这些类所在的包及其子包中所有的类,这种方式可以有效避免这种问题。
  下面来看一下basePackageClasses的方式。案例:basePackageClasses指定扫描范围
  我们可以在需要扫描的包中定义一个标记的接口或者类,他们的唯一的作用是作为basePackageClasses的值,其他没有任何用途。下面我们定义这样一个接口packagecom。javacode2018。lesson001。demo22。test6。beans;publicinterfaceScanClass{}再来定义2个类,用Component注解标记packagecom。javacode2018。lesson001。demo22。test6。beans;importorg。springframework。stereotype。Component;ComponentpublicclassService1{}packagecom。javacode2018。lesson001。demo22。test6。beans;importorg。springframework。stereotype。Component;ComponentpublicclassService2{}来一个CompontentScan标记的类packagecom。javacode2018。lesson001。demo22。test6;importcom。javacode2018。lesson001。demo22。test6。beans。ScanClass;importorg。springframework。context。annotation。ComponentScan;ComponentScan(basePackageClassesScanClass。class)publicclassScanBean6{}测试用例
  ComponentScanTest中新增个方法Testpublicvoidtest6(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean6。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}运行输出service1com。javacode2018。lesson001。demo22。test6。beans。Service179924bservice2com。javacode2018。lesson001。demo22。test6。beans。Service27b9a4292includeFilters的使用用法
  再来看一下includeFilters这个参数的定义:Filter〔〕includeFilters()default{};
  是一个Filter类型的数组,多个Filter之间为或者关系,即满足任意一个就可以了,看一下Filter的代码:Retention(RetentionPolicy。RUNTIME)Target({})interfaceFilter{FilterTypetype()defaultFilterType。ANNOTATION;AliasFor(classes)Classlt;?〔〕value()default{};AliasFor(value)Classlt;?〔〕classes()default{};String〔〕pattern()default{};}可以看出Filter也是一个注解,参数:
  type:过滤器的类型,是个枚举类型,5种类型
  ANNOTATION:通过注解的方式来筛选候选者,即判断候选者是否有指定的注解
  ASSIGNABLETYPE:通过指定的类型来筛选候选者,即判断候选者是否是指定的类型
  ASPECTJ:ASPECTJ表达式方式,即判断候选者是否匹配ASPECTJ表达式
  REGEX:正则表达式方式,即判断候选者的完整名称是否和正则表达式匹配
  CUSTOM:用户自定义过滤器来筛选候选者,对候选者的筛选交给用户自己来判断
  value:和参数classes效果一样,二选一
  classes:3种情况如下
  当typeFilterType。ANNOTATION时,通过classes参数可以指定一些注解,用来判断被扫描的类上是否有classes参数指定的注解
  当typeFilterType。ASSIGNABLETYPE时,通过classes参数可以指定一些类型,用来判断被扫描的类是否是classes参数指定的类型
  当typeFilterType。CUSTOM时,表示这个过滤器是用户自定义的,classes参数就是用来指定用户自定义的过滤器,自定义的过滤器需要实现org。springframework。core。type。filter。TypeFilter接口
  pattern:2种情况如下
  当typeFilterType。ASPECTJ时,通过pattern来指定需要匹配的ASPECTJ表达式的值
  当typeFilterType。REGEX时,通过pattern来自正则表达式的值案例:扫描包含注解的类需求
  我们自定义一个注解,让标注有这些注解的类自动注册到容器中代码实现
  下面的代码都在com。javacode2018。lesson001。demo22。test3包中。定义一个注解packagecom。javacode2018。lesson001。demo22。test3;importjava。lang。annotation。;DocumentedTarget(ElementType。TYPE)Retention(RetentionPolicy。RUNTIME)publicinterfaceMyBean{}创建一个类,使用这个注解标注packagecom。javacode2018。lesson001。demo22。test3;MyBeanpublicclassService1{}再来一个类,使用spring中的Compontent标注packagecom。javacode2018。lesson001。demo22。test3;importorg。springframework。stereotype。Component;ComponentpublicclassService2{}再来一个类,使用CompontentScan标注packagecom。javacode2018。lesson001。demo22。test3;importorg。springframework。context。annotation。ComponentScan;importorg。springframework。context。annotation。FilterType;ComponentScan(includeFilters{ComponentScan。Filter(typeFilterType。ANNOTATION,classesMyBean。class)})publicclassScanBean3{}
  上面指定了Filter的type为注解的类型,只要类上面有MyBean注解的,都会被作为bean注册到容器中。测试用例
  ComponentScanTest中新增个测试用例Testpublicvoidtest3(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean3。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}运行输出,截取了主要的几行service1com。javacode2018。lesson001。demo22。test3。Service16b81ce95service2com。javacode2018。lesson001。demo22。test3。Service22a798d51
  Service1上标注了MyBean注解,被注册到容器了,但是Service2上没有标注MyBean啊,怎么也被注册到容器了?
  原因:Service2上标注了Compontent注解,而CompontentScan注解中的useDefaultFilters默认是true,表示也会启用默认的过滤器,而默认的过滤器会将标注有Component、Repository、Service、Controller这几个注解的类也注册到容器中
  如果我们只想将标注有MyBean注解的bean注册到容器,需要将默认过滤器关闭,即:useDefaultFiltersfalse,我们修改一下ScanBean3的代码如下:ComponentScan(useDefaultFiltersfalse,不启用默认过滤器includeFilters{ComponentScan。Filter(typeFilterType。ANNOTATION,classesMyBean。class)})publicclassScanBean3{}
  再次运行test3输出:service1com。javacode2018。lesson001。demo22。test3。Service1294425a7扩展:自定义注解支持定义bean名称
  上面的自定义的MyBean注解,是无法指定bean的名称的,可以对这个注解做一下改造,加个value参数来指定bean的名称,如下:DocumentedTarget(ElementType。TYPE)Retention(RetentionPolicy。RUNTIME)Component1publicinterfaceMyBean{AliasFor(annotationComponent。class)2Stringvalue()default;3}重点在于1和2这2个地方的代码,通过上面的参数可以间接给Component注解中的value设置值。
  这块用到了AliasFor注解,对这块不了解的,可以去看一下:java注解详解及spring对注解的增强
  修改一下Service1的代码:MyBean(service1Bean)publicclassService1{}
  运行test3用例输出:service1Beancom。javacode2018。lesson001。demo22。test3。Service1222545dc
  此时bean名称就变成了service1Bean。案例:包含指定类型的类
  下面的代码都位于com。javacode2018。lesson001。demo22。test4包中。来个接口packagecom。javacode2018。lesson001。demo22。test4;publicinterfaceIService{}
  让spring来进行扫描,类型满足IService的都将其注册到容器中。来2个实现类packagecom。javacode2018。lesson001。demo22。test4;publicclassService1implementsIService{}packagecom。javacode2018。lesson001。demo22。test4;publicclassService2implementsIService{}来一个CompontentScan标注的类packagecom。javacode2018。lesson001。demo22。test4;importorg。springframework。context。annotation。ComponentScan;importorg。springframework。context。annotation。FilterType;ComponentScan(useDefaultFiltersfalse,不启用默认过滤器includeFilters{ComponentScan。Filter(typeFilterType。ASSIGNABLETYPE,classesIService。class)1})publicclassScanBean4{}
  1:被扫描的类满足IService。class。isAssignableFrom(被扫描的类)条件的都会被注册到spring容器中来个测试用例
  ComponentScanTest中新增个测试用例Testpublicvoidtest4(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean4。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}运行输出service1com。javacode2018。lesson001。demo22。test4。Service16379ebservice2com。javacode2018。lesson001。demo22。test4。Service2294425a7自定义Filter用法
  有时候我们需要用到自定义的过滤器,使用自定义过滤器的步骤:1。设置Filter中type的类型为:FilterType。CUSTOM2。自定义过滤器类,需要实现接口:org。springframework。core。type。filter。TypeFilter3。设置Filter中的classses为自定义的过滤器类型
  来看一下TypeFilter这个接口的定义:FunctionalInterfacepublicinterfaceTypeFilter{booleanmatch(MetadataReadermetadataReader,MetadataReaderFactorymetadataReaderFactory)throwsIOException;}
  是一个函数式接口,包含一个match方法,方法返回boolean类型,有2个参数,都是接口类型的,下面介绍一下这2个接口。MetadataReader接口
  类元数据读取器,可以读取一个类上的任意信息,如类上面的注解信息、类的磁盘路径信息、类的class对象的各种信息,spring进行了封装,提供了各种方便使用的方法。
  看一下这个接口的定义:publicinterfaceMetadataReader{返回类文件的资源引用ResourcegetResource();返回一个ClassMetadata对象,可以通过这个读想获取类的一些元数据信息,如类的class对象、是否是接口、是否有注解、是否是抽象类、父类名称、接口名称、内部包含的之类列表等等,可以去看一下源码ClassMetadatagetClassMetadata();获取类上所有的注解信息AnnotationMetadatagetAnnotationMetadata();}MetadataReaderFactory接口
  类元数据读取器工厂,可以通过这个类获取任意一个类的MetadataReader对象。
  源码:publicinterfaceMetadataReaderFactory{返回给定类名的MetadataReader对象MetadataReadergetMetadataReader(StringclassName)throwsIOException;返回指定资源的MetadataReader对象MetadataReadergetMetadataReader(Resourceresource)throwsIOException;}自定义Filter案例需求
  我们来个自定义的Filter,判断被扫描的类如果是IService接口类型的,就让其注册到容器中。代码实现
  来个自定义的TypeFilter类:packagecom。javacode2018。lesson001。demo22。test5;importcom。javacode2018。lesson001。demo22。test4。IService;importorg。springframework。core。type。ClassMetadata;importorg。springframework。core。type。classreading。MetadataReader;importorg。springframework。core。type。classreading。MetadataReaderFactory;importorg。springframework。core。type。filter。TypeFilter;importjava。io。IOException;publicclassMyFilterimplementsTypeFilter{parammetadataReaderparammetadataReaderFactoryreturnthrowsIOExceptionOverridepublicbooleanmatch(MetadataReadermetadataReader,MetadataReaderFactorymetadataReaderFactory)throwsIOException{ClasscurClassnull;try{当前被扫描的类curClassClass。forName(metadataReader。getClassMetadata()。getClassName());}catch(ClassNotFoundExceptione){e。printStackTrace();}判断curClass是否是IService类型booleanresultIService。class。isAssignableFrom(curClass);returnresult;}}来一个CompontentScan标注的类packagecom。javacode2018。lesson001。demo22。test5;importorg。springframework。context。annotation。ComponentScan;importorg。springframework。context。annotation。FilterType;ComponentScan(basePackages{com。javacode2018。lesson001。demo22。test4},useDefaultFiltersfalse,不启用默认过滤器includeFilters{ComponentScan。Filter(typeFilterType。CUSTOM,classesMyFilter。class)1})publicclassScanBean5{}
  1:type为FilterType。CUSTOM,表示Filter是用户自定义的,classes为自定义的过滤器再来个测试用例
  ComponentScanTest中新增个测试用例Testpublicvoidtest5(){AnnotationConfigApplicationContextcontextnewAnnotationConfigApplicationContext(ScanBean5。class);for(StringbeanName:context。getBeanDefinitionNames()){System。out。println(beanNamecontext。getBean(beanName));}}运行输出service1com。javacode2018。lesson001。demo22。test4。Service14cc451f2service2com。javacode2018。lesson001。demo22。test4。Service26379ebexcludeFilters
  配置排除的过滤器,满足这些过滤器的类不会被注册到容器中,用法上面和includeFilters用一样,这个我就不演示了,可以自己玩玩ComponentScan重复使用
  从这个注解的定义上可以看出这个注解可以同时使用多个,如:ComponentScan(basePackageClassesScanClass。class)ComponentScan(useDefaultFiltersfalse,不启用默认过滤器includeFilters{ComponentScan。Filter(typeFilterType。ASSIGNABLETYPE,classesIService。class)})publicclassScanBean7{}
  还有一种写法,使用ComponentScans的方式:ComponentScans({ComponentScan(basePackageClassesScanClass。class),ComponentScan(useDefaultFiltersfalse,不启用默认过滤器includeFilters{ComponentScan。Filter(typeFilterType。ASSIGNABLETYPE,classesIService。class)})})publicclassScanBean7{}Spring中这块的源码
  CompontentScan注解是被下面这个类处理的org。springframework。context。annotation。ConfigurationClassPostProcessor
  这个类非常非常关键,主要用户bean的注册,前面我们介绍的Configuration,Bean注解也是被这个类处理的。
  还有下面这些注解:PropertySourceImportImportResourceCompontent
  以上这些注解都是被ConfigurationClassPostProcessor这个类处理的,内部会递归处理这些注解,完成bean的注册。
  以CompontentScan来说一下过程,第一次扫描之后会得到一批需要注册的类,然后会对这些需要注册的类进行遍历,判断是否有上面任意一个注解,如果有,会将这个类交给ConfigurationClassPostProcessor继续处理,直到递归完成所有bean的注册。
  想成为高手,这个类是必看的。总结ComponentScan用于批量注册bean,spring会按照这个注解的配置,递归扫描指定包中的所有类,将满足条件的类批量注册到spring容器中可以通过value、basePackages、basePackageClasses这几个参数来配置包的扫描范围可以通过useDefaultFilters、includeFilters、excludeFilters这几个参数来配置类的过滤器,被过滤器处理之后剩下的类会被注册到容器中指定包名的方式配置扫描范围存在隐患,包名被重命名之后,会导致扫描实现,所以一般我们在需要扫描的包中可以创建一个标记的接口或者类,作为basePackageClasses的值,通过这个来控制包的扫描范围CompontScan注解会被ConfigurationClassPostProcessor类递归处理,最终得到所有需要注册的类。作者:路人甲Java
  链接:https:mp。weixin。qq。comsMPMouZPsdLww7RgDZNtzLQ

中国女排新队长尘埃落定?集训照曝光,26岁主力与领导侃侃而谈在蔡斌走马上任担任中国女排的主教练后,就对女排进行了大刀阔斧的改革,首先就是抽调各地方队的优秀队员组建训练营,最终确定了新一届的中国女排阵容。在蔡斌治下的新一届中国女排已……常吃玉米,身体会出现什么变化?适量食用玉米可以有效增加饱腹感,减少其他高热量食物的摄入,是减肥者的好选择,同时,膳食纤维还可以加速胃肠蠕动,促进有害物质的排出,帮助缓解便秘。对于种植玉米作物的农民来说……李晓霞携女儿罕见出镜,女儿梦想当奥运冠军,身后一大片奖杯抢镜李晓霞是我们国家曾经的女乒绝对主力,也是第4位完成大满贯的女运动员,不过和几位前辈相比,她的存在感相对低一些,自从离开乒坛后,几乎很少公开露面。近日,李晓霞在参加某活动的时候,……GitHub推荐changedetection。iochangedetection。io是一个GitHub上优秀的开源项目,目前项目点赞数已达:8。5k,基于FlaskSelenium构建的Web服务,可以在目标网站发生变化时发……一个无法用数据衡量的NBA球星巴蒂尔肖恩巴蒂尔(ShaneBattier),1978年9月9日出生于美国密歇根州伯明翰市,职业生涯效力过孟菲斯灰熊队、休斯顿火箭队以及迈阿密热火队,主职小前锋,偶尔也可以客串大前锋……三星990ProSSD被爆出健康度问题下降过快,官方拒绝保修三星在去年8月发布了990ProSSD,提供了1TB、2TB和4TB三种容量。其采用了PCIe4。0x4接口,搭载了三星新推出的自研主控芯片,以及新的VNAND闪存技术,顺序读……海南潮玩东方闹元宵!元宵节最全活动指南元宵节是我国重要的传统节日传承至今已有两千多年的历史赏花灯,吃汤圆、猜灯谜今年元宵东方都有哪些特色民俗活动?这份活动指南请收下东方大剧院招募……菲诗小铺水光无瑕气垫修颜乳真假菲诗小铺气垫cc真假鉴菲诗小铺水光无瑕气垫修颜乳是任意依恋中国民女神裴秀智的专属气垫,在剧中简直将女神打扮得更加出落了,让很多妹纸也动了女主同款的小心思,不过化妆品虽好,要学会辨别真假啊哦!菲诗小铺……新西兰再度提前对全球旅客重新开放,并大范围开放技术移民昨天,总理JacindaArdern通过Zoom在BusinessNZ聚会上发表讲话,新西兰将于2022年7月31日晚上11点59分重新向全球旅行者开放,新西兰再次向世界发布了……永磁DD直驱微蒸烘干除螨海信HD1014FD蒸汽洗烘一体机测写在前面一直想着给爸妈换一台新洗衣机,家里的洗衣机还是波轮的,洗衣服很容易缠绕,而且南方阴雨天气非常多,衣服不干已是常态,这次洗衣机出故障,索性换一台新的。爸妈的观念里,……从哲学上看,爱的本质是什么?来看看弗洛姆关于爱的言论:幼稚的是我爱你,因为我需要你,而成熟的爱是我需要你,因为我爱你。我想大部分的人都是经历过前面那种状态的吧?我爱你,因为我需要你。我之……中国。山西。盂县。藏山讲述的是2600多年前的悲壮历史,免门藏山是中国古代故事《赵氏孤儿》发源地,国家4A级风景区,位于山西省阳泉市盂县藏山村的太行山脉。主体建筑排列在一条中轴线上这是一段春秋时期舍己救人的悲壮历史。后人把盂……
比分来到2比2,保罗夺冠路再蒙阴影,鹈鹕能否黑九创历史?季后赛首轮,布克的伤病给太阳的季后赛征程蒙上了阴影,而媒体也开始普遍看衰太阳,认为鹈鹕会上演黑九奇迹。目前太阳和鹈鹕的比分来到了2比2,下一场会回到凤凰城。对季后赛而言,所谓的……火爆全网的醋酸面料到底是什么?和真丝有什么区别?醋酸纤维面世至今已有一百多年的历史,但直至今夏,网上关于它的讨论屈指可数,但今年却突然爆火,开始成为各大品牌争相追逐的焦点,成为某书、某乎、某宝上的行业热点讨论话题。对醋……沉默十几秒!韩国女足进球功臣落泪,中国将与日本争冠东亚杯小组赛第二轮落幕,中国女足VS韩国女足,上半场34分钟韩国中场崔宥莉破门,下半场,伤停5个多月的王霜替补换下张琳艳,第76分钟汪琳琳接肖裕仪传球,在乱战中扳平比分,最终中……线路周末自驾2天凤堰梯田后柳水乡雁山瀑布石泉老街轻奢自驾五星享受往年同期拍摄。。。。。。春暖花开约起来自驾穿梭在风景大道上处处都是花海沿途风光迤逦,美不胜收各式各样的花朵、小草……48岁贾静雯大秀曼妙身材!肤如凝脂依旧美得让人窒息近日,著名女星贾静雯《乘风2023》录制路透释出,魅力十足。图中,48岁的贾静雯俏脸清爽干练,浓眉大眼,唇红齿白,头扎高马尾,皮肤紧致,状态十分不错,美得让人窒息。贾静雯……社论引导金融机构让利实体经济畅通经济金融良性循环近来,有两组数据体现出金融机构与包括规模以上工业企业等在内的实体经济利润方面的落差。一是,截至3月底,包括中国银行、农业银行、工商银行、建设银行、交通银行、邮储银行在内的……在泰国住酒店,出门前为什么枕头底留下20泰铢?回来就有惊喜在泰国住酒店的老司机为何出门前都会在枕头旁留20泰铢?泰国姑娘表示,回到酒店,会有意想不到的惊喜。(此处已添加小程序,请到今日头条客户端查看)大家都知道,泰国是东南……除了吃药,这8种食物也可以帮助提升血小板!想知道?看这里除了吃药,这8种食物也可以帮助提升血小板,有益血液病恢复!想知道?看这里!夏末初秋血液病患者,受天气的影响会出现胸闷、心烦、身热、汗多尿少、舌苔黄腻等诸多不适,病情不免反……一位成都妈妈的教育梦让每个特殊的孩子,都能更有尊严地生活记者丨李宇欣大部分人,可能从未接触过这类孩子:他们有一双明亮的眼睛,眼神却飘忽不定;他们可能突然在课堂上情绪爆发,大声哭喊;部分孩子不会写自己的名字,甚……彩电寒冬之下,品牌加速分化,全球老三或将ampampquot2022年即将过半,全球尚未真正从疫情走出,又遭遇了俄乌地缘冲突,全球超级通胀。美联储货币紧缩等诸多负向因素影响下,让全球彩电市场的整体需求进一步陷入衰退期。据行业知名数……你有过自信吗?你现在还自信吗?你未来能自信吗?真正的自信不依赖于外物!自信是一种内心的力量,是一种对自己的肯定和信任。外界的评价和物质的支持无疑可以带来暂时的满足感和信心,但真正的自信却需要从内心深处发掘和建立起来。……红米K50重回低价,天玑81002K直屏大电池,真香机再度爆在手机市场当中,性价比一直是永恒的话题,广大厂商都有自己的真香机,尤其是国产品牌那几家,旗下的子品牌都很给力,目前最有实力的应该是红米,今年的K50系列大杀四方,成为中端价位的……
友情链接:易事利快生活快传网聚热点七猫云快好知快百科中准网快好找文好找中准网快软网