我的编程空间,编程开发者的网络收藏夹
学习永远不晚

SSM框架详细讲解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

SSM框架详细讲解

SSM框架

文章目录


介绍SSM框架<原理>

一、什么是SSM框架?

SSM框架是spring、spring MVC 、和mybatis框架的整合,是标准的MVC模式。标准的SSM框架有四层,分别是dao层(mapper),service层,controller层和View层。使用spring实现业务对象管理,使用spring MVC负责请求的转发和视图管理,mybatis作为数据对象的持久化引擎。

1)持久层:dao层(mapper)层 作用:主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此。

  • Dao层首先设计的是接口,然后再Spring的配置文件中定义接口的实现类。
  • 然后可以在模块中进行接口的调用来进行数据业务的处理。(不在关心接口的实现类是哪个类)
  • 数据源的配置以及有关数据库连接的参数都在Spring的配置文件中进行配置。

2)业务层:Service层 作用:Service层主要负责业务模块的逻辑应用设计。

  • 先设计接口然后再设计实类,然后再在Spring的配置文件中配置其实现的关联。(业务逻辑层的实现具体要调用到自己已经定义好的Dao的接口上)这样就可以在应用中调用Service接口来进行业务处理。
  • 建立好Dao之后再建立service层,service层又要在controller层之下,因为既要调用Dao层的接口又要提供接口给controller层。每个模型都有一个service接口,每个接口分别封装各自的业务处理的方法。

3)表现层:Controller层(Handler层) 作用:负责具体的业务模块流程的控制。

  • 配置也同样是在Spring的配置文件里面进行,
  • 调用Service层提供的接口来控制业务流程。
  • 业务流程的不同会有不同的控制器,在具体的开发中可以将我们的流程进行抽象的归纳,设计出可以重复利用的子单元流程模块。

4)View层 作用:主要和控制层紧密结合,主要负责前台jsp页面的表示。

各层之间的联系

这里是引用 DAO层,Service层这两个层次都可以单独开发,互相的耦合度很低,完全可以独立进行,这样的一种模式在开发大项目的过程中尤其有优势,Controller,View层因为耦合度比较高,因而要结合在一起开发,但是也可以看作一个整体独立于前两个层进行开发。这样,在层与层之前我们只需要知道接口的定义,调用接口即可完成所需要的逻辑单元应用,一切显得非常清晰简单。

1.Spring

Spring里面的IOC容器和AOP是我们平时使用最多的。 1)IOC(控制反转) 它可以装载bean,也是一种降低对象之间耦合关系的设计思想。(比如租房子。以前租房子需要一个房子一个房子找,费时费力,然后现在加入一个房屋中介,把你需要的房型告诉中介,就可以直接选到需要的房子,中介就相当于spring容器。) 2)AOP(面向切面) 是面向对象开发的一种补充,它允许开发人员在不改变原来模型的基础上动态的修改模型以满足新的需求,如:动态的增加日志、安全或异常处理等。AOP使业务逻辑各部分间的耦合度降低,提高程序可重用性,提高开发效率。

横切关注点:从每个方法中抽取出来的同一类非核心业务代码。 2.切面:封装横切信息点的类,每个关注点体现为一个通知方法。 3.通知:切面必须要完成的各个具体工作,也就是切面里的一个个方法。 4.目标:被通知的对象,也就是被通知方法所作用的对象。 5.代理:像目标对象应用通知之后所创建的代理对象。 6.连接点:横切关注点在程序代码中的具体体现,对应用程序执行的某个特定位置。(通俗来讲就是一个个的方法) 7.切入点:切入点就是定位连接点的方式。每个通知上的切入点表达式找到对应的连接点,执行通知之后连接点也就变成了切入点。

2.Spring MVC

<复杂版> 1、 用户发送请求至前端控制器DispatcherServlet。 2、 DispatcherServlet收到请求调用HandlerMapping处理器映射器。 3、 处理器映射器找到具体的处理器(可以根据xml配置、注解进行查找),生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet。 4、 DispatcherServlet调用HandlerAdapter处理器适配器。 5、 HandlerAdapter经过适配调用具体的处理器(Controller,也叫后端控制器)。 6、 Controller执行完成返回ModelAndView。 7、 HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet。 8、 DispatcherServlet将ModelAndView传给ViewReslover视图解析器。 9、 ViewReslover解析后返回具体View。 10、DispatcherServlet根据View进行渲染视图(即将模型数据填充至视图中)。 11、 DispatcherServlet响应用户。

