23_ Python基础到实战一飞冲天(二)-python基础(二十三)--变量
off999 2024-12-31 13:44 24 浏览 0 评论
23_ Python基础到实战一飞冲天(二)-python基础(二十三)--变量的引用
## 一、处理名片-03-修改名片
### 1、名片管理系统案例:cards_tools.py 文件中,修改名片方法(deal_card) 代码:
* 由于找到的字典记录已经在列表中保存
* 要修改名片记录,只需要把列表中对应的字典中每一个键值对的数据修改即可
```python
def deal_card(find_dict):
"""操作搜索到的名片字典
:param find_dict:找到的名片字典
"""
print(find_dict)
action_str = input("请选择要执行的操作 "
"[1] 修改 [2] 删除 [0] 返回上级菜单")
if action_str == "1":
find_dict["name"] = input("姓名:")
find_dict["phone"] = input("电话:")
find_dict["qq"] = input("QQ号码:")
find_dict["email"] = input("邮箱:")
print("修改名片成功!")
elif action_str == "2":
card_list.remove(find_dict)
print("删除名片成功!")
```
### 2、名片管理系统案例:cards_tools.py 文件 代码
```python
# cards_tools.py
# 所有名片记录的列表
card_list = []
def show_menu():
"""显示菜单"""
print("*" * 50)
print("欢迎使用【名片管理系统】 V1.0")
print("")
print("1.新增名片")
print("2.显示全部")
print("3.搜索名片")
print("")
print("0.退出系统")
print("*" * 50)
def new_card():
"""新增名片"""
print("-" * 50)
print("新增名片")
# 1)提示用户依次输入名片信息
name_str = input("请输入姓名:")
phone_str = input("请输入电话:")
qq_str = input("请输入qq号码:")
email_str = input("请输入email:")
# 2)将名片信息保存到一个字典
card_dict = {"name": name_str,
"phone": phone_str,
"qq": qq_str,
"email": email_str}
# 3)将字典添加到名片列表
card_list.append(card_dict)
# 4)提示名片添加完成
print(card_list)
print("添加用户 %s 的名片成功" % name_str)
def show_all():
"""显示全部名片"""
print("-" * 50)
print("功能:显示全部名片")
# 判断是否有名片记录,如果没有,提示用户并且返回
if len(card_list) == 0:
print("提示:没有任何名片记录")
# 在函数中使用 `return` 表示返回,下方的代码不会再执行。
# 如果在 `return` 后没有跟任何内容,表示会返回到调用函数位置,并不返回任何结果
return
# 打印表头
for name in ["姓名", "电话", "QQ", "邮箱"]:
print(name, end="\t\t")
print("")
# 打印分隔线
print("=" * 50)
# 遍历名片列表依次输出字典信息
for card_dict in card_list:
print("%s\t\t%s\t\t%s\t\t%s" % (card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
def search_card():
"""搜索名片"""
print("-" * 50)
print("功能:搜索名片")
# 1. 提示要搜索的姓名
find_name = input("请输入要搜索的姓名:")
# 2. 遍历名片列表,查询要搜索的姓名,如果没找到,提示用户
for card_dict in card_list:
if card_dict["name"] == find_name:
print("姓名\t\t\t电话\t\t\tQQ\t\t\t邮箱")
print("-" * 40)
print("%s\t\t\t%s\t\t\t%s\t\t\t%s" % (
card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
print("-" * 40)
# TODO(小明) 针对找到的字典进行后续操作:修改/删除
deal_card(card_dict)
break
else:
print("没有找到 %s" % find_name)
def deal_card(find_dict):
"""操作搜索到的名片字典
:param find_dict:找到的名片字典
"""
print(find_dict)
action_str = input("请选择要执行的操作 "
"[1] 修改 [2] 删除 [0] 返回上级菜单")
if action_str == "1":
find_dict["name"] = input("姓名:")
find_dict["phone"] = input("电话:")
find_dict["qq"] = input("QQ号码:")
find_dict["email"] = input("邮箱:")
print("修改名片成功!")
elif action_str == "2":
card_list.remove(find_dict)
print("删除名片成功!")
```
### 3、名片管理系统案例:cards_main.py 文件 代码
```python
# cards_main.py
import cards_tools
# 添加一个无限循环,由用户主动决定什么时候退出循环
while True:
# TODO(小明) 显示功能菜单
cards_tools.show_menu()
action_str = input("请选择希望执行的操作:")
print("您选择的操作是【%s】" % action_str)
# 1,2,3针对名片的操作
if action_str in ["1", "2", "3"]:
# 新增名片
if action_str == "1":
cards_tools.new_card()
# 显示全部
elif action_str == "2":
cards_tools.show_all()
# 查询名片
elif action_str == "3":
cards_tools.search_card()
pass
# 0 退出系统
elif action_str == "0":
print("欢迎再次使用【名片管理系统】")
break
# 如果在开发中,不希望立刻编写分支内部的代码,可以使用 pass 关键字
# pass 表示一个占位符,能够保证程序代码结构正确。
# 程序运行时,pass关键字不会执行任何操作。
# pass
# 其他内容输入错误,需要提示用户
else:
print("您输入的不正确,请重新选择")
```
### 4示例:
## 二、处理名片-04-明确细化修改名片的思路,准备新的输入函数
### 1、名片管理系统案例:cards_tools.py 文件中,对 修改名片方法(deal_card) 进行改进细化
**如果用户在使用时,某些名片内容并不想修改**,应该如何做呢?
既然系统提供的 `input` 函数不能满足需求,那么就新定义一个函数 `input_card_info` 对系统的 `input` 函数进行扩展。
### 2、`input_card_info` 函数编写思路
```python
def input_card_info(dict_value, tip_message):
"""输入名片信息
:param dict_value: 字典原有值
:param tip_message: 输入提示信息
:return: 如果输入,返回输入内容,否则返回字典原有值
"""
# 1. 提示用户输入内容
# 2. 针对用户的输入进行判断,如果用户输入了内容,直接返回结果
# 3. 如果用户没有输入内容,返回 `字典中原有的值`
```
## 三、处理名片-05-实现修改名片输入函数
### 1、名片管理系统案例:cards_tools.py 文件中,对 修改名片方法(deal_card) 进行改进细化,添加 `input_card_info` 函数,并编写 代码
```python
def input_card_info(dict_value, tip_message):
"""输入名片信息
:param dict_value: 字典原有值
:param tip_message: 输入提示信息
:return: 如果输入,返回输入内容,否则返回字典原有值
"""
# 1. 提示用户输入内容
result_str = input(tip_message)
# 2. 针对用户的输入进行判断,如果用户输入了内容,直接返回结果
if len(result_str) > 0:
return result_str
# 3. 如果用户没有输入内容,返回 `字典中原有的值`
else:
return dict_value
```
### 2、`cards_tools.py` 文件 代码
```python
# cards_tools.py
# 所有名片记录的列表
card_list = []
def show_menu():
"""显示菜单"""
print("*" * 50)
print("欢迎使用【名片管理系统】 V1.0")
print("")
print("1.新增名片")
print("2.显示全部")
print("3.搜索名片")
print("")
print("0.退出系统")
print("*" * 50)
def new_card():
"""新增名片"""
print("-" * 50)
print("新增名片")
# 1)提示用户依次输入名片信息
name_str = input("请输入姓名:")
phone_str = input("请输入电话:")
qq_str = input("请输入qq号码:")
email_str = input("请输入email:")
# 2)将名片信息保存到一个字典
card_dict = {"name": name_str,
"phone": phone_str,
"qq": qq_str,
"email": email_str}
# 3)将字典添加到名片列表
card_list.append(card_dict)
# 4)提示名片添加完成
print(card_list)
print("添加用户 %s 的名片成功" % name_str)
def show_all():
"""显示全部名片"""
print("-" * 50)
print("功能:显示全部名片")
# 判断是否有名片记录,如果没有,提示用户并且返回
if len(card_list) == 0:
print("提示:没有任何名片记录")
# 在函数中使用 `return` 表示返回,下方的代码不会再执行。
# 如果在 `return` 后没有跟任何内容,表示会返回到调用函数位置,并不返回任何结果
return
# 打印表头
for name in ["姓名", "电话", "QQ", "邮箱"]:
print(name, end="\t\t")
print("")
# 打印分隔线
print("=" * 50)
# 遍历名片列表依次输出字典信息
for card_dict in card_list:
print("%s\t\t%s\t\t%s\t\t%s" % (card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
def search_card():
"""搜索名片"""
print("-" * 50)
print("功能:搜索名片")
# 1. 提示要搜索的姓名
find_name = input("请输入要搜索的姓名:")
# 2. 遍历名片列表,查询要搜索的姓名,如果没找到,提示用户
for card_dict in card_list:
if card_dict["name"] == find_name:
print("姓名\t\t\t电话\t\t\tQQ\t\t\t邮箱")
print("-" * 40)
print("%s\t\t\t%s\t\t\t%s\t\t\t%s" % (
card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
print("-" * 40)
# TODO(小明) 针对找到的字典进行后续操作:修改/删除
deal_card(card_dict)
break
else:
print("没有找到 %s" % find_name)
def deal_card(find_dict):
"""操作搜索到的名片字典
:param find_dict:找到的名片字典
"""
print(find_dict)
action_str = input("请选择要执行的操作 "
"[1] 修改 [2] 删除 [0] 返回上级菜单")
if action_str == "1":
# find_dict["name"] = input("姓名:")
# find_dict["phone"] = input("电话:")
# find_dict["qq"] = input("QQ号码:")
# find_dict["email"] = input("邮箱:")
# 改进细化代码
find_dict["name"] = input_card_info(find_dict["name"], "姓名:")
find_dict["phone"] = input_card_info(find_dict["phone"], "电话:")
find_dict["qq"] = input_card_info(find_dict["qq"], "QQ号码:")
find_dict["email"] = input_card_info(find_dict["email"], "邮箱:")
print("修改名片成功!")
elif action_str == "2":
card_list.remove(find_dict)
print("删除名片成功!")
def input_card_info(dict_value, tip_message):
"""输入名片信息
:param dict_value: 字典原有值
:param tip_message: 输入提示信息
:return: 如果输入,返回输入内容,否则返回字典原有值
"""
# 1. 提示用户输入内容
result_str = input(tip_message)
# 2. 针对用户的输入进行判断,如果用户输入了内容,直接返回结果
if len(result_str) > 0:
return result_str
# 3. 如果用户没有输入内容,返回 `字典中原有的值`
else:
return dict_value
```
### 3、示例:
## 四、处理名片-06-增加文档注释、删除TODO标记
### 1、pycharm 中,给函数快速添加文档注释
1)点击某一函数,如:cards_tools.py 文件中的 def input_card_info 函数:
2)点击函数左边 【黄色灯泡】小三角下面的【Insert docuumentation string stub】。
3)给函数添加注释,如下:
4)选中全部注释,点击 pycharm 菜单栏的【Code】下面的【Move line Up】会把全部注释快速移动到函数顶部。
```python
def input_card_info(dict_value, tip_message):
"""输入名片信息
:param dict_value: 字典原有值
:param tip_message: 输入提示信息
:return: 如果输入,返回输入内容,否则返回字典原有值
"""
```
```python
def deal_card(find_dict):
"""操作搜索到的名片字典
:param find_dict:找到的名片字典
"""
```
### 2、`cards_tools.py` 文件 代码
```python
# cards_tools.py
# 所有名片记录的列表
card_list = []
def show_menu():
"""显示菜单"""
print("*" * 50)
print("欢迎使用【名片管理系统】 V1.0")
print("")
print("1.新增名片")
print("2.显示全部")
print("3.搜索名片")
print("")
print("0.退出系统")
print("*" * 50)
def new_card():
"""新增名片"""
print("-" * 50)
print("新增名片")
# 1)提示用户依次输入名片信息
name_str = input("请输入姓名:")
phone_str = input("请输入电话:")
qq_str = input("请输入qq号码:")
email_str = input("请输入email:")
# 2)将名片信息保存到一个字典
card_dict = {"name": name_str,
"phone": phone_str,
"qq": qq_str,
"email": email_str}
# 3)将字典添加到名片列表
card_list.append(card_dict)
# 4)提示名片添加完成
print(card_list)
print("添加用户 %s 的名片成功" % name_str)
def show_all():
"""显示全部名片"""
print("-" * 50)
print("功能:显示全部名片")
# 判断是否有名片记录,如果没有,提示用户并且返回
if len(card_list) == 0:
print("提示:没有任何名片记录")
# 在函数中使用 `return` 表示返回,下方的代码不会再执行。
# 如果在 `return` 后没有跟任何内容,表示会返回到调用函数位置,并不返回任何结果
return
# 打印表头
for name in ["姓名", "电话", "QQ", "邮箱"]:
print(name, end="\t\t")
print("")
# 打印分隔线
print("=" * 50)
# 遍历名片列表依次输出字典信息
for card_dict in card_list:
print("%s\t\t%s\t\t%s\t\t%s" % (card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
def search_card():
"""搜索名片"""
print("-" * 50)
print("功能:搜索名片")
# 1. 提示要搜索的姓名
find_name = input("请输入要搜索的姓名:")
# 2. 遍历名片列表,查询要搜索的姓名,如果没找到,提示用户
for card_dict in card_list:
if card_dict["name"] == find_name:
print("姓名\t\t\t电话\t\t\tQQ\t\t\t邮箱")
print("-" * 40)
print("%s\t\t\t%s\t\t\t%s\t\t\t%s" % (
card_dict["name"],
card_dict["phone"],
card_dict["qq"],
card_dict["email"]))
print("-" * 40)
# TODO(小明) 针对找到的字典进行后续操作:修改/删除
deal_card(card_dict)
break
else:
print("没有找到 %s" % find_name)
def deal_card(find_dict):
"""处理查找到的名片
:param find_dict: 查找到的名片
"""
print(find_dict)
action_str = input("请选择要执行的操作 "
"[1] 修改 [2] 删除 [0] 返回上级菜单")
if action_str == "1":
# find_dict["name"] = input("姓名:")
# find_dict["phone"] = input("电话:")
# find_dict["qq"] = input("QQ号码:")
# find_dict["email"] = input("邮箱:")
# 改进细化代码
find_dict["name"] = input_card_info(find_dict["name"], "姓名:")
find_dict["phone"] = input_card_info(find_dict["phone"], "电话:")
find_dict["qq"] = input_card_info(find_dict["qq"], "QQ号码:")
find_dict["email"] = input_card_info(find_dict["email"], "邮箱:")
print("修改名片成功!")
elif action_str == "2":
card_list.remove(find_dict)
print("删除名片成功!")
def input_card_info(dict_value, tip_message):
"""输入名片信息
:param dict_value: 字典原有值
:param tip_message: 输入提示信息
:return: 如果输入,返回输入内容,否则返回字典原有值
"""
# 1. 提示用户输入内容
result_str = input(tip_message)
# 2. 针对用户的输入进行判断,如果用户输入了内容,直接返回结果
if len(result_str) > 0:
return result_str
# 3. 如果用户没有输入内容,返回 `字典中原有的值`
else:
return dict_value
```
### 3、示例:
## 五、运行程序-01-增加Shebang符号直接运行Python程序
### 1、linux系统上的 `Shebang` 符号(`#!`)
1) `#!`这个符号叫做 `Shebang` 或者 `Sha-bang`。
2) `Shebang` 通常在 `Unix` 系统脚本的中 **第一行开头** 使用。
3) 指明 **执行这个脚本文件** 的 **解释程序**。
### 2、使用 Shebang 的步骤
1)使用 `which` 查询 `python3` 解释器所在路径
```bash
$ which python3
```
2)修改要运行的 **主 python 文件**(如:cards_main.py ),在第一行增加以下内容
```python
#! /usr/bin/python3
```
3)修改 **主 python 文件**(如:cards_main.py ) 的文件权限,增加执行权限
```bash
$ chmod +x cards_main.py
```
4)在需要时执行程序即可
```bash
sudo ./cards_main.py
```
### 3示例:
```bash
python@Ubuntu:~/桌面/06_名片管理系统$ pwd
/home/python/桌面/06_名片管理系统
python@Ubuntu:~/桌面/06_名片管理系统$ ls
cards_main.py cards_tools.py __pycache__
python@Ubuntu:~/桌面/06_名片管理系统$ ./cards_main.py
bash: ./cards_main.py: 权限不够
python@Ubuntu:~/桌面/06_名片管理系统$ sudo ./cards_main.py
[sudo] python 的密码:
sudo: ./cards_main.py:找不到命令
python@Ubuntu:~/桌面/06_名片管理系统$ sudo python3 ./cards_main.py
**************************************************
欢迎使用【名片管理系统】 V1.0
1.新增名片
2.显示全部
3.搜索名片
0.退出系统
**************************************************
请选择希望执行的操作:0
您选择的操作是【0】
欢迎再次使用【名片管理系统】
python@Ubuntu:~/桌面/06_名片管理系统$ which python3
/usr/bin/python3
python@Ubuntu:~/桌面/06_名片管理系统$ sudo chmod +x cards_main.py
python@Ubuntu:~/桌面/06_名片管理系统$ ls
cards_main.py cards_tools.py __pycache__
python@Ubuntu:~/桌面/06_名片管理系统$ sudo ./cards_main.py
^C
python@Ubuntu:~/桌面/06_名片管理系统$ sudo ./cards_main.py
**************************************************
欢迎使用【名片管理系统】 V1.0
```
## 六、变量的引用-01-变量的引用概念
### 1、变量进阶(理解):目标
1)变量的引用。
2)可变和不可变类型。
3)局部变量和全局变量。
### 2、变量的引用
> * 变量 和 数据 都是保存在 **内存** 中的。
> * 在 `Python` 中 **函数 的 参数传递** 以及 **返回值** 都是靠 **引用** 传递的。
### 3、引用的概念:在 `Python` 中
1)**变量** 和 **数据** 是分开存储的。
2)**数据** 保存在内存中的一个位置。
3)**变量** 中保存着数据在内存中的地址。
4)**变量** 中 **记录数据的地址**,就叫做 **引用**。
5)使用 `id()` 函数可以查看变量中保存数据所在的 **内存地址**。
> 注意:如果变量已经被定义,当给一个变量赋值的时候,本质上是 **修改了数据的引用**
>
> * 变量 **不再** 对之前的数据引用。
> * 变量 **改为** 对新赋值的数据引用。
### 4、 `变量引用` 的示例
在 `Python` 中,变量的名字类似于 **便签纸** 贴在 **数据** 上。
1)定义一个整数变量 `a`,并且赋值为 `1`
2)将变量 `a` 赋值为 `2`
3)定义一个整数变量 `b`,并且将变量 `a` 的值赋值给 `b`
> 变量 `b` 是第 2 个贴在数字 `2` 上的标签
### 5、在 ipython3 中演示变量的引用 示例:
```python
In [1]: a = 1
In [2]: id(a)
Out[2]: 139381312
In [3]: id(1)
Out[3]: 139381312
In [4]: b = a
In [5]: id(b)
Out[5]: 139381312
In [6]: a = 2
In [7]: id(a)
Out[7]: 139381328
In [8]: c = 1
In [9]: id(c)
Out[9]: 139381312
In [10]: id(b)
Out[10]: 139381312
```
## 七、变量的引用-02-调用函数传递实参的引用
### 1、调用函数传递实参的引用 示例(dzs_01_引用.py) 代码
```python
# dzs_01_引用.py
def test(num):
print("在函数内部 %d 对应的内存地址是 %d " % (num, id(num)))
# 1.定义一个变量
a = 10
# 数据的地址本身就是一个数字
print("变量 a 在内存中的地址是 %d " % id(a))
# 2.调用 test 函数
test(a)
```
### 2、示例
## 八、变量的引用-03-函数返回值传递引用
### 1、函数的参数和返回值的传递 示例(dzs_01_引用2.py) 代码
在 `Python` 中,函数的 **实参**/**返回值** 都是是靠 **引用** 来传递来的.
```python
# dzs_01_引用2.py
def test(num):
print("-" * 50)
print("%d 在函数内的内存地址是 %x" % (num, id(num)))
result = 100
print("返回值 %d 在内存中的地址是 %x" % (result, id(result)))
print("-" * 50)
return result
a = 10
print("调用函数前 内存地址是 %x" % id(a))
r = test(a)
print("调用函数后 实参内存地址是 %x" % id(a))
print("调用函数后 返回值内存地址是 %x" % id(r))
```
### 2、示例
## 九、可变类型和不可变类型-01-基本概念
### 1、python 中**不可变类型**,内存中的数据不允许被修改:
1)数字类型 `int`, `bool`, `float`, `complex`, `long(2.x)`
2)字符串 `str`
3)元组 `tuple`
### 2、python 中**可变类型**,内存中的数据可以被修改:
1)列表 `list`
2)字典 `dict`
### 3、示例代码
```python
a = 1
a = "hello"
a = [1, 2, 3]
a = [3, 2, 1]
```
## 十、可变类型和不可变类型-02-列表、字典的修改和赋值
### 1、可变数据类型:列表和字典的内存地址引用 示例(dzs_02_列表字典引用.py) 代码:
```python
# dzs_02_列表字典引用.py
demo_list = [1, 2, 3]
print("定义列表后的内存地址 %d" % id(demo_list))
demo_list.append(999)
demo_list.pop(0)
demo_list.remove(2)
demo_list[0] = 10
print("修改数据后的内存地址 %d" % id(demo_list))
demo_dict = {"name": "小明"}
print("定义字典后的内存地址 %d" % id(demo_dict))
demo_dict["age"] = 18
demo_dict.pop("name")
demo_dict["name"] = "老王"
print("修改数据后的内存地址 %d" % id(demo_dict))
```
> 注意:字典的 `key` **只能使用不可变类型的数据**
### 2、**注意**
1)**可变类型**的数据变化,是通过 **方法** 来实现的。
2)如果给一个可变类型的变量,赋值了一个新的数据,**引用会修改**。
* 变量 **不再** 对之前的数据引用。
* 变量 **改为** 对新赋值的数据引用。
### 3、示例1:
### 4、示例2:ipython3 中演示 列表 类型数据内存地址变化
```python
In [1]: # 列表
In [2]: a = [1,3,5]
In [3]: id(a)
Out[3]: 3051217132
In [4]: a.append(99)
In [5]: a
Out[5]: [1, 3, 5, 99]
In [6]: id(a)
Out[6]: 3051217132
In [7]: a.remove(3)
In [8]: a
Out[8]: [1, 5, 99]
In [9]: id(a)
Out[9]: 3051217132
In [10]: a.clear()
In [11]: a
Out[11]: []
In [12]: id(a)
Out[12]: 3051217132
In [13]: a = []
In [14]: id(a)
Out[14]: 3051227948
```
### 5、示例3:ipython3 中演示 字典 类型数据内存地址变化
```python
In [15]: # 字典
In [16]: b = {"name": "zhangsan"}
In [17]: b["age"] = 18
In [18]: id(b)
Out[18]: 3051199724
In [19]: b
Out[19]: {'name': 'zhangsan', 'age': 18}
In [21]: b.pop("name")
Out[21]: 'zhangsan'
In [22]: b
Out[22]: {'age': 18}
In [23]: id(b)
Out[23]: 3051199724
In [24]: b.clear()
In [25]: b
Out[25]: {}
In [26]: id(b)
Out[26]: 3051199724
In [27]: b = {}
In [28]: id(b)
Out[28]: 3051223916
```
`上一节关联链接请点击:`
相关推荐
- 阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?
 - 
        
TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...
 
- 高流量大并发Linux TCP性能调优_linux 高并发网络编程
 - 
        
其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...
 
- 性能测试100集(12)性能指标资源使用率
 - 
        
在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...
 
- Linux 服务器常见的性能调优_linux高性能服务端编程
 - 
        
一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...
 
- Nginx性能优化实战:手把手教你提升10倍性能!
 - 
        
关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...
 
- 高并发场景下,Spring Cloud Gateway如何抗住百万QPS?
 - 
        
关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...
 
- Kubernetes 高并发处理实战(可落地案例 + 源码)
 - 
        
目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...
 
- 高并发场景下,Nginx如何扛住千万级请求?
 - 
        
Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...
 
- Spring Boot+Vue全栈开发实战,中文版高清PDF资源
 - 
        
SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...
 
- Docker-基础操作_docker基础实战教程二
 - 
        
一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...
 
- 你有空吗?跟我一起搭个服务器好不好?
 - 
        
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...
 
- 部署你自己的 SaaS_saas如何部署
 - 
        
部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...
 
- Docker Compose_dockercompose安装
 - 
        
DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...
 
- 京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统
 - 
        
前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...
 
- Kubernetes (k8s) 入门学习指南_k8s kubeproxy
 - 
        
Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...
 
欢迎 你 发表评论:
- 一周热门
 - 
                    
- 
                            
                                                                
抖音上好看的小姐姐,Python给你都下载了
 - 
                            
                                                                
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
 - 
                            
                                                                
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
 - 
                            
                                                                
python入门到脱坑 输入与输出—str()函数
 - 
                            
                                                                
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
 - 
                            
                                                                
Python三目运算基础与进阶_python三目运算符判断三个变量
 - 
                            
                                                                
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
 - 
                            
                                                                
慕ke 前端工程师2024「完整」
 - 
                            
                                                                
失业程序员复习python笔记——条件与循环
 - 
                            
                                                                
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
 
 - 
                            
                                                                
 
- 最近发表
 
- 标签列表
 - 
- python计时 (73)
 - python安装路径 (56)
 - python类型转换 (93)
 - python进度条 (67)
 - python吧 (67)
 - python的for循环 (65)
 - python格式化字符串 (61)
 - python静态方法 (57)
 - python列表切片 (59)
 - python面向对象编程 (60)
 - python 代码加密 (65)
 - python串口编程 (77)
 - python封装 (57)
 - python写入txt (66)
 - python读取文件夹下所有文件 (59)
 - python操作mysql数据库 (66)
 - python获取列表的长度 (64)
 - python接口 (63)
 - python调用函数 (57)
 - python多态 (60)
 - python匿名函数 (59)
 - python打印九九乘法表 (65)
 - python赋值 (62)
 - python异常 (69)
 - python元祖 (57)
 
 
