隔壁老王出喝酒去了,留下女友半夜一个人在家,我用python给她写了一个

哈喽大兄弟们
今日重点:
划重点:
1、python开发小游戏,pygame环境搭建;
2、给失眠的小姐姐开发一个迷宫小游戏。
代码干货满满,建议收藏+实操!!!有问题及需要,请留言哦~~

前因后果

事情是这样的,昨晚隔壁老王大晚上出去喝酒,把女友一个人丢在家里,半夜都还没回来。

然后我就听到隔壁来来回回,忙忙碌碌的声音。

像我这么心思细腻,体贴入微的Python小哥哥(还好我不姓王)

敏锐的感觉到,老王他女友肯定是失眠了…


好担心哦,我都睡不着了呢
辗转反侧

最后爬起来撸出了我的python代码

在这里插入图片描述

完整源码 —— 文末名片

环境要求

windows系统,python3.6+安装游戏依赖模块pip install pyqt5pip install pygame

游戏介绍

1、游戏目标

随机生成一张迷宫地图,将玩家设置在迷宫内部,通过光标 上 下 左 右,来移动玩家,按照迷宫地图的道路来走出迷宫。

2、先上游戏效果图

完整开发流程

1、项目主结构

首先,先整理一下项目的主结构,其实看一下主结构,基本就清晰了

modules:存放自己写的python类
——mazes.py
——misc.py
——sprites.pyresources:存放引用到的图片、音频等等
——audios:音频资源
——images:图片资源config.py:为主配置文件maze.py:主程序文件requirements.txt:需要引入的python依赖包

2、详细配置

配置文件中,需要引入os模块,并且配置打开游戏的屏幕大小,并将资源中引用到的图片、音频插入到合适的位置。

因为我们的迷宫游戏,需要划开模块。

'''配置文件'''
import os'''屏幕大小'''
SCREENSIZE = (800, 625)
'''游戏素材'''
# 完整源码+Q裙:708525271
BGMPATH = os.path.join(os.getcwd(), 'resources/audios/bgm.mp3')
HEROPICPATH = os.path.join(os.getcwd(), 'resources/images/hero.png')
'''FPS'''
FPS = 20
'''块大小'''
BLOCKSIZE = 15
MAZESIZE = (35, 50) # num_rows * num_cols
BORDERSIZE = (25, 50) # 25 * 2 + 50 * 15 = 800, 50 * 2 + 35 * 15 = 625

3、随机生成迷宫地图

迷宫虽然是个小游戏,但是我们每次打开,进入 地图需要随机生成一个新地图。

定义randommaze 随机生成地图,并将地图投在主游戏屏幕上

