当前位置: 首页 > 编程日记 > 正文

python 核心编程 第十三章

python面对对象

类和实例:类是对象的定义,实例是真真的实物。

创建一个类:

class AddrBookEnttry(object):def __init__(self, nm, ph):self.name = nmself.phone = phprint"Created instance for:", self.namedef updatePhone(self, newph):self.phont = newphprint "Update phone for:", self.name
john = AddrBookEnttry("John", "408-34324")
jane = AddrBookEnttry("Jane Doe", "42345423-32")
john.updatePhone("1376478763")
print john.phone
print john.name

定义类后,创建实例,可以查看实例的属性,以及调用实例的方法进行操作属性

创建子类:

class AddrBookEnttry(object):def __init__(self, nm, ph):self.name = nmself.phone = phprint"Created instance for:", self.namedef updatePhone(self, newph):self.phont = newphprint "Update phone for:", self.name
class EmplAddrBookEntry(AddrBookEnttry):def __init__(self, nm, ph, id, em):AddrBookEnttry.__init__(self, nm, ph)self.empid = idself.email = emdef updateEmail(self, newem):self.email = newemprint "Updated email address for:", self.namejohn = EmplAddrBookEntry("john Doe", "408-555-1212", 42,"Jojn@qq.com")
print john, john.name, john.phone
john.updatePhone("1376478763")
john.updateEmail("Join@163.com")
print john.phone, john.email

Created instance for: john Doe
<main.EmplAddrBookEntry object at 0x027B14F0> john Doe 408-555-1212
Update phone for: john Doe
Updated email address for: john Doe
408-555-1212 Join@163.com

子类继承了父类的方法,但不会继承构造器,需要显示的调用还需要传入self参数。

特殊类属性

对于类C
C.__name__ 类C的名字(字符串)
C.__doc__ 类C的文档字符串
C.__bases__ 类C的所有父类构成的元组
C.__dict__ 类C的属性
C.__module__ 类C定义所在的模块(1.5 版本新增)
C.__class__ 实例C对应的类(仅新式类中)

del()解构器方法:这个函数要直到该实例对象所有的引用都被清除掉后才会执行。

class C(object):def __init__(self):print"initialized"def __del__(self):print"deleted"
c1 = C()
c2 = c1
del c2
del c1
raw_input()

当清楚c1实例的全部引用后,就会执行__del__(),加上raw的原因是,程序运行结束会自动回收实例。
核心笔记:跟踪实例
Python 没有提供任何内部机制来跟踪一个类有多少个实例被创建了,或者记录这些实例是些什
么东西。如果需要这些功能,你可以显式加入一些代码到类定义或者__init__()和__del__()中去。
核心笔记:跟踪实例
Python 没有提供任何内部机制来跟踪一个类有多少个实例被创建了,或者记录这些实例是些什
么东西。如果需要这些功能,你可以显式加入一些代码到类定义或者__init__()和__del__()中去。
最好的方式是使用一个静态成员来记录实例的个数。靠保存它们的引用来跟踪实例对象是很危险的,
因为你必须合理管理这些引用,不然,你的引用可能没办法释放(因为还有其它的引用) ! 例子:

class InstCt(object):count = 0def __init__(self):InstCt.count += 1def __del__(self):InstCt.count -= 1def howMany(self):print InstCt.countreturn InstCt.counta = InstCt()
b = InstCt()
b.howMany()
a.howMany()
del b
a.howMany()
del a
print InstCt.count

2
2
1
0

类的静态方法和类方法

经典类创建静态方法和类方法:

class TestStaticMethod():def foo():print 'calling static method foo()'foo = staticmethod(foo)
class TestClassMethod:def foo(cls):print 'calling class method foo()'print 'foo() is part of class:', cls.__name__foo = classmethod(foo)
TestClassMethod.foo()

使用staticmethod()和classmethed()函数创建。

来看看另一种创建的方法(使用装饰器):

class TestStaticMethod():@staticmethoddef foo():print 'calling static method foo()'
class TestClassMethod:@classmethoddef foo(cls):print 'calling class method foo()'print 'foo() is part of class:', cls.__name__
TestClassMethod.foo()
TestStaticMethod.foo()

类的继承覆盖方法:

class P(object):def foo(self):print "Hi, I am P-foo"class C(P):def foo(self):super(C, self).foo()print "Hi I am C-foo"c = C()
c.foo()

Hi, I am P-foo
Hi I am C-foo