<简单版> 1.客户端发送请求到DispacherServlet(分发器) 2.由DispacherServlet控制器查询HanderMapping,找到处理请求的Controller 3.Controller调用业务逻辑处理后,返回ModelAndView 4.DispacherSerclet查询视图解析器,找到ModelAndView指定的视图 5.视图负责将结果显示到客户端

3.Mybatis (核心是SqlSession)

mybatis是对jdbc的封装,它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件,Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。

二、代码实战

1.创建配置工程

1)创建maven工程 2)创建目录

  • class="lazy" data-src——main下创建两个文件夹(Java和resources)。
  • 和main同级的创建一个test,test里面创建一个Java。

3)配置工程

  • file——project structure——modules

4)创建包

  • 在class="lazy" data-src——java下创建问价夹(XXX),
  • (XXX)下创建entity,mapper,,service和util包。

5)配置依赖 pom.xml加入依赖,一个是Mybatis的,一个是MySQL的。

代码如下(示例):

          org.mybatis      mybatis      3.5.1              mysql      mysql-connector-java      5.1.36    

复制

2.代码实战(查询记录数)

1)设计数据库

1)创建实体类 在entity下new一个名为person的class

代码如下(示例):

public class Person {        private Integer Id;    private String name;    private String nickname;    private Integer age;    public Integer getId() {            return Id;    }    public void setId(Integer id) {            this.Id = id;    }    public String getName() {            return name;    }    public void setName(String name) {            this.name = name;    }    public String getNickname() {            return nickname;    }    public void setNickname(String nickname) {            this.nickname = nickname;    }    public Integer getAge() {            return age;    }    public void setAge(Integer age) {            this.age = age;    }    @Override    public String toString() {            return "Person{" +                "Id=" + Id +                ", name='" + name + '\'' +                ", nickname='" + nickname + '\'' +                ", age=" + age +                '}';    }}

复制

2)Mapper接口 定义方法(实体名+Mapper) 在mapper下创建一个名为PersonMapper的interface

public interface PersonMapper {        //定义查询记录方法数    public Integer findCount();    }

复制

3)resources包

  • resources包下创建cn包
  • cn包下创建kgc包
  • kgc包下创建一个XML(这里的xml文件名与mapper接口名一致) xml文件中有两个部分组成,一个是头部文件,一个是主体
//头文件:

复制

//查询映射标签(select):    

复制

(1)mapper叫根节点,根节点有个属性是namespace=””、namespace=””、的作用是映射我们mapper的全路径,在以后的使用中会自动映射成我们mapper的实现类 (2)select里面的Id=“”一般和我们PersonMapper里面的方法名保持一致 (3)返回值这里有一个专门的属性叫resultType=”java.lang.Integer” (4)方法名和返回值都对应之后看有无参数,如果有要加上parameterType=””