import pygame
import random
from .misc import *'''一个游戏地图块'''
# Python学习交流裙 708525271
class Block():def __init__(self, coordinate, block_size, border_size, **kwargs):# (col, row)self.coordinate = coordinateself.block_size = block_sizeself.border_size = border_sizeself.is_visited = False# 上下左右有没有墙self.has_walls = [True, True, True, True]self.color = (0, 0, 0)'''画到屏幕上'''def draw(self, screen):directions = ['top', 'bottom', 'left', 'right']for idx, direction in enumerate(directions):if self.has_walls[idx]:if direction == 'top':x1 = self.coordinate[0] * self.block_size + self.border_size[0]y1 = self.coordinate[1] * self.block_size + self.border_size[1]x2 = (self.coordinate[0] + 1) * self.block_size + self.border_size[0]y2 = self.coordinate[1] * self.block_size + self.border_size[1]pygame.draw.line(screen, self.color, (x1, y1), (x2, y2))elif direction == 'bottom':x1 = self.coordinate[0] * self.block_size + self.border_size[0]y1 = (self.coordinate[1] + 1) * self.block_size + self.border_size[1]x2 = (self.coordinate[0] + 1) * self.block_size + self.border_size[0]y2 = (self.coordinate[1] + 1) * self.block_size + self.border_size[1]pygame.draw.line(screen, self.color, (x1, y1), (x2, y2))elif direction == 'left':x1 = self.coordinate[0] * self.block_size + self.border_size[0]y1 = self.coordinate[1] * self.block_size + self.border_size[1]x2 = self.coordinate[0] * self.block_size + self.border_size[0]y2 = (self.coordinate[1] + 1) * self.block_size + self.border_size[1]pygame.draw.line(screen, self.color, (x1, y1), (x2, y2))elif direction == 'right':x1 = (self.coordinate[0] + 1) * self.block_size + self.border_size[0]y1 = self.coordinate[1] * self.block_size + self.border_size[1]x2 = (self.coordinate[0] + 1) * self.block_size + self.border_size[0]y2 = (self.coordinate[1] + 1) * self.block_size + self.border_size[1]pygame.draw.line(screen, self.color, (x1, y1), (x2, y2))return True'''随机生成迷宫类'''
class RandomMaze():def __init__(self, maze_size, block_size, border_size, **kwargs):self.block_size = block_sizeself.border_size = border_sizeself.maze_size = maze_sizeself.blocks_list = RandomMaze.createMaze(maze_size, block_size, border_size)self.font = pygame.font.SysFont('Consolas', 15)'''画到屏幕上'''def draw(self, screen):for row in range(self.maze_size[0]):for col in range(self.maze_size[1]):self.blocks_list[row][col].draw(screen)# 起点和终点标志showText(screen, self.font, 'S', (255, 0, 0), (self.border_size[0]-10, self.border_size[1]))showText(screen, self.font, 'D', (255, 0, 0), (self.border_size[0]+(self.maze_size[1]-1)*self.block_size, self.border_size[1]+self.maze_size[0]*self.block_size+5))'''创建迷宫'''@staticmethoddef createMaze(maze_size, block_size, border_size):def nextBlock(block_now, blocks_list):directions = ['top', 'bottom', 'left', 'right']blocks_around = dict(zip(directions, [None]*4))block_next = Nonecount = 0# 查看上边blockif block_now.coordinate[1]-1 >= 0:block_now_top = blocks_list[block_now.coordinate[1]-1][block_now.coordinate[0]]if not block_now_top.is_visited:blocks_around['top'] = block_now_topcount += 1# 查看下边blockif block_now.coordinate[1]+1 < maze_size[0]:block_now_bottom = blocks_list[block_now.coordinate[1]+1][block_now.coordinate[0]]if not block_now_bottom.is_visited:blocks_around['bottom'] = block_now_bottomcount += 1# 查看左边blockif block_now.coordinate[0]-1 >= 0:block_now_left = blocks_list[block_now.coordinate[1]][block_now.coordinate[0]-1]if not block_now_left.is_visited:blocks_around['left'] = block_now_leftcount += 1# 查看右边blockif block_now.coordinate[0]+1 < maze_size[1]:block_now_right = blocks_list[block_now.coordinate[1]][block_now.coordinate[0]+1]if not block_now_right.is_visited:blocks_around['right'] = block_now_rightcount += 1if count > 0:while True:direction = random.choice(directions)if blocks_around.get(direction):block_next = blocks_around.get(direction)if direction == 'top':block_next.has_walls[1] = Falseblock_now.has_walls[0] = Falseelif direction == 'bottom':block_next.has_walls[0] = Falseblock_now.has_walls[1] = Falseelif direction == 'left':block_next.has_walls[3] = Falseblock_now.has_walls[2] = Falseelif direction == 'right':block_next.has_walls[2] = Falseblock_now.has_walls[3] = Falsebreakreturn block_nextblocks_list = [[Block([col, row], block_size, border_size) for col in range(maze_size[1])] for row in range(maze_size[0])]block_now = blocks_list[0][0]records = []while True:if block_now:if not block_now.is_visited:block_now.is_visited = Truerecords.append(block_now)block_now = nextBlock(block_now, blocks_list)else:block_now = records.pop()if len(records) == 0:breakreturn blocks_list

4、光标控制玩家

通过读取键盘的上下左右光标来移动我们的小可爱