这里子类C覆盖了基类的方法,但是使用super()可以调用已经被覆盖的基类的方法。

从标准类型派生

class RoundFloat(float):def __new__(cls, val):return super(RoundFloat, cls).__new__(cls, round(val, 2))
print RoundFloat(2.3333)

这里使用super()函数捕获对应的基类,并且调用__new__()

另一个例子,一个新的字典类型,他的keys()方法会自动排序结果

class SortedKey(dict):def keys(self):return sorted(super(SortedKey, self).keys())d = SortedKey((('zheng-cai', 67), ('hui-jun', 68),('xin-yi', 2)))
print 'By iterator:'.ljust(12), [key for key in d]
print 'By keys():'.ljust(24), d.keys()

多重继承

class P1(object):def foo(self):print"called P1-foo()"class P2(object):def foo(self):print"called P2-foo()"def bar(self):print"called P2-bar()"class C1(P1, P2):passclass C2(P2, P1):passclass GC(C1, C2):passtest = GC()
test.foo()

TypeError: Error when calling the metaclass bases
Cannot create a consistent method resolution
order (MRO) for bases P2, P1
产生了一个所谓的菱形效应,mrojiu错误了

这里有些看不太懂,不过如果删除object使用以前的继承方式就不会出现这个问题,还是想不通╮(╯▽╰)╭。

内建函数

表 13.3 类,实例及其它对象的内建函数
内建函数 描述

  1. issubclass(sub, sup) 如果类 sub 是类 sup 的子类,则返回 True,反之,为 False。
    isinstance(obj1, obj2) 如果实例obj1是类obj2或者obj2子类的一个实例; 或者如果obj1
    是 obj2 的类型,则返回 True;反之,为 False。
  2. hasattr(obj, attr) 如果 obj 有属性 attr(用字符串给出) ,返回 True,反之,返回
    表 13.3 类,实例及其它对象的内建函数(续)
    内建函数 描述
  3. getattr(obj, attr[, default]) 获取 obj 的 attr 属性;与返回 obj.attr 类似;如果 attr
    不是 obj 的属性, 如果提供了默认值, 则返回默认值; 不然,
    就会引发一个 AttributeError 异常。
  4. setattr(obj, attr, val) 设置obj的 attr 属性值为 val, 替换任何已存在的属性值;
    不然,就创建属性;类似于 obj.attr=val
  5. delattr(obj, attr) 从 obj 中删除属性 attr(以字符串给出) ;类似于 del
    obj.attr。
  6. dir(obj=None) 返回 obj 的属性的一个列表;如果没有给定 obj,dir()则
    显示局部名字空间空间中的属性, 也就是 locals().keys()
  7. super(type, obj=None)
    a
    返回一个表示父类类型的代理对象;如果没有传入 obj,
    则返 回的 super 对象是非绑定的;反之,如果 obj 是一个
    type , issubclass(obj,type) 必 为 True ; 否 则 ,
    isinstance(obj,type)就必为 True。
  8. vars(obj=None) 返回 obj 的属性及其值的一个字典;如果没有给出 obj,
    vars()显示局部名字空间字典(属性及其值) ,也就是
    locals()。

用特殊方法定制类

特殊方法 描述
基本定制型

  1. C.__init__(self[, arg1, ...]) 构造器(带一些可选的参数)
  2. C.__new__(self[, arg1, ...])
    a
    构造器(带一些可选的参数) ;通常用在设置不变数据类
    型的子类。
  3. C.__del__(self) 解构器
  4. C.__str__(self) 可打印的字符输出;内建 str()及 print 语句
  5. C.__repr__(self) 运行时的字符串输出;内建 repr() 和‘ ‘ 操作符
  6. C.__unicode__(self)
    b
    Unicode 字符串输出;内建 unicode()
  7. C.__call__(self, *args) 表示可调用的实例
  8. C.__nonzero__(self) 为 object 定义 False 值;内建 bool() (从 2.2 版开始)
  9. C.__len__(self) “长度” (可用于类) ;内建 len()
    一个修改默认输出的例子:
class RoundFloat(object):def __init__(self, val):self.value = round(val, 2)def __str__(self):return str(self.value)rfm = RoundFloat(4.5353535)
print rfm

4.54

__str()__方法,覆盖了默认的行为。

数值定制的例子