4)写sql语句`

            select count(*) from t_user                insert into t_user(name,nickname,age) values(#{    name},#{    nickname},#{    age})        

复制

测试类

    @Test    public void testInsert() throws Exception {            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        //5.调用接口的方法        Person p = new Person();        p.setName("李四");        p.setNickname("一个人的夜晚上");        p.setAge(22);        sqlSession.getMapper(PersonMapper.class).addPerson(p);        //6.提交实物,该行代码必须放在关闭sqlsession之前        sqlSession.commit();        sqlSession.close();    }

复制

3.代码实战(增删改查,模糊精确查询集合)

完整工程代码 Person类

package cn.kgc.entity;public class Person {        private Integer Id;    private String name;    private String nickname;    private Integer age;    public Integer getId() {            return Id;    }    public void setId(Integer id) {            this.Id = id;    }    public String getName() {            return name;    }    public void setName(String name) {            this.name = name;    }    public String getNickname() {            return nickname;    }    public void setNickname(String nickname) {            this.nickname = nickname;    }    public Integer getAge() {            return age;    }    public void setAge(Integer age) {            this.age = age;    }    @Override    public String toString() {            return "Person{" +                "Id=" + Id +                ", name='" + name + '\'' +                ", nickname='" + nickname + '\'' +                ", age=" + age +                '}';    }}

复制

PersonMapper类

package cn.kgc.mapper;import cn.kgc.entity.Person;import org.apache.ibatis.annotations.Param;import java.util.List;public interface PersonMapper {        //定义查询记录方法数    public Integer findCount();    //增加    public Integer addPerson(Person person);    //修改功能    public Integer updatePerson(Person person);    //删除功能    public Integer delById(Integer Id);    //删除功能2    public Integer delById2(Person person);    //查询对象    public Person findById(Integer Id);    //查询集合    public List findAll();    //模糊查询    public List findByName(String name);    //通过用户名和昵称 绝对查询    public List findByPerson(Person person);    //通过用户名和昵称 绝对查询2    public List findByPerson2(@Param("name")String name,@Param("nickname")String nickname);    //测试¥(不安全)符号和#(安全)的作用    public List findColList(@Param("colname")String colname);}

复制

MybatisUtil类

package cn.kgc.util;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;import java.io.InputStream;public class MytabisUtil {        private static SqlSessionFactory factory = null;    static {            try {                InputStream in = Resources.getResourceAsStream("mybatis-config.xml");            SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();            factory = builder.build(in);        }catch (IOException e){                e.printStackTrace();        }    }    //获取SqlSession对象    public static SqlSession getSqlSession(){            SqlSession sqlSession = null;        if(factory!=null){                sqlSession = factory.openSession();        }        return sqlSession;    }}

复制

PersonMapper.xml

            select * from t_user where id = #{    Id}                select * from t_user where `name` like concat('%',#{    name},'%')                select * from t_user where  `name` = #{    name} and nickname = #{    nickname}        

复制

jdbc.properties(配置文件)

driver=com.mysql.jdbc.Driverurl=jdbc:mysql://localhost:3306/db_202125username=rootpassword=123

复制

mybatis-config.xml

                                                                                                                                                                                                                                                                                                                        

复制

TestMybatis类

import cn.kgc.entity.Person;import cn.kgc.mapper.PersonMapper;import cn.kgc.util.MytabisUtil;import jdk.internal.util.xml.impl.Input;import org.apache.ibatis.io.Resources;import org.apache.ibatis.session.SqlSession;import org.apache.ibatis.session.SqlSessionFactory;import org.apache.ibatis.session.SqlSessionFactoryBuilder;import org.junit.Test;import java.io.IOException;import java.io.InputStream;import java.util.List;public class TestMybatis {        @Test    public void testHelloWorld() throws IOException {            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        //5.调用接口的方法        Integer count = sqlSession.getMapper(PersonMapper.class).findCount();        //6.输出对应的返回值count        System.out.println("count:" + count);        //7.关闭 SqlSession        sqlSession.close();    }    @Test    public void testInsert() throws Exception {            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        //5.调用接口的方法        Person p = new Person();        p.setName("李四");        p.setNickname("一个人的夜晚上");        p.setAge(22);        sqlSession.getMapper(PersonMapper.class).addPerson(p);        //6.提交实物,该行代码必须放在关闭sqlsession之前        sqlSession.commit();        sqlSession.close();    }    @Test    public void testupdate() throws Exception {            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        Person p2 = new Person();        p2.setId(2);        p2.setName("赵四");        p2.setNickname("来啊,造作啊");        p2.setAge(23);        sqlSession.getMapper(PersonMapper.class).updatePerson(p2);        //6.提交实物,该行代码必须放在关闭sqlsession之前        sqlSession.commit();        sqlSession.close();    }    @Test    public void testdel() throws  Exception{            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        sqlSession.getMapper(PersonMapper.class).delById(2);        sqlSession.commit();        sqlSession.close();    }    @Test    public void testdel2 () throws Exception{            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        Person person = new Person();        person.setId(2);        sqlSession.getMapper(PersonMapper.class).delById2(person);        sqlSession.commit();        sqlSession.close();    }    @Test    public void testfindById () throws Exception{            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        Person person = sqlSession.getMapper(PersonMapper.class).findById(1);        System.out.println("id"+ person.getId()+"name"+ person.getName()+"nickname"+ person.getNickname()+"age"+ person.getAge());        sqlSession.close();    }    @Test    public void testfindAll () throws IOException{           String str ="mybatis-config.xml";        InputStream in =Resources.getResourceAsStream(str);        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        SqlSessionFactory factory = builder.build(in);        SqlSession sqlSession = factory.openSession();        List all = sqlSession.getMapper(PersonMapper.class).findAll();        for(Person p:all){                System.out.println(p);        }        sqlSession.close();    }    @Test    public void testfindByName () throws IOException{            String str ="mybatis-config.xml";        InputStream in =Resources.getResourceAsStream(str);        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        SqlSessionFactory factory = builder.build(in);        SqlSession sqlSession = factory.openSession();        List list = sqlSession.getMapper(PersonMapper.class).findByName("wqz");        for(Person p:list){                System.out.println(p);        }        sqlSession.close();    }    @Test    public void testfindByPerson () throws IOException{            String str ="mybatis-config.xml";        InputStream in =Resources.getResourceAsStream(str);        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        SqlSessionFactory factory = builder.build(in);        SqlSession sqlSession = factory.openSession();        Person person = new Person();        List list = sqlSession.getMapper(PersonMapper.class).findByPerson(person);        for(Person p:list){                System.out.println(p);        }        sqlSession.close();    }    @Test    public void findByPerson2 () throws Exception {            //1.通过流的机制获取主配置文件mybatis-config.xml的主要配置信息        InputStream in = Resources.getResourceAsStream("mybatis-config.xml");        //2.实例化SqlSessionFactoryBuilder对象        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();        //3.调用builder对象的builder()方法,获取SqlSessionFactory对象        SqlSessionFactory factory = builder.build(in);        //4.调用factory对象的openSession()方法,获取SqlSession对象        SqlSession sqlSession = factory.openSession();        String name = "王五";        String nickname = "123";        List list = sqlSession.getMapper(PersonMapper.class).findByPerson2(name,nickname);        for(Person p:list){                System.out.println("name:"+p.getName()+"nickname"+p.getNickname());        }        sqlSession.close();    }    @Test    public void testfindCount(){            SqlSession sqlSession = MytabisUtil.getSqlSession();        Integer count = sqlSession.getMapper(PersonMapper.class).findCount();        System.out.println(count);    }    @Test    public void findColList(){            SqlSession sqlSession = MytabisUtil.getSqlSession();        List colList = sqlSession.getMapper(PersonMapper.class).findColList("Id");        for (Person p:colList){                System.out.println(p);        }    }}

复制

pom.xml

  4.0.0  war  20211125  org.example  20211125  1.0-SNAPSHOT                    org.mortbay.jetty        maven-jetty-plugin        6.1.7                                            8888              30000                                ${    project.build.directory}/${    pom.artifactId}-${    pom.version}          /                                org.mybatis      mybatis      3.5.1              mysql      mysql-connector-java      5.1.36              junit      junit      4.12      test          

来源地址:https://blog.csdn.net/m0_60814318/article/details/128403613

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

SSM框架详细讲解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SSM框架讲解(史上最详细的文章)

SSM框架(白痴都看完都会) 文章目录 SSM框架(白痴都看完都会)介绍SSM框架一、什么是SSM框架?1.Spring2.Spring MVC3.Mybatis (核心是SqlSession) 二、代码实战1.创建配置工程2.
2023-08-24

Flutter路由框架Fluro使用教程详细讲解

在Flutter应用开发过程中,除了使用Flutter官方提供的路由外,还可以使用一些第三方路由框架来实现页面管理和导航,Fluro作为一款优秀的Flutter企业级路由框架,Fluro的使用比官方提供的路由框架要复杂一些,但是却非常适合中大型项目
2022-11-13

关于OpenStack的架构详细讲解

欢迎各位阅读本篇文章,OpenStack是一个开源的云计算管理平台项目,由几个主要的组件组合起来完成具体工作。本篇文章讲述了关于OpenStack的架构详细讲解,编程学习网教育平台提醒各位:本篇文章纯干货~因此大家一定要认真阅读本篇文章哦!
关于OpenStack的架构详细讲解
2024-04-23

SpringSecurity概念及整合ssm框架的示例详解

用户登录系统时我们协助SpringSecurity把用户对应的角色、权限组装好,同时把各个资源所要求的权限信息设定好,剩下的“登录验证”、“权限验证”等等工作都交给SpringSecurity,对SpringSecurity整合ssm框架相关知识感兴趣的朋友跟随小编一起看看吧
2022-12-16

Java OkHttp框架源码超详细解析

okhttp是一个第三方类库,用于android中请求网络。这是一个开源项目,是安卓端最火热的轻量级框架,由移动支付Square公司贡献(该公司还贡献了Picasso和LeakCanary) 。用于替代HttpUrlConnection和Apache HttpClient
2022-11-13

SpringCloudNetflixRibbon超详细讲解

这篇文章主要介绍了SpringCloud笔记HoxtonNetflix之Ribbon负载均衡,Ribbon是管理HTTP和TCP服务客户端的负载均衡器,Ribbon具有一系列带有名称的客户端(NamedClient),对SpringCloudRibbon负载均衡相关知识感兴趣的朋友一起看看吧
2022-11-13

C++BoostAtomic详细讲解

Boost是为C++语言标准库提供扩展的一些C++程序库的总称。Boost库是一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进程的开发引擎之一,是为C++语言标准库提供扩展的一些C++程序库的总称
2022-11-21

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录