'''
Function:定义其他必要模块
Author:lexsaints
'''
import sys
import pygame'''在屏幕指定位置显示文字'''
def showText(screen, font, text, color, position):text_render = font.render(text, True, color)rect = text_render.get_rect()rect.left, rect.top = positionscreen.blit(text_render, rect)return rect.right'''按钮'''
def Button(screen, position, text, font, buttoncolor=(120, 120, 120), linecolor=(20, 20, 20), textcolor=(255, 255, 255), bwidth=200, bheight=50):left, top = positionpygame.draw.line(screen, linecolor, (left, top), (left+bwidth, top), 5)pygame.draw.line(screen, linecolor, (left, top-2), (left, top+bheight), 5)pygame.draw.line(screen, linecolor, (left, top+bheight), (left+bwidth, top+bheight), 5)pygame.draw.line(screen, linecolor, (left+bwidth, top+bheight), (left+bwidth, top), 5)pygame.draw.rect(screen, buttoncolor, (left, top, bwidth, bheight))text_render = font.render(text, 1, textcolor)rect = text_render.get_rect()rect.centerx, rect.centery = left + bwidth / 2, top + bheight / 2return screen.blit(text_render, rect)'''游戏开始/关卡切换/游戏结束界面'''
def Interface(screen, config, mode='game_start'):pygame.display.set_mode(config.SCREENSIZE)font = pygame.font.SysFont('Consolas', 30)if mode == 'game_start':clock = pygame.time.Clock()while True:screen.fill((192, 192, 192))button_1 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//3), 'START', font)button_2 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//2), 'QUIT', font)for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit(-1)elif event.type == pygame.MOUSEBUTTONDOWN:if button_1.collidepoint(pygame.mouse.get_pos()):return Trueelif button_2.collidepoint(pygame.mouse.get_pos()):pygame.quit()sys.exit(-1)pygame.display.update()clock.tick(config.FPS)elif mode == 'game_switch':clock = pygame.time.Clock()while True:screen.fill((192, 192, 192))button_1 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//3), 'NEXT', font)button_2 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//2), 'QUIT', font)for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit(-1)elif event.type == pygame.MOUSEBUTTONDOWN:if button_1.collidepoint(pygame.mouse.get_pos()):return Trueelif button_2.collidepoint(pygame.mouse.get_pos()):pygame.quit()sys.exit(-1)pygame.display.update()clock.tick(config.FPS)elif mode == 'game_end':clock = pygame.time.Clock()while True:screen.fill((192, 192, 192))button_1 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//3), 'RESTART', font)button_2 = Button(screen, ((config.SCREENSIZE[0]-200)//2, config.SCREENSIZE[1]//2), 'QUIT', font)for event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit(-1)elif event.type == pygame.MOUSEBUTTONDOWN:if button_1.collidepoint(pygame.mouse.get_pos()):return Trueelif button_2.collidepoint(pygame.mouse.get_pos()):pygame.quit()sys.exit(-1)pygame.display.update()clock.tick(config.FPS)else:raise ValueError('Interface.mode unsupport %s...' % mode)

5、定义主玩家 绘制全图

绘制完整游戏,并定义主角,就叫hero吧

'''
Function:定义游戏精灵类
Author:lexsaints
'''
import pygame'''定义hero'''
class Hero(pygame.sprite.Sprite):def __init__(self, imagepath, coordinate, block_size, border_size, **kwargs):pygame.sprite.Sprite.__init__(self)self.image = pygame.image.load(imagepath)self.image = pygame.transform.scale(self.image, (block_size, block_size))self.rect = self.image.get_rect()self.rect.left, self.rect.top = coordinate[0] * block_size + border_size[0], coordinate[1] * block_size + border_size[1]self.coordinate = coordinateself.block_size = block_sizeself.border_size = border_size'''移动'''def move(self, direction, maze):blocks_list = maze.blocks_listif direction == 'up':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[0]:return Falseelse:self.coordinate[1] = self.coordinate[1] - 1return Trueelif direction == 'down':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[1]:return Falseelse:self.coordinate[1] = self.coordinate[1] + 1return Trueelif direction == 'left':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[2]:return Falseelse:self.coordinate[0] = self.coordinate[0] - 1return Trueelif direction == 'right':if blocks_list[self.coordinate[1]][self.coordinate[0]].has_walls[3]:return Falseelse:self.coordinate[0] = self.coordinate[0] + 1return Trueelse:raise ValueError('Unsupport direction %s in Hero.move...' % direction)'''绑定到屏幕'''def draw(self, screen):self.rect.left, self.rect.top = self.coordinate[0] * self.block_size + self.border_size[0], self.coordinate[1] * self.block_size + self.border_size[1]screen.blit(self.image, self.rect)