class Time60(object):def __init__(self, hr, min):self.hr = hrself.min = mindef __str__(self):return "%d:%d" % (self.hr, self.min)__repr__ = __str__def __add__(self, other):return self.__class__(self.hr + other.hr, self.min +other.min)def __iadd__(self, other):self.hr += other.hrself.min +=other.minreturn selfmon = Time60(10, 30)
tue = Time60(11, 15)
print mon + tue
mon += tue
print mon

21:45
21:45

这个例子我们重新定义了 + 和+=的方法,使它支持更有趣的操作。

练习

13-3. 对类进行定制。写一个类,用来将浮点数值转换为金额。
基本任务: 编写一个 dollarize()函数,它以一个浮点数值作为输入,返回一个字符串形式的金额数。

class MoneyFmt(object):def __init__(self, value=0.0):self.dollarize(value)def dollarize(self, valus):val = "$"valus = round(valus, 2)valus = str(valus)if valus[0] == "-":val = "-$"valus = valus[1:]strmoney = valus.split(".")valus = ""if (len(strmoney[0])) % 3:strHead = strmoney[0][0:(len(strmoney[0])) % 3]else:strHead = strmoney[0][0, 3]for i in range(0, (len(strmoney[0]) + 1) / 3 - 1):valus += "," + strmoney[0][len(strHead) + i * 3:len(strHead) + i * 3 + 3]valus = val + strHead + valus + "." + strmoney[1]self.value = valusdef update (self, value=None):if value:self.dollarize(value)def __str__(self):return self.valuedef __nonzero__(self):return int(self.value)def __repr__(self):return self.value
text = MoneyFmt(-11333311111.22)
print text-$11,333,311,111.2

13-7. 数据类。提供一个 time 模块的接口,允许用户按照自己给定时间的格式,比如:
“MM/DD/YY,” “MM/DD/YYYY,” “DD/MM/YY,” “DD/MM/ YYYY,” “Mon DD, YYYY,” 或是标准
的 Unix 日期格式: “Day Mon DD, HH:MM:SS YYYY” 来查看日期。你的类应该维护一个日期值,并
用给定的时间创建一个实例。如果没有给出时间值,程序执行时会默认采用当前的系统时间。还包
括另外一些方法:
update() 按给定时间或是默认的当前系统时间修改数据值
display() 以代表时间格式的字符串做参数,并按照给定时间的格式显示:
'MDY' ==> MM/DD/YY
'MDYY' ==> MM/DD/YYYY
'DMY' ==> DD/MM/YY
'DMYY' ==> DD/MM/YYYY
'MODYY' ==> Mon DD, YYYY

import datetime
class myTime(object):def __init__(self, year=2016, month=11, day=1, hour=0, minute=0, second=0 ):self.datas = {"MDY": "%M-%d-%y", "MDYY": "%M-%d-%Y", "DMY": "%d-%M-%y", "DMYY": "%d-%M-%Y", "MODYY": "%m-%d-%y"}if minute and second and hour:self.dt = datetime.datetime.now()else:self.dt = datetime.datetime(year, month, day, hour, minute, second)def update(self, year=2016, month=11, day=0, hour=0, minute=0, second=0 ):self.dt = datetime.datetime(year, month, day, hour, minute, second)def display(self,data=None):try:strtemp = self.datas[data]print self.dt.strftime((strtemp))except:print self.dt.ctime()text = myTime()
text.update(2016, 1, 1, 1, 1, 1)
text.display()Fri Jan  1 01:01:01 2016

13-10. 堆栈和队列。编写一个类,定义一个能够同时具有堆栈(FIFO)和队列(LIFO)操作行为
的数据结构。这个类和 Perl 语言中数组相像。需要实现四个方法:
shift() 返回并删除列表中的第一个元素,类似于前面的 dequeue()函数。
unshift() 在列表的头部"压入"一个新元素
push() 在列表的尾部加上一个新元素,类似于前面的 enqueue()和 push()方法。
pop() 返回并删除列表中的最后一个元素,与前面的 pop()方法完全一样。

class StackQueue(object):def __init__(self, sq=[]):self.sq = []+sqdef shift(self):str = self.sq[0]self.sq.pop(0)return strdef unshift(self,x):self.sq.insert(0, x)def push(self, x):self.sq.append(x)def pop(self):str = self.sq[-1]self.sq.pop()return strdef __str__(self):return str(self.sq)

13-20. 类的定制。改进脚本time60.py,见13.13.2 节,示例13.3.

(a) 允许“空”实例化: 如果小时和分钟的值没有给出,默认为零小时、零分钟。

