zoukankan      html  css  js  c++  java
  • python的起源

    Python简介及入门

    • 编程语言简介

    • Python介绍

    • Python安装

    • pycharm安装

    • 中文编码

    1.编程语言简介

    编程语言概念

      编程语言(programming language),是用来定义计算机程序的形式语言。它是一种被标准化的交流技巧,用来向计算机发出指令。一种计算机语言让程序员能够准确地定义计算机所需要使用的数据,并精确地定义在不同情况下所应当采取的行动。

    编程语言的类别

      编程语言分为机器语言汇编语言以及高级语言,一般我们将机器语言、汇编语言这样的偏向底层设计的统称为低级语言,低级语言并不是说功能少,而是编程起来相对于高级语言来说太麻烦了。

      高级语言的代表有:Python、Java、PHP、C#·····等等;

      低级语言的代表有:汇编、C······等等;

      编程语言也可以分为编译型语言解释型语言

      编译型语言:编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快;

           解释型语言:解释器则是只在执行程序时,才一条一条的解释成机器语言给计算机来执行,所以运行速度是不如编译后的程序运行的快的;

           当然还有其它的,比如静态语言动态语言强类型定义语言弱类型定义语言

      

      编译型VS解释型

           编译型

           优点:编译器一般会有预编译的过程对代码进行优化。因为编译只做一次,运行时不需要编译,所以编译型语言的程序执行效率高,可以脱离语言环境独立运行。

           缺点:编译之后如果需要修改就需要整个模块重新编译。编译的时候根据对应的运行环境生成机器码,不同的操作系统之间移植就会有问题,需要根据运行的操作系统环境编译不同的可执行文件。

           解释型

           优点:有良好的平台兼容性,在任何环境中都可以运行,前提是安装了解释器,灵活,修改代码的时候直接修改就行,可以快速部署,不用停止维护。

           缺点:每次运行的时候都要解释一遍,性能上不如编译型语言。

      

    高级语言和低级语言的优缺点

      高级语言,优点:开发快,缺点:执行效率低,需要将代码转化成字节码,然后将字节码再编译成机器码供计算机识别执行;

      低级语言,优点:执行效率高,缺点:开发慢,不放变编写,编写后的代码可直接供计算机识别执行;

    机器码和字节码介绍

      机器码:

      学名机器语言指令,有时也被称为原生码(Native Code),是电脑的CPU可直接解读的数据。通常意义上来理解的话,机器码就是计算机可以直接执行,并且执行速度最快的代码,用机器语言编写程序,编程人员要首先熟记所用计算机的全部指令代码和代码的涵义。手编程序时,程序员得自己处理每条指令和每一数据的存储分配和输入输出,还得记住编程过程中每步所使用的工作单元处在何种状态。这是一件十分繁琐的工作,编写程序花费的时间往往是实际运行时间的几十倍或几百倍。而且,编出的程序全是些0和1的指令代码,直观性差,还容易出错。

      总体来说,机器码是电脑CPU直接读取运行的机器指令,运行速度最快,但是非常晦涩难懂,也比较难编写,一般从业人员接触不到。

      字节码:

      字节码(Bytecode)是一种包含执行程序、由一序列 op 代码/数据对 组成的二进制文件字节码是一种中间码,它比机器码更抽象,需要直译器转译后才能成为机器码的中间代码。通常情况下它是已经经过编译,但与特定机器码无关。字节码通常不像源码一样可以让人阅读,而是编码后的数值常量、引用、指令等构成的序列。字节码主要为了实现特定软件运行和软件环境、与硬件环境无关。字节码的实现方式是通过编译器和虚拟机器。编译器将源码编译成字节码,特定平台上的虚拟机器将字节码转译为可以直接执行的指令。

      总体来说,字节码是一种中间状态(中间码)的二进制代码(文件)。需要直译器转译后才能成为机器码。

      高级语言生成的是字节码,再由各语言的编译器进行编译后转成机器码供计算机执行。

      低级语言生成的是机器码,可直接由计算机执行。

    编码介绍

      编码是信息从一种形式或格式转换为另一种形式的过程也称为计算机编程语言的代码简称编码。用预先规定的方法将文字、数字或其它对象编成数码,或将信息、数据转换成规定的电脉冲信号。

      种类:

      ASCII、Unicode、utf8、gbk等等;

      a.ASCII

      目前计算机中用得最广泛的字符集及其编码,是由美国国家标准局(ANSI)制定的ASCII码。适用于所有拉丁文字字母,ASCII码有7位码和8位码两种形式。

      我们知道,在计算机内部,所有的信息最终都表示为一个二进制的字符串。每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称为一个字节(byte)。也就是说,一个字节一共可以用来表示256种不同的状态,每一个状态对应一个符号,就是256个符号,从 0000000到11111111。

      ASCII码一共规定了128个字符的编码,这128个符号(包括32个不能打印出来的控制符号),只占用了一个字节的后面7位,最前面的1位统一规定为0。

      缺点:英语用128个符号编码就够了,但是用来表示其他语言,128个符号是不够的。比如,在法语中,字母上方有注音符号,它就无法用ASCII码表示。于是,一些欧洲国家就决定,利用字节中闲置的最高位编入新的符号。比如,法语中的é的编码为130(二进制10000010)。这样一来,这些欧洲国家使用的编码 体系,可以表示最多256个符号。但是,这里又出现了新的问题。不同的国家有不同的字母,因此,哪怕它们都使用256个符号的编码方式,代表的字母却不一样。比如,130在法语编码中代表了 é,在希伯来语编码中却代表了字母Gimel (?),在俄语编码中又会代表另一个符号。但是不管怎样,所有这些编码方式中,0—127表示的符号是一样的,不一样的只是128—255的这一段。至于亚洲国家的文字,使用的符号就更多了,汉字就多达10万左右。一个字节只能表示256种符号,肯定是不够的,就必须使用多个字节表达一个符号。比如,简体中文常见的编码方式是GB2312,使用两个字节表示一个汉字,所以理论上最多可以表示256x256=65536个符号。

      b.Unicode

      世界上存在着多种编码方式,同一个二进制数字可以被解释成不同的符号。因此,要想打开一个文本文件,就必须知道它的编码方式,否则用错误的编码方式解读,就会出现乱码。为什么电子邮件经常出现乱码?就是因为发信人和收信人使用的编码方式不一样。

      可以想象,假如有一种编码,将世界上所有的符号都纳入其中。每一个符号都给予一个独一无二的编码,那么乱码问题就会消失。这就是Unicode,就像它的名字都表示的,这是一种所有符号的编码。

      缺点:浪费内存;我们已经知道,英文字母只用一个字节表示就够了,假如unicode统一规定,每个符号用三个或四个字节表示,那么每个英文字母前都必然有二到三 个字节是0,这对于存储来说是极大的浪费,文本文件的大小会因此大出二三倍,这是无法接受的。

      c.utf8

      UTF-8就是在互联网上使用最广的一种unicode的实现方式。UTF-8最大的一个特点,就是它是一种变长的编码方式。它可以使用1~4个字节表示一个符号,根据不同的符号而变化字节长度。

      UTF-8的编码规则很简单,只有二条:

      1)对于单字节的符号,字节的第一位设为0,后面7位为这个符号的unicode码。因此对于英语字母,UTF-8编码和ASCII码是相同的。

      2)对于n字节的符号(n>1),第一个字节的前n位都设为1,第n+1位设为0,后面字节的前两位一律设为10。剩下的没有提及的二进制位,全部为这个符号的unicode码。

      d.gbk

      GBK是中国国家编码,通用性比UTF8差,不过UTF8占用的空间比GBK大。

      UTF8是国际编码,它的通用性比较好,外国人也可以浏览论坛,而且中文可以直接识别,假如你的论坛要做的比较国际化那就必须用UTF8。

    2.Python介绍

    Python由来

      Python的创始人为Guido van Rossum。1989年圣诞节期间,在阿萨姆特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本解释程序,作为ABC 语言的一种继承。之所以选中Python(大蟒蛇的意思)作为该编程语言的名字,是因为他是一个叫Monty Python的喜剧团体的爱好者。

      Python可以应用于众多领域,如:数据分析、组件集成、网络服务、图像处理、数值计算和科学计算等众多领域。目前业内几乎所有大中型互联网企业都在使用Python,如:Youtube、Dropbox、BT、Quora(中国知乎)、豆瓣、知乎、Google、Yahoo!、Facebook、NASA、百度、腾讯、汽车之家、美团等。互联网公司广泛使用Python来做的事一般有:自动化运维自动化测试大数据分析、爬虫、Web 等。

    Python和其他语言区别

      

      大多数高级语言都是在C语言的基础上开发的,比如Python、Java、C#......等等;

      C vs Python、Java、C#等等:

      C语言: 代码编译得到 机器码 ,机器码在处理器上直接执行,每一条指令控制CPU工作;

      其他语言: 代码编译得到 字节码 ,虚拟机执行字节码并转换成机器码再后在处理器上执行;

      Python也称C Python由C语言开发而来:

      对于使用:Python的类库齐全并且使用简洁,如果要实现同样的功能,Python 10行代码可以解决,C可能就需要100行甚至更多.
      对于速度:Python的运行速度相较与C,比较慢,没有C执行的快;

      Python vs Java、C#等等:

      对于使用:Linux原装Python,其他语言没有;以上几门语言都有非常丰富的类库支持;
      对于速度:Python在速度上可能稍显逊色;

    Python种类

      

    • CPython
          Python的官方版本,使用C语言实现,使用最为广泛,CPython实现会将源文件(py文件)转换成字节码文件(pyc文件),然后运行在Python虚拟机上。
    • JPyhton
          Python的Java实现,Jython会将Python代码动态编译成Java字节码,然后在JVM上运行。
    • IronPython
          Python的C#实现,IronPython将Python代码编译成C#字节码,然后在CLR上运行。(与Jython类似)
    • PyPy(特殊)
          Python实现的Python,将Python的代码转换字节码再编译成机器码。优点,在第二次执行代码是则直接将代码转换成机器码交给计算机去执行。
    • RubyPython、Brython ...

    3.Python安装

    在Windows环境下:

    复制代码
    1.从官网下载2.x系列和3.x系列的安装包:
       https://www.python.org/downloads/
    2.安装:
       默认安装路径:C:python,可自定义安装;
    3.配置环境变量:
       【右键计算机】--》【属性】--》【高级系统设置】--》【高级】--》【环境变量】--》【在第二个内容框中找到 变量名为Path 的一行,双击】 --> 【Python安装目录追加到变值值中,用 ; 分割】
        如:原来的值;C:python27,切记前面有分号
    复制代码

    在Linux环境下:

    1.Linux环境下,默认安装了python2.x系列;
    2.再安装一个3.x系列;

    4.pycharm软件

    pycharm简介

      PyCharm是一种Python IDE,带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具,比如调试、语法高亮、Project管理、代码跳转、智能提示、自动完成、单元测试、版本控制。此外,该IDE提供了一些高级功能,以用于支持Django框架下的专业Web开发。

    pycharm安装

      具体安装方法见度娘!

    5.中文编码

      在python2中如果未指定编码,在执行过程中遇到中文会出现报错:

    print "向未来"
    --------输出结果---------
    SyntaxError: Non-ASCII character 'xe8' in file C:/Users/Administrator/Desktop/python/zjk/zjk1.py on line 28, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

      Python中默认的编码格式是 ASCII 格式,在没修改编码格式时无法正确打印汉字,所以在读取中文时会报错。

      解决方法为只要在文件开头加入 # -*- coding: UTF-8 -*- 或者 #coding=utf-8 就行了。

      注意:“ #coding=utf-8”等号两边不要加空格;

      如下:

    # -*-coding:UTF-8 -*-
    print "向未来"
    --------输出结果---------
    向未来16:59:4616:59:4916:59:51

      注意:python3源码文件默认使用utf-8编码,所以可以正常解析中文,无需指定编码,但为了更好更方便使用,最好还是加上。

  • 相关阅读:
    boost::asio 连接管理11 如何关闭连接
    boost::asio async_write也不能保证一次发完所有数据 二
    boost::asio async_write也不能保证一次发完所有数据 一
    boost参考博客
    C++ 多线程编程总结
    Boost::asio io_service 实现分析
    使用boost io_service时,需要注意的东西
    Boost::Thread 多线程的基础知识
    boost::thread类
    Boost::thread库的使用
  • 原文地址:https://www.cnblogs.com/xiangweilai/p/9438046.html
Copyright © 2011-2022 走看看