6、引入音频、图片

启动游戏主程序

在主程序中,通过读取配置文件,引入项目资源:包括图片、音频等,并通过定义类,加载游戏地图

import config
import sys
import pygame
from modules import *'''主函数'''
def main(config):# 初始化pygame.init()pygame.mixer.init()pygame.font.init()pygame.mixer.music.load(config.BGMPATH)pygame.mixer.music.play(-1, 0.0)screen = pygame.display.set_mode(config.SCREENSIZE)pygame.display.set_caption('Python学习交流Q裙708525271')font = pygame.font.SysFont('Consolas', 15)# 开始界面Interface(screen, config, 'game_start')# 记录关卡数num_levels = 0# 记录最少用了多少步通关best_scores = 'None'# 关卡循环切换while True:num_levels += 1clock = pygame.time.Clock()screen = pygame.display.set_mode(config.SCREENSIZE)# --随机生成关卡地图maze_now = RandomMaze(config.MAZESIZE, config.BLOCKSIZE, config.BORDERSIZE)# --生成herohero_now = Hero(config.HEROPICPATH, [0, 0], config.BLOCKSIZE, config.BORDERSIZE)# --统计步数num_steps = 0# --关卡内主循环while True:dt = clock.tick(config.FPS)screen.fill((255, 255, 255))is_move = False# ----↑↓←→控制herofor event in pygame.event.get():if event.type == pygame.QUIT:pygame.quit()sys.exit(-1)elif event.type == pygame.KEYDOWN:if event.key == pygame.K_UP:is_move = hero_now.move('up', maze_now)elif event.key == pygame.K_DOWN:is_move = hero_now.move('down', maze_now)elif event.key == pygame.K_LEFT:is_move = hero_now.move('left', maze_now)elif event.key == pygame.K_RIGHT:is_move = hero_now.move('right', maze_now)num_steps += int(is_move)hero_now.draw(screen)maze_now.draw(screen)# ----显示一些信息showText(screen, font, 'LEVELDONE: %d' % num_levels, (255, 0, 0), (10, 10))showText(screen, font, 'BESTSCORE: %s' % best_scores, (255, 0, 0), (210, 10))showText(screen, font, 'USEDSTEPS: %s' % num_steps, (255, 0, 0), (410, 10))showText(screen, font, 'S: your starting point    D: your destination', (255, 0, 0), (10, 600))# ----判断游戏是否胜利if (hero_now.coordinate[0] == config.MAZESIZE[1] - 1) and (hero_now.coordinate[1] == config.MAZESIZE[0] - 1):breakpygame.display.update()# --更新最优成绩if best_scores == 'None':best_scores = num_stepselse:if best_scores > num_steps:best_scores = num_steps# --关卡切换Interface(screen, config, mode='game_switch')'''run'''
if __name__ == '__main__':main(config)

游戏启动方法

1、开发工具启动

如果你配置了开发工具的环境VScode、sublimeText、notepad+、pycharm什么的,可以直接在工具中,运行游戏。

如果没配置,可以使用命令启动。

2、命令行启动 gif

最后

好了,今天的分享就到这结束了,我要继续去隔壁安慰老王女友了。

大家记得点赞收藏!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/51506.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

程序员用10分钟写了个旅游管家APP,女友用了直呼贴心

「呐&#xff0c;你知道吗&#xff1f; 听说樱花飘落的速度是秒速五厘米哦。」 听到阿珍又念起这句经典台词&#xff0c;阿强&#xff0c;这个对自然界的花期不太敏感的程序员&#xff0c;也收到了“樱花开了”的讯号。 春天的樱花不能错过&#xff0c;赏樱是写进阿珍价值观的…

python实现垃圾分类程序,对于要处理的垃圾,判断该投放到哪个类别的垃圾桶中