(b) 用零占位组成两位数的表示形式,因为当前的时间格式不符合要求。如下面的示例,wed
应该输出为“12:05.”
(c)除了用hours (hr) 和minutes (min)进行初始化外,还支持以下时间输入格式:
一个由小时和分钟组成的元组(10, 30)
一个由小时和分钟组成的字典({'hr': 10, 'min': 30})
一个代表小时和分钟的字符串("10:30")
附加题: 允许不恰当的时间字符串表示形式,如 “12:5”.

(d) 我们是否需要实现__radd__()方法? 为什么? 如果不必实现此方法,那我们什么时候可
以或应该覆盖它?

(e) repr()函数的实现是有缺陷而且被误导的。我们只是重载了此函数,这样我们可以省
去使用print 语句的麻烦,使它在解释器中很好的显示出来。但是,这个违背了一个原则:对于可估
值的Python 表达式,repr()总是应该给出一个(有效的)字符串表示形式。12:05 本身不是一个合法
的Python 表达式,但Time60('12:05')是合法的。请实现它。

(f) 添加六十进制(基数是60)的运算功能。下面示例中的输出应该是19:15,而不是18:75:

class Time60(object):def __init__(self,  *args, **kwargs):if len(args) == 0:args = (None,None)if type(args[0]) is str:self.hr, self.min = args[0].split(":")elif type(args[0]) is tuple:self.hr, self.min = args[0]elif type(args[0]) is dict:self.hr = args[0]["hr"]self.min = args[0]["min"]elif type(args[0]) is int and type(args[1]) is int:self.hr = args[0]self.min = args[1]elif len(kwargs) == 2:self.hr = kwargs["hr"]self.min = kwargs["min"]else:self.hr, self.min = (0, 0)self.hr = int(self.hr)self.min = int(self.min)if self.min >= 60:self.hr += self.min/60self.min = self.min%60def __str__(self):return "%d-%d" % (self.hr, self.min)def __add__(self, other):hr = self.hr + other.hrmin = self.min + other.minif min >= 60:hr += min/60min = min%60return hr, mindef __iadd__(self, other):self.hr += other.hrself.min += other.minif self.min >= 60:self.hr += self.min/60self.min = self.min%60return selfs1 = Time60(hr=23, min=77)
s2 = Time60(33, 50)
s3 = Time60("6:22")
s4 = Time60({"hr": 43, "min": 27})
s5 = Time60((54, 46))
print s1, s2, s3, s4, s5
print s1 + s5
s1+=s2
print s124-17 33-50 6-22 43-27 54-46
(79, 3)
58-7

转载于:https://www.cnblogs.com/jikeboy/p/6021480.html

相关文章:

python写一个文件下载器_Python3使用TCP编写一个简易的文件下载器

原标题&#xff1a;Python3使用TCP编写一个简易的文件下载器利用Python3来实现TCP协议&#xff0c;和UDP类似。UDP应用于及时通信&#xff0c;而TCP协议用来传送文件、命令等操作&#xff0c;因为这些数据不允许丢失&#xff0c;否则会造成文件错误或命令混乱。下面代码就是模拟…

提取Jar2Exe源代码,JavaAgent监控法

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 最近遇见一个麻烦&#xff0c;明明知道是java写的小软件&#xff0c;但是打包成了exe&#xff0c;木得办法&#xff0c;之前打包的都有缓存能在TEMP…

并发编程之多进程

一 multiprocessing模块介绍 python中的多线程无法利用多核优势&#xff0c;如果想要充分地使用多核CPU的资源&#xff08;os.cpu_count()查看&#xff09;&#xff0c;在python中大部分情况需要使用多进程。Python提供了multiprocessing。 multiprocessing模块用来开启子进…

x9此计算机上没有hasp_mastercam x9安装步骤

大家好&#xff0c;我是时间财富网智能客服时间君&#xff0c;上述问题将由我为大家进行解答。mastercam x9安装步骤是&#xff1a;1、首先&#xff0c;先下载好mastercam软件&#xff0c;下载安装包的大小为3.01G&#xff0c;双击打开setup.exe安装文件&#xff0c;然后再安装…

bitcoinj开发环境搭建

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 bitcoinj开发包是一个Java版本的比特币协议实现&#xff0c;使用bitcoinj就可以实现钱包管理和交易的发送与接收&#xff0c;而无须本地安装bitcoin…

static关键字用法

