Python入门笔记(三)
文章目录
- 第八章 字典dict
- 8.1 创建字典:{}、dict()、字典生成式、zip()
- 8.2 获取键对应的值:get()
- 8.3 in, not in判断键是否在字典中
- 8.4 增加键值对:fromkeys()、setdefault()、update()
- 8.5 删除键值对:del语句、clear()、pop()、popitem()
- 8.6 遍历键、值、键值对:keys()、values()、items()
- 8.7 字典、列表相互嵌套
- 8.8 字典中索引键对应的值:.index()
- 8.9 备份字典:copy()
前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。
点击跳转:人工智能从入门到精通教程
本文电子版获取方式:
「Python入门笔记(三).pdf」,复制整段内容,打开最新版「夸克APP」即可获取。
链接:https://pan.quark.cn/s/93216671fe07
第八章 字典dict
和list比较,dict有以下几个特点:
- 查找和插入的速度极快,不会随着key的增加而变慢;
- 需要占用大量的内存,内存浪费多。
而list相反:
- 查找和插入的时间随着元素的增加而增加;
- 占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法。
- 字典是无序的,是可变序列
- 用花括号括起来
- 字典是一系列的键-值对(key-value),值可以是数字、字符串、列表乃至字典。
- 字典是一种动态结构,可随时在其中添加键-值对。要添加键-值对,可依次指定字典名、用方括号括起来键和相关联的值
- dict的key必须是不可变对象。
- 键不可重复,值可以重复
8.1 创建字典:{}、dict()、字典生成式、zip()
- 花括号
- 使用内置函数dict()
- 字典生成式
dict()
例1:
dict1 = dict(name='zdb', age='1')
print(dict1)
{'name': 'zdb', 'age': '1'}
例2
a = (('F',70),('i',105),('s',115),('h',104),('C',67))
print(type(a))dict3 = dict((('F',70),('i',105),('s',115),('h',104),('C',67))) #元组转换字典
print(dict3)
<class 'tuple'>
{'F': 70, 'i': 105, 's': 115, 'h': 104, 'C': 67}
创建空字典
print(dict())
{}
字典生成式
公式: d = {item: price for item, price in zip(items, prices)}
例
items = ['Fruits', 'Books', 'Others']
prices = [96, 78, 85, 100]d = {item: price for item, price in zip(items, prices)}
print(d)
{'Fruits': 96, 'Books': 78, 'Others': 85}
zip():将两个列表对应位置的值括起来
list1=[3,2,1,6,5,4,9,9,9]
list2=[1,2,3,4,5,6]
print(zip(list1,list2))
print(list(zip(list1,list2)))
<zip object at 0x000001C3AF8CCB88>
[(3, 1), (2, 2), (1, 3), (6, 4), (5, 5), (4, 6)]
8.2 获取键对应的值:get()
1. 通过访问键得到值
例1
alien_0 = {'color':'green', 'points':5}
print(alien_0['color']) #输出color对应的值
print(alien_0['points'])
green
5
例2
scores = {'张三':100, '李四':98, '王二':45}
print(scores['张三'])
100
.get()
- 1.字典中有这个键则输出值
- 2.字典没有这个键则输出none
- 3.可以自定义没有这个键时输出的内容
例1
scores = {'张三':100, '李四':98, '王二':45}
print(scores.get('张三'))
print(scores.get('麻子'))
print(scores.get('麻子', '没有'))
100
None
没有
8.3 in, not in判断键是否在字典中
scores = {'张三':100, '李四':98, '王二':45}
print('张三' in scores)
print('麻子' not in scores)
True
True
8.4 增加键值对:fromkeys()、setdefault()、update()
1.直接增加键值对
例1:添加两个键
alien_0 = {'color':'green', 'points':5}
print(alien_0)alien_0['x_position'] = 0 #添加键-值对
alien_0['y_position'] = 25
print(alien_0)
{'color': 'green', 'points': 5}
{'color': 'green', 'points': 5, 'x_position': 0, 'y_position': 25}
例2:添加键和值
- 给字典中没有的键赋予值就是添加键值对
- 给字典中有的键赋予新值就是修改键所对应的值
dict4 = dict(name='zdb', 性别='男')
print(dict4)dict4['name'] = 'zz'
print(dict4)dict4['民族'] = '汉'
print(dict4)
{'name': 'zdb', '性别': '男'}
{'name': 'zz', '性别': '男'}
{'name': 'zz', '性别': '男', '民族': '汉'}
例3. 空字典中添加键-值对
alien_0 = {}alien_0['color'] = 'green'
alien_0['prints'] = 5
print(alien_0)
{'color': 'green', 'prints': 5}
2.fromkeys(): 创建键-值对
例1
dict1 = dict.fromkeys(range(5),'zdb')
print(dict1)
{0: 'zdb', 1: 'zdb', 2: 'zdb', 3: 'zdb', 4: 'zdb'}
例2
dict1 = {}
print(dict1.fromkeys((1,2,3)))
print(dict1.fromkeys((1,2,3),'number')) #三个键对应的值一样
print(dict1.fromkeys((1,2,3),('one','two','three')))
print(dict1.fromkeys((1,3),'数字'))
{1: None, 2: None, 3: None}
{1: 'number', 2: 'number', 3: 'number'}
{1: ('one', 'two', 'three'), 2: ('one', 'two', 'three'), 3: ('one', 'two', 'three')}
{1: '数字', 3: '数字'}
3.setdefault():添加键和值
a = {1:'one',2:'two',3:'three',4:'four'} #字典没有顺序
a.setdefault('小白') #添加键
print(a)a.setdefault(5,'five') #添加键和值
print(a)
{1: 'one', 2: 'two', 3: 'three', 4: 'four', '小白': None}
{1: 'one', 2: 'two', 3: 'three', 4: 'four', '小白': None, 5: 'five'}
4.update():用字典A更新字典B的键值对
a = {1:'one',2:'two',3:'three',4:'four'} # 字典没有顺序
b = {'小白':'狗'}
a.update(b) # 用b更新a
print(a)
{1: 'one', 2: 'two', 3: 'three', 4: 'four', '小白': '狗'}
8.5 删除键值对:del语句、clear()、pop()、popitem()
1.del:永久性删除,删除指定的键值对
例:
alien_0 = {'color':'green', 'points':5}
print(alien_0)del alien_0['points'] #删除键
print(alien_0)
{'color': 'green', 'points': 5}
{'color': 'green'}
2、.clear():清空字典,永久的,清空后为空字典
dict1 = dict.fromkeys(range(5),'zdb')
print(dict1)
dict1.clear()
print(dict1)
{0: 'zdb', 1: 'zdb', 2: 'zdb', 3: 'zdb', 4: 'zdb'}
{}
3. pop():删除键值对,永久的
a = {'a':'one', 'b':'two', 'c':'three', 'd':'four'} #字典没有顺序
a.pop('b')
print(a)
{'a': 'one', 'c': 'three', 'd': 'four'}
4.popitem():删除最后一个键值对,永久的
a = {1:'one',2:'two',3:'three',4:'four'} #字典没有顺序
print(a.popitem()) #输出最后一个
print(a)
(4, 'four')
{1: 'one', 2: 'two', 3: 'three'}
8.6 遍历键、值、键值对:keys()、values()、items()
1. 遍历键
方法一
scores = {'张三': 100, '李四': 98, '王二': 45}
for i in scores:print(i)
张三
李四
王二
方法二:keys()
favorite_language = {'jen':'python','sarah':'c','edward':'ruby','phil':'python'}for name in favorite_language.keys(): #两个变量随便取名 print(name.title())
Jen
Sarah
Edward
Phil
例2
favorite_language = {'jen':'python','sarah':'c','edward':'ruby','phil':'python'}friends = ['phil', 'sarah']
for name in favorite_language.keys(): #遍历键print(name.title())if name in friends:print("我朋友" + name.title() + "最喜欢的语言是:" +favorite_language[name].title() + '!')
Jen
Sarah
我朋友Sarah最喜欢的语言是:C!
Edward
Phil
我朋友Phil最喜欢的语言是:Python!
例3
scores = {'张三': 100, '李四': 98, '王二': 45}
keys = scores.keys()
print(list(keys))
['张三', '李四', '王二']
2.遍历值
方法一
scores = {'张三': 100, '李四': 98, '王二': 45}
for i in scores:print(scores[i])
100
98
45
方法二
scores = {'张三': 100, '李四': 98, '王二': 45}
for i in scores:print(scores.get(i))
方法三 :.values()
favorite_language = {'jen':'python','sarah':'c','edward':'ruby','phil':'python'}print('以下语言被提到过:')
for language in favorite_language.values(): #遍历所有的值print(language.title())
以下语言被提到过:
Python
C
Ruby
Python
3. 遍历键值对
方法一
scores = {'张三': 100, '李四': 98, '王二': 45}
for i in scores:print(i, scores[i], scores.get(i))
张三 100 100
李四 98 98
王二 45 45
方法二:.items():遍历所有的键-值对
例1:
user_0 = {'姓名': 'zdb','姓': 'z','名': 'db',}
for key, value in user_0.items(): # 两个变量随便取名print('Key:' + key) # 拼接输出print('Value: ' + value)
Key:姓名
Value: zdb
Key:姓
Value: z
Key:名
Value: db
例2
favorite_language = {'jen': 'python','sarah': 'c','edward': 'ruby','phil':' python'}for name, language in favorite_language.items(): #两个变量随便取名print(name.title() + "'最喜欢的语言是:" +language.title() + '.')
Jen'最喜欢的语言是:Python.
Sarah'最喜欢的语言是:C.
Edward'最喜欢的语言是:Ruby.
Phil'最喜欢的语言是: Python.
8.7 字典、列表相互嵌套
1.在列表中存储字典:[{}, {}, {}]
alien_0 ={'color':'green', 'points':5}
alien_1 ={'color':'yellow', 'points':10}
alien_2 ={'color':'red', 'points':15}aliens = [alien_0, alien_1, alien_2] #列表中嵌套字典for alien in aliens:print(alien)
{'color': 'green', 'points': 5}
{'color': 'yellow', 'points': 10}
{'color': 'red', 'points': 15}
创建30个外星人
#创建一个用于存储外星人的空列表
aliens = []#创建30个绿色的外星人
for alien_number in range(30): #0到29,循环30下new_alien = {'color':'green', 'points':5, 'speed':'slow'}aliens.append(new_alien) #添加了30个外星人#显示当前五个外星人
for alien in aliens[:5]: #循环5下print(alien)
print('...')#显示创建了多少个外星人
print("Total number of aliens: " + str(len(aliens)))
{'color': 'green', 'points': 5, 'speed': 'slow'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
...
Total number of aliens: 30
将前三个外星人修改为黄色
#创建一个用于存储外星人的空列表
aliens = []#创建30个绿色的外星人
for alien_number in range(30):new_alien = {'color':'green', 'points':5, 'speed':'slow'}aliens.append(new_alien)for alien in aliens[0:3]: #前三个if alien['color'] == 'green': #修改颜色,速度,点数alien['color'] = 'yellow'alien['speed'] = 'medium'alien['points'] = 10#显示当前五个外星人
for alien in aliens[:5]: #循环前五个print(alien)
print('...')#显示创建了多少个外星人
print("Total number of aliens: " + str(len(aliens)))
{'color': 'yellow', 'points': 10, 'speed': 'medium'}
{'color': 'yellow', 'points': 10, 'speed': 'medium'}
{'color': 'yellow', 'points': 10, 'speed': 'medium'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
{'color': 'green', 'points': 5, 'speed': 'slow'}
2.在字典中存储列表:{[], [], []}
例1
#存储所点披萨的信息
pizza = {'crust':'thick','toppings':['mushrooms', 'extra cheese'] #列表在字典中}#概述所点的披萨
print("You ordered a " + pizza['crust'] + "-crust pizza" +"with the following toppings:")for topping in pizza['toppings']: #遍历键topping所对应的值print('\t' + topping)
You ordered a thick-crust pizzawith the following toppings:mushroomsextra cheese
例2
favorite_languages = {'jen':['python', 'ruby'],'sarah':['c'],'edward':['ruby', 'go'],'phil':['python', 'haskell'],}for name, languages in favorite_languages.items(): #两个变量随便取名print('\n' + name.title() + "'s favorite languages are:")for language in languages:print("\t" + language.title())
Jen's favorite languages are:PythonRubySarah's favorite languages are:CEdward's favorite languages are:RubyGoPhil's favorite languages are:PythonHaskell
在字典中存储字典:{{}, {}, {}}
users = {'aeinstein':{ #字典在字典中 'first':'albert','last':'einstein','location':'princeton',},'mxurie':{'first':'marie','last':'curie','location':'paris',},}for username, user_info in users.items(): #遍历键-值对print("\nUsername: " + username) #输出字典中的字典full_name = user_info['first'] + ' ' + user_info['last']location = user_info['location']print("\tFull name: " + full_name.title())print("\tlocation: " + location.title())
Username: aeinsteinFull name: Albert Einsteinlocation: PrincetonUsername: mxurieFull name: Marie Curielocation: Paris
8.8 字典中索引键对应的值:.index()
brand = ['甲','乙','丙']
slogan = ['a','b','c']
print('甲是什么:',slogan[brand.index('甲')])
print('乙是什么:',slogan[brand.index('乙')])
print('丙是什么:',slogan[brand.index('丙')])
甲是什么: a
乙是什么: b
丙是什么: c
8.9 备份字典:copy()
改变原来的,等号=赋值的会改变,但copy()的永远不变
id()
查询ID,用来判断是否改变
例1: 不管怎么改变a, c永远不变;重新等号赋值a,不影响最初等号赋值的b
a = {'姓名':'zdb'}
b_fuzhi = a # 赋值,要变两个都变,ID相同
c_copy = a.copy() # 与a,b的ID不同
print(id(a)) # 原来的
print(id(b_fuzhi)) # 与a的一样
print(id(c_copy)) # 与a的不一样a = {} # 再次赋值改变a
print(a) # a现在是空字典
print(b_fuzhi) # 与上面的b_fuzhi相同
print(c_copy) # 与上面的c_copy相同
print(id(a)) # 跟最初始的a相比,变了
print(id(b_fuzhi)) # 与上面的b_fuzhi相同
print(id(c_copy)) # 与上面的c_copy相同
1585541151464
1585541151464
1585541151544{} #变了
{'姓名': 'zdb'} #没变
{'姓名': 'zdb'} #没变
1585541152584 #变了
1585541151464 #没变
1585541151544 #没变
例2:这里用clear清除a
不管怎么改变a,c永远不变;clear清除a,这里之前等号赋值的b也会被清除
只有重新赋值a才会变ID,用clear清除a,a前后的ID不会改变
a = {'姓名':'zdb'}
b = a # 赋值,要变两个都变,ID相同
c = a.copy() # 与a、b的ID不同
print(id(a)) # 原来的
print(id(b)) # 与a的一样
print(id(c)) # 与a的不一样a.clear() # 清除a
print(a) # 空字典
print(b) # 空字典
print(c) # 与上面的c相同,不是空的
print(id(a)) # 与最初始的a没变
print(id(b)) # 与最初始的b没变,还与a相同
print(id(c)) # 死也不变
2709389179624
2709389179624
2709389179704 #copy的内容不变{}
{} #赋值的也清除了
{'姓名': 'zdb'} #copy的没变
2709389179624
2709389179624 #与a原来的ID一直一样
2709389179704
例3:a等号赋值给b,不管是a还是b增加或减少元素,另外一个都会跟着改变,但是ID永远不变
a = {'姓名':'zdb'} #字典里面没有顺序
b = a # 等号赋值
c = a.copy() # 这里就不在举例这个了,永远不变
print(id(a)) # 原来的
print(id(b)) # 与a的相同b[2] = 'z' #b增加元素,a也会增加
print(a)
print(b)
print(id(a))
print(id(b))a[3] = '猪' #a增加元素,b也会增加
print(a)
print(b)
print(id(a))
print(id(b))a.pop(3) #删除a的键3,b跟着删除
print(a)
print(b)
print(id(a))
print(id(b))a.pop(2) #删除a的键2,b跟着删除
print(a)
print(b)
print(id(a))
print(id(b))
1734662028008
1734662028008{'姓名': 'zdb', 2: 'z'}
{'姓名': 'zdb', 2: 'z'}
1734662028008
1734662028008{'姓名': 'zdb', 2: 'z', 3: '猪'}
{'姓名': 'zdb', 2: 'z', 3: '猪'}
1734662028008
1734662028008{'姓名': 'zdb', 2: 'z'}
{'姓名': 'zdb', 2: 'z'}
1734662028008
1734662028008{'姓名': 'zdb'}
{'姓名': 'zdb'}
1734662028008
1734662028008
相关文章:
Python入门笔记(三)
文章目录 第八章 字典dict8.1 创建字典:{}、dict()、字典生成式、zip()8.2 获取键对应的值:get()8.3 in, not in判断键是否在字典中8.4 增加键值对:fromkeys()、setdefault()、update()8.5 删除键值对:del语句、clear(…...

PostgreSQL 任意命令执行漏洞(CVE-2019-9193)
记一次授权攻击通过PostgreSql弱口令拿到服务器权限的事件。 使用靶机复现攻击过程。 过程 在信息收集过程中,获取到在公网服务器上开启了5432端口,尝试进行暴破,获取到数据库名为默认postgres,密码为1 随后连接进PostgreSql …...

使用tgz包下载安装clickhouse低版本
1.下载安装包 官方下载地址:https://packages.clickhouse.com/tgz/stable 阿里云下载地址:clickhouse-tgz-stable安装包下载_开源镜像站-阿里云 共需要下载四个文件 clickhouse-common-static-20.3.10.75.tgz clickhouse-common-static-dbg-20.3.10.7…...

外包功能测试干了6个月,技术退步太明显了。。。。。
先说一下自己的情况,本科生,23年通过校招进入武汉某软件公司,干了差不多6个月的功能测试,今年中秋,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我就在一个外包企业干了6个月的功…...
动态规划和贪心算法
目录 动态规划和贪心算法 动态规划 贪心算法 两者之间的区别 动态规划和贪心算法 是两种经典的算法设计策略,它们各自具有独特的特点和适用场景。 动态规划 动态规划是一种将复杂问题分解为更简单子问题的求解方法。它特别适用于那些具有重叠子问题和最优子结构特性的问…...

python爬虫--tx动漫完整信息抓取
python爬虫--tx动漫完整信息抓取 一、采集主页信息二、采集详情页信息三、完整代码一、采集主页信息 先看一下采集到的信息,结果保存为csv文件: 打开开发者工具,找到数据接口。 使用xpath提取详情页url。 二、采集详情页信息 如上图所示,使用xpath提取详情页的标题、作…...
《使用Java做爬虫和使用python做爬虫哪个好》
使用Java做爬虫和使用python做爬虫哪个好 Java 和 Python 都是非常出色的编程语言,在爬虫领域各有其优势,具体使用哪种语言更好取决于多种因素: 一、开发效率 1. Python Python 以其简洁、易读的语法而闻名。在爬虫开发中,有许…...
如果我想开发一个APP,需要准备哪些材料呢
开发一个APP需要准备的材料相对复杂,涵盖了公司资质、技术资源、支付接口以及第三方服务等多个方面。以下是一份详细的材料清单: 一、公司资质证明 营业执照:需要提供公司的营业执照副本,用于申请企业支付、域名备案、APP上架及…...

告别论文初稿焦虑!ChatGPT让你轻松完成写作!
AIPaperGPT,论文写作神器~ https://www.aipapergpt.com/ 在面对繁琐的论文写作时,很多人都会遇到无从下手的困惑,尤其是论文初稿阶段,往往需要大量的时间来组织思路和编写内容。然而,随着AI技术的发展,像…...

mongodb 数据迁移,亲测成功!
mysql进行数据迁移,最简单的不过是导出sql,然后在运行sql,数据也自然迁移过去了。 可是mongodb里,我们存储的是文件,是怎么做到的呢,当我在翻阅网上博客的时候,并没有发现有这方面的顾虑。 当…...

如何使用ssm实现疫情居家办公OA系统
TOC 10902ssm疫情居家办公OA系统 系统概述 进过系统的分析后,就开始记性系统的设计,系统设计包含总体设计和详细设计。总体设计只是一个大体的设计,经过了总体设计,我们能够划分出系统的一些东西,例如文件、文档、数…...
深入了解 MySQL 中的 JSON_CONTAINS
深入了解 MySQL 中的 JSON_CONTAINS MySQL 5.7 及更高版本引入了对 JSON 数据类型的支持,使得在数据库中存储和查询 JSON 数据成为可能。在这些新功能中,JSON_CONTAINS 函数是一个非常有用的工具,允许我们检查一个 JSON 文档是否包含特定的值…...

宝藏推荐:精选十款知识库搭建软件
当今这个信息爆炸的时代,高效地管理和利用知识成为了各行各业追求的目标。无论是企业内部的协作,还是对外提供的信息服务,一个强大的知识库都是不可或缺的。为了帮助大家更好地守护和利用知识宝藏,以下是精选的十款知识库搭建软件…...
go语言接口设计三国人物
题目 请设计一个接口Person,然后设计两个结构体实现Person接口,这两个结构体都代表三国时代的名人。Person接口中有一个方法,该方法输出一句最能代表该人物特点的话。 程序 package main import ("fmt") type Person interface …...

day-63 优质数对的总数 II
思路 nums1[i] 可以被 nums2[j] * k 整除,所以nums[i]/k的所有因子都符合条件,问题转换为遍历nums1,统计nums[i]/k的因子出现次数,然后遍历nums2,如果nums2[i]是某一个因子,将其出现次数加入答案中即可 解题过程 利用哈希表统计出…...

基于 Prometheus+Grafana+Alertmanager 搭建 K8S 云监控告警平台(附配置告警至QQ、钉钉)
文章目录 一、机器规划二、部署安装 node-exporter、prometheus、Grafana、kube-state-metrics1、创建 monitor-sa 命名空间2、安装node-exporter组件2.1、说明2.2、应用资源清单2.3、通过node-exporter采集数据 3、k8s 集群中部署 prometheus3.1、创建一个 sa 账号3.2、将 sa …...

C++ | Leetcode C++题解之第461题汉明距离
题目: 题解: class Solution { public:int hammingDistance(int x, int y) {int s x ^ y, ret 0;while (s) {s & s - 1;ret;}return ret;} };...

ElasticSearch备考 -- Update by query Reindex
一、题目 有个索引task,里面的文档长这样 现在需要添加一个字段all,这个字段的值是以下 a、b、c、d字段的值连在一起 二、思考 需要把四个字段拼接到一起,组成一个新的字段,这个就需要脚本, 这里有两种方案ÿ…...

从认识String类,到走进String类的世界
作为一个常用的数据类型,跟随小编一同进入String的学习吧,领略String的一些用法。 1. 认识 String 类 2. 了解 String 类的基本用法 3. 熟练掌握 String 类的常见操作 4. 认识字符串常量池 5. 认识 StringBuffer 和 StringBuilder 一:…...

Vue入门-指令修饰符-@keyup.enter
指令修饰符: 通过"."指明一些指令后缀,不同后缀封装了不同的处理操作 ->简化代码 ①按键修饰符 keyup.enter ->键盘回车监听 ".enter"if(e.keyenter){} //".enter"用来简化代码 demo: <!DOCTYPE…...

python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...

Mybatis逆向工程,动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
今天呢,博主的学习进度也是步入了Java Mybatis 框架,目前正在逐步杨帆旗航。 那么接下来就给大家出一期有关 Mybatis 逆向工程的教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正确的建议&…...

高危文件识别的常用算法:原理、应用与企业场景
高危文件识别的常用算法:原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件,如包含恶意代码、敏感数据或欺诈内容的文档,在企业协同办公环境中(如Teams、Google Workspace)尤为重要。结合大模型技术&…...

【OSG学习笔记】Day 16: 骨骼动画与蒙皮(osgAnimation)
骨骼动画基础 骨骼动画是 3D 计算机图形中常用的技术,它通过以下两个主要组件实现角色动画。 骨骼系统 (Skeleton):由层级结构的骨头组成,类似于人体骨骼蒙皮 (Mesh Skinning):将模型网格顶点绑定到骨骼上,使骨骼移动…...

用docker来安装部署freeswitch记录
今天刚才测试一个callcenter的项目,所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...

CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...
Java编程之桥接模式
定义 桥接模式(Bridge Pattern)属于结构型设计模式,它的核心意图是将抽象部分与实现部分分离,使它们可以独立地变化。这种模式通过组合关系来替代继承关系,从而降低了抽象和实现这两个可变维度之间的耦合度。 用例子…...
MySQL 8.0 事务全面讲解
以下是一个结合两次回答的 MySQL 8.0 事务全面讲解,涵盖了事务的核心概念、操作示例、失败回滚、隔离级别、事务性 DDL 和 XA 事务等内容,并修正了查看隔离级别的命令。 MySQL 8.0 事务全面讲解 一、事务的核心概念(ACID) 事务是…...

MacOS下Homebrew国内镜像加速指南(2025最新国内镜像加速)
macos brew国内镜像加速方法 brew install 加速formula.jws.json下载慢加速 🍺 最新版brew安装慢到怀疑人生?别怕,教你轻松起飞! 最近Homebrew更新至最新版,每次执行 brew 命令时都会自动从官方地址 https://formulae.…...

从物理机到云原生:全面解析计算虚拟化技术的演进与应用
前言:我的虚拟化技术探索之旅 我最早接触"虚拟机"的概念是从Java开始的——JVM(Java Virtual Machine)让"一次编写,到处运行"成为可能。这个软件层面的虚拟化让我着迷,但直到后来接触VMware和Doc…...