python实现垃圾分类程序&#xff0c;对于要处理的垃圾&#xff0c;判断该投放到哪个类别的垃圾桶中 一、编程题目 编程题目&#xff1a;输入要处理的垃圾&#xff0c;空格分隔&#xff0c;判断并输出各个垃圾应该投放到哪个类别的垃圾桶中。其中垃圾有以下分类&#xff1a; 废…

Python之美[从菜鸟到高手]--Python垃圾回收机制及gc模块详解

Python中的垃圾回收是以引用计数为主&#xff0c;标记-清除和分代收集为辅。引用计数最大缺陷就是循环引用的问题&#xff0c;所以Python采用了辅助方法。本篇文章并不详细探讨Python的垃圾回收机制的内部实现&#xff0c;而是以gc模块为切入点学习Python的垃圾回收机制&#x…

【PythonGUI小程序】相信我,这是最in的n种骰子梭哈小游戏新玩法,好玩到丧心病狂~(文中有惊喜)

导语 哈喽&#xff01;大家晚上好&#xff0c;我是木木子吖&#xff0c;很久没给大家更新游戏代码的类型啦~ 所有文章完整的素材源码都在&#x1f447;&#x1f447; 粉丝白嫖源码福利&#xff0c;请移步至CSDN社区或文末公众hao即可免费。 在长沙这个美食遍地的城市&#xff…

李峋同款心跳Python代码

李峋同款心跳Python代码【按头安利《点燃我温暖你》】 import random from math import sin,cos,pi,log from tkinter import * CANVAS_WIDTH 640 CANVAS_HEIGHT 640 CANVAS_CENTER_X CANVAS_WIDTH / 2 CANVAS_CENTER_Y CANVAS_HEIGHT / 2 IMAGE_ENLARGE 11 HEART_COLOR …

【Python案例】Python实现垃圾分类APP(附带微信小程序)

嗨嗨&#xff0c;大家好呀&#xff0c;我是小圆~ 今天给你们分享一个有趣的东西 如何利用现有的工具来实现一个垃圾分类的应用 主要做了三个核心内容&#xff1a; 对比现有垃圾分类服务&#xff0c;挑选一个合适并编码实现开发桌面版垃圾分类APP开发垃圾分类微信小程序 上…

【python】制作李峋同款爱心代码,也不是很难嘛~

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! 最近&#xff0c;一部名叫《点燃我&#xff0c;温暖你》得电视剧冲进了大家得视野~ 其中李峋用代码做出的红色跳动的爱心&#xff0c;一下子跳到朱韵的心坎里&#xff0c;同样也跳到我们的心坎 今天&#xff0c;我们就用py…

太棒了 | 手把手教你用Python做一个 “举牌小人” 生成器!

教你如何使用Selenium库 本文禁止转载&#xff0c;如有违反&#xff0c;严肃处理&#xff01; 前几天写了一个婴儿级别的爬虫图文教程&#xff0c;大家很喜欢。戳我查看&#xff1a;3000字 “婴儿级” 爬虫图文教学 | 手把手教你用Python爬取 “实习网”&#xff01; 趁热打铁…

李峋的跳动爱心代码(python)

运行效果 代码&#xff1a; """ author:Athena Geng """ import random from math import sin, cos, pi, log from tkinter import *CANVAS_WIDTH 640 # 画布的宽 CANVAS_HEIGHT 480 # 画布的高 CANVAS_CENTER_X CANVAS_WIDTH / 2 # 画布中…

李峋爱心Python代码

李峋爱心Python代码&#xff1a; # codinggbk import random from math import sin, cos, pi, log from tkinter import * CANVAS_WIDTH 640 CANVAS_HEIGHT 480 CANVAS_CENTER_X CANVAS_WIDTH / 2 CANVAS_CENTER_Y CANVAS_HEIGHT / 2 IMAGE_ENLARGE 11 HEART_COLOR "…

李峋同款爱心python实现

爱心运行结果截图&#xff1a; import random from math import sin, cos, pi, log from tkinter import *CANVAS_WIDTH 840 # 画布的宽 CANVAS_HEIGHT 680 # 画布的高 CANVAS_CENTER_X CANVAS_WIDTH / 2 # 画布中心的X轴坐标 CANVAS_CENTER_Y CANVAS_HEIGHT / 2 # 画…