static关键字 1.修饰成员变量 在我们平时的使用当中&#xff0c;static最常用的功能就是修饰类的属性和方法&#xff0c;让他们成为类的成员属性和方法&#xff0c;我们通常将用static修饰的成员称为类成员或者静态成员&#xff0c;这句话挺起来都点奇怪&#xff0c;其实这是相…

swift x输入流_SwiftUI 探索 - 状态和数据流

SwiftUI是iOS13新出的声明式UI框架&#xff0c;将会完全改变以前命令式操作UI的开发方式。此文章主要介绍SwiftUI中状态管理的方式。可变状态State与React和Flutter中的State类似&#xff0c;只不过React和Flutter中需要显式调用setState方法。在SwiftUI 中直接修改State属性值…

qt 控件 背景色 透明 除去边框

在调试ui的时候&#xff0c;需要将背景色变为透明&#xff0c;与母控件的颜色一致&#xff0c;并且除去边框。 参考链接&#xff1a; http://www.qtcentre.org/threads/12148-how-QTextEdit-transparent-to-his-parent-window 除去背景色&#xff0c;使透明。ui->textBrowse…

A Strange Bitcoin Transaction

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 在之前的谈谈比特币的地址安全问题这篇文章中&#xff0c;我们谈到一个名为”LBC”的项目&#xff0c;这个项目通过暴力碰撞企图打捞到一些什么东西…

Jsoncpp 使用方法解析

Jsoncpp是目前比较好用的开源Json解析库&#xff0c;现在总结一下它的使用方法&#xff0c;理解&#xff0c;以供以后查阅。 在引入Jsoncpp的时候我们看到Jsoncpp里边的常用的cpp文件&#xff0c;有json_reader.cpp,json_value.cpp,json_writer.cpp, 其中&#xff1a; json_val…

tomcat限速_WEB服务的下载限速(二)(限速模块安装与配置)

一、准备工作1、下载mod_bw-0.92.tgz2、安装httpd-develyum install httpd-devel二、安装限速模块tar -xvf mod_bw-0.92.tgzapxs -c -i -a mod_bw.c三、配置apachevim /usr/local/apache/conf/httpd.conf查看是否已加载 LoadModule bw_module modules/mod_bw.so如果没…

EntityFrameworkCore 安装

映射现有&#xff08;多个&#xff09;数据库&#xff1a; 安装Microsoft.EntityFrameworkCore最新版本Tools -> NuGet Package Manager -> Package Manager Console 分别输入&#xff1a; Scaffold-DbContext "Server.;DatabaseSxh;Trusted_ConnectionTrue;" …

python神秘的魔法函数_Python魔法函数

1.什么是魔法函数魔法函数即Python类中以__(双下划线)开头&#xff0c;以__(双下划线)结尾的函数&#xff0c;Python提供的函数&#xff0c;可让咱们随意定义类的特性示例&#xff1a;class Company(object):def __init__(self, employee_list):self.employee employee_listde…

HDU-4738-Caocao's Bridges(tarjan)

转载于:https://www.cnblogs.com/GrowingJlx/p/6642692.html

博客园美化技巧汇总

首先得有js权限 1.1 页脚js代码 <script type"text/javascript"> /*功能&#xff1a;生成博客目录的JS工具测试&#xff1a;IE8&#xff0c;火狐&#xff0c;google测试通过zhang_derek2018-01-03 */ var BlogDirectory {/*获取元素位置&#xff0c;距浏览器左…

数据事务四种隔离机制和七种传播行为

数据事务四种隔离机制和七种传播行为 一、隔离级别&#xff1a; 数据库事务的隔离级别有4个&#xff0c;由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable&#xff0c;这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。 &#xff11;.…

vue注册新节点_vue怎么重新组装slots节点

在后台列表中通常会有比较多的操作按钮 过多的按钮影响布局 也影响操作 因此想通过vue的组件来控制显示的按钮个数 多余的按钮自动被收进一个特殊的 更多 按钮里面&#xff0c;效果图&#xff1a;组件定义&#xff1a;Vue.component(button-groups, {render(createElement) {re…

什么是EOS?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 关于EOS有很多炒作。2017年5月&#xff0c;EOS的创始人丹•拉莫(Dan Larimer)在纽约宣布这一消息时&#xff0c;一幅巨大的巨型屏幕广告在时代广场上…

【GDKOI2016Day1T1-魔卡少女】【拆位】线段树维护区间内所有连续子区间的异或和...

题意&#xff1a;给出N个数&#xff0c;M个操作。操作有修改和询问两种&#xff0c;每次修改将一个数改成另一个数&#xff0c;每次询问一个区间的所有连续子区间的异或和。n,m<100000,ai<1000 题解&#xff1a; 当年&#xff08;其实也就是今年&#xff09;做不出来的题…

用composer安装laravel-bjyblog

前面讲了两行命令composer的安装&#xff0c;现在我们来操作一下composer安装基于laravel的博客laravel-bjyblog。测试环境是linux&#xff0c;bt面板&#xff0c;php7.2安装扩展fileinfo/opcache/redis/imagemagick/imap/exif&#xff0c;禁用 proc_open 函数 下面开始安装&am…

微信小程序多项选择器_微信小程序三级联动之多列选择器

有些时候&#xff0c;三级联动业务场景并不只是全国地区选择&#xff0c;可能还涉及到自定义分类的三级联动&#xff0c;这时就需要使用微信的多列选择器。如果只是一列字段&#xff0c;或者每次拖动一次都去服务端取&#xff0c;会比较容易。 如果想一次定义好json,关联数据相…

eosjs-ecc中文文档

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 eosjs-ecc是eos官方处理密钥和签名的javascript开发包。访问地址&#xff1a;eosjs-ecc中文手册。 eosjs-ecc安装 nodejs环境下&#xff0c;使用N…

rocketmq 组监听_最全的RocketMQ学习指南,程序员必备的中间件技能

一、简介RocketMq是阿里开发出来的一个消息中间件&#xff0c;后捐献给Apache。官网上是这样介绍的&#xff1a; Apache RocketMQ™ is a unified messaging engine, lightweight data processing platform.RocketMQ是一个统一的处理消息引擎&#xff0c;轻量级的数据处理平台。…

【刷题】BZOJ 4516 [Sdoi2016]生成魔咒

Description 魔咒串由许多魔咒字符组成&#xff0c;魔咒字符可以用数字表示。例如可以将魔咒字符 1、2 拼凑起来形成一个魔咒串 [1,2]。 一个魔咒串 S 的非空字串被称为魔咒串 S 的生成魔咒。 例如 S[1,2,1] 时&#xff0c;它的生成魔咒有 [1]、[2]、[1,2]、[2,1]、[1,2,1] 五种…

jQuery的文档操作方法

jQuery 文档操作方法 这些方法对于 XML 文档和 HTML 文档均是适用的&#xff0c;除了&#xff1a;html()。 方法描述addClass()向匹配的元素添加指定的类名。after()在匹配的元素之后插入内容。append()向匹配元素集合中的每个元素结尾插入由参数指定的内容。appendTo()向目标结…

原 EOS智能合约开发入门

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 EOS智能合约的开发需要使用llvm和abigen来生成abi文件。 为此eos提供了一个 名为eosiocpp的工具。 在这篇文章中&#xff0c;我们介绍如何使用这个工…

python安装虚拟环境virtualenv

虚拟环境 虚拟环境是一个将不同项目所需求的依赖分别放在独立的地方的一个工具&#xff0c;它给这些工程创建虚拟的Python环境。它解决了“项目X依赖于版本1.x&#xff0c;而项目Y需要项目4.x”的两难问题&#xff0c;而且使你的全局site-packages目录保持干净和可管理。 比如&…

可变分区存储管理实验报告总结_操作系统实验报告-可变分区存储管理方式的内存分配回收...

一&#xff0e;实验目的(1)深入了解可变分区存储管理方式的内存分配回收的实现。二&#xff0e;实验内容编写程序完成可变分区存储管理方式的内存分配回收&#xff0c;要求有内存空间分配表&#xff0c;并采用最优适应算法完成内存的分配与回收。三&#xff0e;实验原理在可变分…

ubuntu/linuxmint如何添加和删除PPA源

【添加】 1、sudo add-apt-repository ppa:user/ppa-name 2、sudo apt-get update (然后再安装软件sudo apt-get install <package-name>或更新软件sudo apt-get upgrade) 【删除】 1、cd /etc/apt/source.list.d/ 2、sudo rm <ppa-name> 转载于:https://www.cnblo…

了解EOS看这一篇就够了一、团队二、技术三、项目进度四、争议和风险五、展望

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 无论是混迹于币圈、链圈还是矿圈&#xff0c;对BTC&#xff08;比特币&#xff09;、ETH&#xff08;以太坊&#xff09;、EOS这三大主流币一定不会…