OpenAI CEO创建的Worldcoin正式推出「世界币」:AI 时代的数字通行证?

编辑&#xff1a;秦晋 据外媒Semafor独家报道&#xff0c;知情人士透露&#xff0c;由 OpenAI 首席执行官 Sam Altman 创建的Worldcoin 代币将于今日推出。 在硅谷引发争议的Worldcoin 代币试图解决两个棘手问题&#xff1a;在线身份认证与收入不平等问题。 据知情人士透露&…

华为鸿蒙HarmonyOS 4定档8月;ChatGPT之父的加密货币正式上线;微软必应聊天将推出重新生成答案功能|极客头条...

「极客头条」—— 技术人员的新闻圈&#xff01; CSDN 的读者朋友们早上好哇&#xff0c;「极客头条」来啦&#xff0c;快来看今天都有哪些值得我们技术人关注的重要新闻吧。 整理 | 梦依丹 出品 | CSDN&#xff08;ID&#xff1a;CSDNnews&#xff09; 一分钟速览新闻点&#…

数据分析实战(六):英国电商用户行为分析

案例&#xff1a;英国电商用户行为数据分析 Part 1. 数据获取 1.1 数据集简介 https://archive.ics.uci.edu/ml/datasets/onlineretail# 该数据集为英国在线零售商在2010年12月1日至2011年12月9日间发生的所有网络交易订单信息。 1.2 数据集内容 数据集为xlsx格式&#xff0c…

亚马逊跟卖分析与经验分享

亚马逊设置跟卖机制&#xff0c;也是给了卖家一个机会&#xff0c;对于新手来说自己制作产品的listing花费大量的时间与精力大多数出单效果很不理想&#xff0c;这个时候把握得当跟卖就会取得很大的优势。 首先它能快速的获得流量 亚马逊的跟卖就是产品的listing共享&#xff…

Lazada和Shopee选品分析之马来西亚电商市场详解-海鲸跨境

马来西亚基础信息: 马来西亚是东南亚第三大经济体,国民富足;并且年轻人众多,对中国的产品非常喜爱。 国民经济:2019你那GDP 3543亿美元,增长4.7% 人均收入:10460美元,仅次于新加坡 年龄结构:30岁以下年轻人占人口53% 电商市场规模与潜力: 马来西亚电商用户数量…

为Lazada商家量身定做的精细化运营数据分析软件,Ushop BI

跨境电商数据可视化BI系统现在在市面上也是比较普遍&#xff0c;但是针对Lazada平台的目前只有一个Ushop BI系统&#xff0c;Ushop BI系统能够把Lazada平台数据可视化做的非常好&#xff0c;其功能覆盖面广&#xff0c;操作简单&#xff0c;是Lazada商家不可多得的好帮手&#…

亚马逊商品销售数据爬虫分析报告

家电产业和消费者升级悄然地展开。 市场的这种变化使消费者对家用电器的期望不再仅仅是一个简单的功能满足&#xff0c;而是更多的细节体验和技术创新。 通过洞察家用电器的消费特点&#xff0c;有利于确定市场的未来趋势&#xff0c;从而积极应对市场变化。 ▼ 我们围绕亚马逊…

Lazada数据大分析:帮你正确解析Lazada市场!

Lazada数据大分析&#xff1a;帮你正确解析Lazada市场&#xff01; 2021年是跨境电商飞速发展的一年&#xff0c;各行各业都选择了加入跨境电商这个行业&#xff0c;而如今在互联网的大趋势下国内电商行业的发展已经非常成熟&#xff0c;而跨境电商行业就后来居上&#xff0c;…

解决TimeWait过多的问题

原文链接&#xff1a;https://www.tiejiang.org/27040.html 服务端客户端通信连接示意图 1、 time_wait的作用&#xff1a; TIME_WAIT状态存在的理由&#xff1a; 1&#xff09;可靠地实现TCP全双工连接的终止 在进行关闭连接四次挥手协议时&#xff0c;最后的ACK是由主动关闭…