活动公告

系统通知
05-18 21:22
系统通知
通知:本站资源由网友上传分享,如有违规等问题请到版务模块进行投诉,资源失效请在帖子内回复要求补档,会尽快处理!
10-23 09:31

Fedora 32编程环境终极指南从系统安装到开发工具配置涵盖Python Java C等多种语言环境搭建与性能优化技巧

SunJu_FaceMall

3万

主题

2860

科技点

3万

积分

白金月票

碾压王

积分
32872

塔罗立华奏

<font color=白金月票" /> 发表于 2025-9-17 02:40:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
引言

Fedora作为Red Hat赞助的社区驱动的Linux发行版,以其前沿的技术特性和对开发者友好的环境而闻名。Fedora 32带来了许多新特性和改进,使其成为理想的编程环境。本文将全面介绍如何在Fedora 32上构建一个高效的编程环境,从系统安装开始,到各种编程语言环境的搭建,再到性能优化技巧,帮助你打造一个强大而高效的开发平台。

Fedora 32系统安装

系统要求

在开始安装之前,确保你的硬件满足以下基本要求:

• 64位处理器(x86_64)
• 至少2GB RAM(推荐4GB或更多)
• 至少20GB的硬盘空间(推荐40GB或更多)
• USB端口(用于安装介质)
• 互联网连接(用于安装软件包和更新)

下载与创建安装介质

1. 访问Fedora官方网站下载Fedora 32的ISO镜像文件。你可以选择Workstation版本,它适合大多数开发者使用。
2. 使用Fedora Media Writer或其他工具(如dd、Etcher等)创建可启动的USB安装介质。

访问Fedora官方网站下载Fedora 32的ISO镜像文件。你可以选择Workstation版本,它适合大多数开发者使用。

使用Fedora Media Writer或其他工具(如dd、Etcher等)创建可启动的USB安装介质。

在Linux上使用dd命令创建安装介质的示例:
  1. # 首先确定你的USB设备名称,例如/dev/sdb
  2. sudo fdisk -l
  3. # 卸载USB设备(如果已挂载)
  4. sudo umount /dev/sdb*
  5. # 使用dd命令写入ISO镜像
  6. sudo dd if=~/Downloads/Fedora-32-Workstation-x86_64.iso of=/dev/sdb bs=4M status=progress
复制代码

安装步骤详解

1. 从USB启动计算机,选择”Start Fedora-Workstation-Live”选项进入Live环境。
2. 双击桌面上的”Install to Hard Drive”图标开始安装过程。
3. 选择安装语言,然后点击”Continue”。
4. 在”INSTALLATION SUMMARY”页面,配置以下选项:KEYBOARD:确认键盘布局正确。TIME & DATE:设置时区。INSTALLATION DESTINATION:选择安装位置。你可以选择自动分区或手动分区。NETWORK & HOST NAME:配置网络连接和主机名。
5. KEYBOARD:确认键盘布局正确。
6. TIME & DATE:设置时区。
7. INSTALLATION DESTINATION:选择安装位置。你可以选择自动分区或手动分区。
8. NETWORK & HOST NAME:配置网络连接和主机名。
9. 手动分区建议(针对开发者):/boot- 1GB(EFI系统分区如果是UEFI启动)swap- 与RAM大小相等或更大/- 至少30GB,用于系统和软件/home- 剩余空间,用于个人文件和项目
10. /boot- 1GB(EFI系统分区如果是UEFI启动)
11. swap- 与RAM大小相等或更大
12. /- 至少30GB,用于系统和软件
13. /home- 剩余空间,用于个人文件和项目
14. 点击”Begin Installation”开始安装过程。
15. 在安装过程中,设置root密码和创建用户账户。
16. 安装完成后,重启系统并移除USB安装介质。

从USB启动计算机,选择”Start Fedora-Workstation-Live”选项进入Live环境。

双击桌面上的”Install to Hard Drive”图标开始安装过程。

选择安装语言,然后点击”Continue”。

在”INSTALLATION SUMMARY”页面,配置以下选项:

• KEYBOARD:确认键盘布局正确。
• TIME & DATE:设置时区。
• INSTALLATION DESTINATION:选择安装位置。你可以选择自动分区或手动分区。
• NETWORK & HOST NAME:配置网络连接和主机名。

手动分区建议(针对开发者):

• /boot- 1GB(EFI系统分区如果是UEFI启动)
• swap- 与RAM大小相等或更大
• /- 至少30GB,用于系统和软件
• /home- 剩余空间,用于个人文件和项目

点击”Begin Installation”开始安装过程。

在安装过程中,设置root密码和创建用户账户。

安装完成后,重启系统并移除USB安装介质。

安装后的基本配置

1. 首次启动后,完成初始设置向导。
2. 打开终端,更新系统:

首次启动后,完成初始设置向导。

打开终端,更新系统:
  1. sudo dnf update -y
  2. sudo dnf upgrade -y
复制代码

1. 安装一些基本的开发工具和软件:
  1. sudo dnf groupinstall "Development Tools" -y
  2. sudo dnf install -y git wget curl vim nano
复制代码

1. 配置Git:
  1. git config --global user.name "Your Name"
  2. git config --global user.email "your.email@example.com"
复制代码

系统基础配置与优化

更新系统

保持系统更新是确保安全性和稳定性的关键步骤:
  1. sudo dnf check-update
  2. sudo dnf update -y
复制代码

设置自动更新(可选):
  1. sudo dnf install -y dnf-automatic
  2. sudo systemctl enable --now dnf-automatic.timer
复制代码

添加必要的软件仓库

Fedora 32默认包含了许多软件仓库,但某些开发工具可能需要额外的仓库:

1. RPM Fusion仓库(提供多媒体和额外软件):
  1. sudo dnf install -y https://download1.rpmfusion.org/free/fedora/rpmfusion-free-release-$(rpm -E %fedora).noarch.rpm
  2. sudo dnf install -y https://download1.rpmfusion.org/nonfree/fedora/rpmfusion-nonfree-release-$(rpm -E %fedora).noarch.rpm
复制代码

1. 启用PowerTools仓库(包含额外的开发工具):
  1. sudo dnf config-manager --set-enabled powertools
复制代码

系统性能基础优化

1. 禁用不必要的服务:
  1. # 查看运行中的服务
  2. systemctl list-units --type=service --state=running
  3. # 禁用不需要的服务(示例)
  4. sudo systemctl disable bluetooth.service
  5. sudo systemctl disable avahi-daemon.service
复制代码

1. 配置系统性能参数:

编辑/etc/sysctl.conf文件添加以下内容:
  1. # 增加文件句柄限制
  2. fs.file-max = 100000
  3. # 优化网络设置
  4. net.core.rmem_max = 16777216
  5. net.core.wmem_max = 16777216
  6. net.ipv4.tcp_rmem = 4096 87380 16777216
  7. net.ipv4.tcp_wmem = 4096 65536 16777216
  8. net.ipv4.tcp_congestion_control = bbr
复制代码

应用更改:
  1. sudo sysctl -p
复制代码

1. 安装并配置性能监控工具:
  1. sudo dnf install -y htop iotop sysstat
复制代码

通用开发工具配置

终端与Shell配置

1. 安装Zsh和Oh My Zsh:
  1. sudo dnf install -y zsh
  2. sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
复制代码

1. 配置Zsh插件:

编辑~/.zshrc文件,修改插件行:
  1. plugins=(git docker python npm node vscode)
复制代码

1. 安装Powerlevel10k主题:
  1. git clone --depth=1 https://github.com/romkatv/powerlevel10k.git ${ZSH_CUSTOM:-$HOME/.oh-my-zsh/custom}/themes/powerlevel10k
复制代码

然后在~/.zshrc中设置主题:
  1. ZSH_THEME="powerlevel10k/powerlevel10k"
复制代码

1. 安装终端复用器Tmux:
  1. sudo dnf install -y tmux
复制代码

创建Tmux配置文件~/.tmux.conf:
  1. # 设置前缀键为Ctrl+A
  2. unbind C-b
  3. set -g prefix C-a
  4. # 启用鼠标支持
  5. set -g mouse on
  6. # 设置256色终端
  7. set -g default-terminal "screen-256color"
  8. # 设置状态栏
  9. set -g status-bg black
  10. set -g status-fg white
  11. set -g status-interval 60
  12. set -g status-left-length 30
  13. set -g status-left '#[fg=green](#S) #(whoami)@#H#[default]'
  14. set -g status-right '#[fg=yellow]#(cut -d " " -f 1-3 /proc/loadavg)#[default] #[fg=cyan]%H:%M#[default]'
复制代码

文本编辑器与IDE

1. Visual Studio Code:
  1. sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc
  2. echo -e "[code]\nname=Visual Studio Code\nbaseurl=https://packages.microsoft.com/yumrepos/vscode\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" | sudo tee /etc/yum.repos.d/vscode.repo
  3. sudo dnf check-update
  4. sudo dnf install -y code
复制代码

1. 安装一些有用的VS Code扩展:
  1. code --install-extension ms-python.python
  2. code --install-extension ms-vscode.cpptools
  3. code --install-extension redhat.java
  4. code --install-extension ms-vscode-remote.remote-containers
  5. code --install-extension eamodio.gitlens
  6. code --install-extension ms-vscode.vscode-typescript-next
复制代码

1. JetBrains Toolbox(用于安装IntelliJ IDEA、PyCharm等):
  1. wget https://download.jetbrains.com/toolbox/jetbrains-toolbox-1.17.7391.tar.gz
  2. tar -xzf jetbrains-toolbox-1.17.7391.tar.gz
  3. cd jetbrains-toolbox-1.17.7391
  4. ./jetbrains-toolbox
复制代码

1. Vim/Neovim配置:
  1. sudo dnf install -y neovim
  2. curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
复制代码

创建Neovim配置文件~/.config/nvim/init.vim:
  1. call plug#begin('~/.local/share/nvim/plugged')
  2. " 主题
  3. Plug 'morhetz/gruvbox'
  4. " 状态栏
  5. Plug 'vim-airline/vim-airline'
  6. Plug 'vim-airline/vim-airline-themes'
  7. " 文件浏览器
  8. Plug 'preservim/nerdtree'
  9. " 模糊查找
  10. Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }
  11. Plug 'junegunn/fzf.vim'
  12. " 代码补全
  13. Plug 'neoclide/coc.nvim', {'branch': 'release'}
  14. " Git集成
  15. Plug 'tpope/vim-fugitive'
  16. " 语法高亮
  17. Plug 'sheerun/vim-polyglot'
  18. call plug#end()
  19. " 基本设置
  20. syntax on
  21. colorscheme gruvbox
  22. set background=dark
  23. set number
  24. set relativenumber
  25. set expandtab
  26. set shiftwidth=2
  27. set smarttab
  28. set autoindent
  29. set smartindent
  30. set encoding=utf-8
  31. set fileencoding=utf-8
  32. " 键盘映射
  33. nnoremap <C-n> :NERDTreeToggle<CR>
  34. nnoremap <C-p> :Files<CR>
复制代码

版本控制工具

1. Git高级配置:

创建全局.gitignore文件:
  1. curl -o ~/.gitignore https://raw.githubusercontent.com/github/gitignore/master/Global/Linux.gitignore
  2. echo ".gitignore_global" >> ~/.gitignore
  3. git config --global core.excludesfile ~/.gitignore
复制代码

配置Git别名:
  1. git config --global alias.st status
  2. git config --global alias.co checkout
  3. git config --global alias.br branch
  4. git config --global alias.ci commit
  5. git config --global alias.lg "log --oneline --graph --decorate --all"
复制代码

1. 安装并配置GitHub CLI:
  1. sudo dnf config-manager --add-repo https://cli.github.com/packages/rpm/gh-cli.repo
  2. sudo dnf install -y gh
复制代码

认证GitHub CLI:
  1. gh auth login
复制代码

1. 安装Git LFS(用于大文件管理):
  1. sudo dnf install -y git-lfs
  2. git lfs install
复制代码

Python开发环境搭建

Python版本管理

Fedora 32默认安装了Python 3.8,但有时你可能需要使用多个Python版本。以下是使用pyenv管理多个Python版本的方法:

1. 安装pyenv:
  1. sudo dnf install -y @development-tools zlib-devel bzip2 bzip2-devel readline-devel sqlite sqlite-devel openssl-devel xz xz-devel libffi-devel findutils
  2. curl https://pyenv.run | bash
复制代码

1. 配置环境变量(在~/.zshrc或~/.bashrc中):
  1. export PATH="$HOME/.pyenv/bin:$PATH"
  2. eval "$(pyenv init -)"
  3. eval "$(pyenv virtualenv-init -)"
复制代码

1. 重新加载shell配置:
  1. source ~/.zshrc
复制代码

1. 安装不同版本的Python:
  1. # 查看可安装的Python版本
  2. pyenv install --list
  3. # 安装特定版本的Python
  4. pyenv install 3.9.0
  5. pyenv install 3.7.9
  6. # 设置全局Python版本
  7. pyenv global 3.8.6
  8. # 在特定目录设置本地Python版本
  9. cd ~/myproject
  10. pyenv local 3.9.0
复制代码

虚拟环境配置

1. 使用venv创建虚拟环境:
  1. # 创建虚拟环境
  2. python -m venv myenv
  3. # 激活虚拟环境
  4. source myenv/bin/activate
  5. # 退出虚拟环境
  6. deactivate
复制代码

1. 使用pyenv-virtualenv创建虚拟环境:
  1. # 创建虚拟环境
  2. pyenv virtualenv 3.8.6 myproject-env
  3. # 激活虚拟环境
  4. pyenv activate myproject-env
  5. # 退出虚拟环境
  6. pyenv deactivate
复制代码

1. 使用pipenv管理项目依赖:
  1. sudo dnf install -y pipenv
  2. # 创建项目并使用特定Python版本
  3. mkdir myproject
  4. cd myproject
  5. pipenv --python 3.8
  6. # 安装包
  7. pipenv install requests
  8. pipenv install --dev pytest
  9. # 激活虚拟环境
  10. pipenv shell
  11. # 退出虚拟环境
  12. exit
复制代码

常用Python开发工具

1. Jupyter Notebook/Lab:
  1. pip install jupyterlab
  2. # 或
  3. sudo dnf install -y python3-jupyterlab
复制代码

创建Jupyter配置文件:
  1. jupyter notebook --generate-config
复制代码

编辑配置文件~/.jupyter/jupyter_notebook_config.py:
  1. # 设置IP和端口
  2. c.NotebookApp.ip = '0.0.0.0'
  3. c.NotebookApp.port = 8888
  4. # 设置密码
  5. from notebook.auth import passwd
  6. c.NotebookApp.password = passwd('your_password')
  7. # 允许远程访问
  8. c.NotebookApp.allow_origin = '*'
  9. c.NotebookApp.open_browser = False
复制代码

1. 代码格式化和检查工具:
  1. pip install black flake8 mypy isort
复制代码

配置pre-commit钩子:
  1. pip install pre-commit
  2. pre-commit install
复制代码

创建.pre-commit-config.yaml文件:
  1. repos:
  2.   - repo: https://github.com/psf/black
  3.     rev: stable
  4.     hooks:
  5.       - id: black
  6.   - repo: https://gitlab.com/pycqa/flake8
  7.     rev: 3.8.3
  8.     hooks:
  9.       - id: flake8
  10.   - repo: https://github.com/pre-commit/mirrors-mypy
  11.     rev: v0.782
  12.     hooks:
  13.       - id: mypy
复制代码

1. 测试工具:
  1. pip install pytest pytest-cov pytest-xdist
复制代码

创建pytest配置文件pytest.ini:
  1. [pytest]
  2. testpaths = tests
  3. python_files = test_*.py
  4. python_classes = Test*
  5. python_functions = test_*
  6. addopts = --verbose --tb=short --cov=yourpackage --cov-report=term-missing
复制代码

Python性能优化

1. 使用PyPy替代CPython:
  1. # 安装PyPy
  2. sudo dnf install -y pypy pypy3
  3. # 使用PyPy运行Python脚本
  4. pypy3 your_script.py
复制代码

1. 使用Cython加速Python代码:
  1. pip install cython
复制代码

示例:将Python代码编译为C扩展
  1. # example.pyx
  2. def say_hello_to(name):
  3.     print(f"Hello, {name}!")
复制代码

创建setup.py文件:
  1. from setuptools import setup
  2. from Cython.Build import cythonize
  3. setup(
  4.     ext_modules = cythonize("example.pyx")
  5. )
复制代码

编译扩展:
  1. python setup.py build_ext --inplace
复制代码

使用编译后的扩展:
  1. import example
  2. example.say_hello_to("World")
复制代码

1. 使用Numba进行JIT编译:
  1. pip install numba
复制代码

示例:
  1. from numba import jit
  2. import random
  3. @jit(nopython=True)
  4. def monte_carlo_pi(nsamples):
  5.     acc = 0
  6.     for i in range(nsamples):
  7.         x = random.random()
  8.         y = random.random()
  9.         if (x**2 + y**2) < 1.0:
  10.             acc += 1
  11.     return 4.0 * acc / nsamples
  12. # 第一次运行会进行编译
  13. print(monte_carlo_pi(1000000))
复制代码

1. 使用多进程和多线程:
  1. import multiprocessing
  2. import concurrent.futures
  3. # 多进程示例
  4. def process_data(data):
  5.     # 处理数据
  6.     return result * 2
  7. if __name__ == "__main__":
  8.     data = [1, 2, 3, 4, 5, 6, 7, 8]
  9.    
  10.     # 使用ProcessPoolExecutor
  11.     with concurrent.futures.ProcessPoolExecutor() as executor:
  12.         results = list(executor.map(process_data, data))
  13.    
  14.     print(results)
  15.    
  16.     # 使用multiprocessing.Pool
  17.     with multiprocessing.Pool() as pool:
  18.         results = pool.map(process_data, data)
  19.    
  20.     print(results)
复制代码

Java开发环境搭建

JDK安装与配置

1. 安装OpenJDK:
  1. # 安装OpenJDK 11(LTS版本)
  2. sudo dnf install -y java-11-openjdk java-11-openjdk-devel
  3. # 安装OpenJDK 8
  4. sudo dnf install -y java-1.8.0-openjdk java-1.8.0-openjdk-devel
  5. # 安装OpenJDK 14(最新版本)
  6. sudo dnf install -y java-14-openjdk java-14-openjdk-devel
复制代码

1. 使用SDKMAN管理多个Java版本:
  1. # 安装SDKMAN
  2. curl -s "https://get.sdkman.io" | bash
  3. source "$HOME/.sdkman/bin/sdkman-init.sh"
  4. # 安装不同版本的Java
  5. sdk install java 11.0.7-open
  6. sdk install java 8.0.252-open
  7. sdk install java 14.0.1-open
  8. # 切换Java版本
  9. sdk use java 11.0.7-open
  10. # 设置默认Java版本
  11. sdk default java 11.0.7-open
复制代码

1. 设置环境变量(在~/.zshrc或~/.bashrc中):
  1. # 设置JAVA_HOME
  2. export JAVA_HOME=/usr/lib/jvm/java-11-openjdk
  3. export PATH=$JAVA_HOME/bin:$PATH
复制代码

1. 验证Java安装:
  1. java -version
  2. javac -version
  3. echo $JAVA_HOME
复制代码

构建工具配置

1. Maven安装与配置:
  1. sudo dnf install -y maven
复制代码

配置Maven(编辑~/.m2/settings.xml):
  1. <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
  2.           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3.           xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
  4.                               https://maven.apache.org/xsd/settings-1.0.0.xsd">
  5.    
  6.     <localRepository>${user.home}/.m2/repository</localRepository>
  7.    
  8.     <mirrors>
  9.         <mirror>
  10.             <id>aliyun</id>
  11.             <mirrorOf>central</mirrorOf>
  12.             <name>Aliyun Maven Central</name>
  13.             <url>https://maven.aliyun.com/repository/central</url>
  14.         </mirror>
  15.     </mirrors>
  16.    
  17.     <profiles>
  18.         <profile>
  19.             <id>jdk-11</id>
  20.             <activation>
  21.                 <activeByDefault>true</activeByDefault>
  22.                 <jdk>11</jdk>
  23.             </activation>
  24.             <properties>
  25.                 <maven.compiler.source>11</maven.compiler.source>
  26.                 <maven.compiler.target>11</maven.compiler.target>
  27.                 <maven.compiler.compilerVersion>11</maven.compiler.compilerVersion>
  28.             </properties>
  29.         </profile>
  30.     </profiles>
  31. </settings>
复制代码

1. Gradle安装与配置:
  1. # 使用SDKMAN安装Gradle
  2. sdk install gradle 6.7
  3. # 或手动安装
  4. wget https://services.gradle.org/distributions/gradle-6.7-bin.zip
  5. unzip gradle-6.7-bin.zip
  6. sudo mv gradle-6.7 /opt/
  7. sudo ln -s /opt/gradle-6.7/bin/gradle /usr/local/bin/gradle
复制代码

配置Gradle(创建~/.gradle/gradle.properties):
  1. org.gradle.parallel=true
  2. org.gradle.daemon=true
  3. org.gradle.jvmargs=-Xms256m -Xmx1024m
复制代码

1. 使用Ant(传统构建工具):
  1. sudo dnf install -y ant
复制代码

IDE配置

1. IntelliJ IDEA配置:
  1. # 使用JetBrains Toolbox安装IntelliJ IDEA
  2. # 或通过命令行安装
  3. sudo dnf install -y intellij-idea-community
复制代码

配置IntelliJ IDEA:

• 导入设置:File > Import Settings
• 配置JDK:File > Project Structure > Project > SDK
• 配置Maven:File > Settings > Build > Build Tools > Maven
• 安装插件:File > Settings > Plugins

推荐插件:

• Lombok
• Key Promoter X
• .ignore
• GitToolBox
• Maven Helper
• SonarLint

1. Eclipse配置:
  1. sudo dnf install -y eclipse-platform eclipse-jdt
复制代码

配置Eclipse:

• 安装Java开发工具:Help > Eclipse Marketplace
• 配置JDK:Window > Preferences > Java > Installed JREs
• 配置Maven:Window > Preferences > Maven

1. VS Code Java配置:

安装VS Code Java扩展包:

• Language Support for Java by Red Hat
• Debugger for Java
• Java Test Runner
• Maven for Java
• Project Manager for Java

Java性能优化

1. JVM参数优化:

创建JVM参数文件jvm.opts:
  1. # 堆内存设置
  2. -Xms2g
  3. -Xmx4g
  4. # 新生代设置
  5. -XX:NewSize=1g
  6. -XX:MaxNewSize=2g
  7. # 永久代/元空间设置
  8. -XX:MetaspaceSize=256m
  9. -XX:MaxMetaspaceSize=512m
  10. # 垃圾收集器设置(G1GC)
  11. -XX:+UseG1GC
  12. -XX:MaxGCPauseMillis=200
  13. -XX:InitiatingHeapOccupancyPercent=45
  14. # GC日志设置
  15. -XX:+PrintGCDetails
  16. -XX:+PrintGCDateStamps
  17. -XX:+PrintGCTimeStamps
  18. -Xloggc:/var/log/gc.log
  19. # 其他优化参数
  20. -XX:+OptimizeStringConcat
  21. -XX:+UseCompressedOops
  22. -XX:+UseCompressedClassPointers
  23. -XX:+AggressiveOpts
复制代码

1. 使用JMH进行微基准测试:

创建Maven项目并添加JMH依赖:
  1. <dependencies>
  2.     <dependency>
  3.         <groupId>org.openjdk.jmh</groupId>
  4.         <artifactId>jmh-core</artifactId>
  5.         <version>1.26</version>
  6.     </dependency>
  7.     <dependency>
  8.         <groupId>org.openjdk.jmh</groupId>
  9.         <artifactId>jmh-generator-annprocess</artifactId>
  10.         <version>1.26</version>
  11.         <scope>provided</scope>
  12.     </dependency>
  13. </dependencies>
复制代码

创建基准测试类:
  1. import org.openjdk.jmh.annotations.*;
  2. import java.util.concurrent.TimeUnit;
  3. @BenchmarkMode(Mode.AverageTime)
  4. @OutputTimeUnit(TimeUnit.MILLISECONDS)
  5. @State(Scope.Thread)
  6. public class MyBenchmark {
  7.    
  8.     @Param({"10", "100", "1000"})
  9.     private int size;
  10.    
  11.     private int[] array;
  12.    
  13.     @Setup
  14.     public void setup() {
  15.         array = new int[size];
  16.         for (int i = 0; i < size; i++) {
  17.             array[i] = i;
  18.         }
  19.     }
  20.    
  21.     @Benchmark
  22.     public int sum() {
  23.         int sum = 0;
  24.         for (int i = 0; i < array.length; i++) {
  25.             sum += array[i];
  26.         }
  27.         return sum;
  28.     }
  29.    
  30.     @Benchmark
  31.     public int streamSum() {
  32.         return java.util.Arrays.stream(array).sum();
  33.     }
  34. }
复制代码

运行基准测试:
  1. import org.openjdk.jmh.runner.Runner;
  2. import org.openjdk.jmh.runner.options.Options;
  3. import org.openjdk.jmh.runner.options.OptionsBuilder;
  4. public class BenchmarkRunner {
  5.     public static void main(String[] args) throws Exception {
  6.         Options opt = new OptionsBuilder()
  7.                 .include(MyBenchmark.class.getSimpleName())
  8.                 .forks(1)
  9.                 .warmupIterations(5)
  10.                 .measurementIterations(5)
  11.                 .build();
  12.         
  13.         new Runner(opt).run();
  14.     }
  15. }
复制代码

1. 使用Java Flight Recorder进行性能分析:
  1. # 启动应用并启用JFR
  2. java -XX:+UnlockCommercialFeatures -XX:+FlightRecorder -XX:StartFlightRecording=duration=60s,filename=myrecording.jfr -jar myapp.jar
  3. # 使用JMC分析JFR记录
  4. sudo dnf install -y jmc
  5. jmc
复制代码

1. 使用Async Profiler进行CPU分析:
  1. # 下载Async Profiler
  2. wget https://github.com/jvm-profiling-tools/async-profiler/releases/download/v1.8.3/async-profiler-1.8.3-linux-x64.tar.gz
  3. tar -xzf async-profiler-1.8.3-linux-x64.tar.gz
  4. # 启动CPU分析
  5. ./profiler.sh -d 60 -f profile.html <pid>
复制代码

C/C++开发环境搭建

编译器安装与配置

1. GCC安装:
  1. # 安装GCC和开发工具
  2. sudo dnf groupinstall "Development Tools" -y
  3. # 安装特定版本的GCC
  4. sudo dnf install -y gcc gcc-c++ gcc-gfortran
  5. # 查看GCC版本
  6. gcc --version
  7. g++ --version
复制代码

1. Clang安装:
  1. # 安装Clang
  2. sudo dnf install -y clang clang-tools-extra
  3. # 查看Clang版本
  4. clang --version
  5. clang++ --version
复制代码

1. 配置编译器别名和优先级:
  1. # 安装alternatives系统
  2. sudo dnf install -y alternatives
  3. # 设置GCC版本优先级
  4. sudo alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-10 10
  5. sudo alternatives --install /usr/bin/g++ g++ /usr/bin/g++-10 10
  6. # 设置Clang版本优先级
  7. sudo alternatives --install /usr/bin/clang clang /usr/bin/clang-10 10
  8. sudo alternatives --install /usr/bin/clang++ clang++ /usr/bin/clang++-10 10
  9. # 切换编译器版本
  10. sudo alternatives --config gcc
  11. sudo alternatives --config clang
复制代码

调试工具配置

1. GDB安装与配置:
  1. # 安装GDB
  2. sudo dnf install -y gdb
  3. # 安装GDB插件
  4. sudo dnf install -y gdb-gdbserver gdb-doc
  5. # 配置GDB(创建~/.gdbinit)
  6. echo "set confirm off" >> ~/.gdbinit
  7. echo "set pagination off" >> ~/.gdbinit
  8. echo "set height 0" >> ~/.gdbinit
  9. echo "set width 0" >> ~/.gdbinit
复制代码

1. Valgrind安装与配置:
  1. # 安装Valgrind
  2. sudo dnf install -y valgrind
  3. # 使用Valgrind检测内存泄漏
  4. valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes --verbose --log-file=valgrind-out.txt ./your_program
复制代码

1. Sanitizers配置:

在编译时启用Sanitizers:
  1. # 地址Sanitizer(检测内存错误)
  2. g++ -fsanitize=address -g your_program.cpp -o your_program
  3. # 未定义行为Sanitizer
  4. g++ -fsanitize=undefined -g your_program.cpp -o your_program
  5. # 线程Sanitizer(检测数据竞争)
  6. g++ -fsanitize=thread -g your_program.cpp -o your_program
  7. # 内存Sanitizer(检测未初始化内存读取)
  8. g++ -fsanitize=memory -g your_program.cpp -o your_program
复制代码

1. Perf安装与配置:
  1. # 安装Perf
  2. sudo dnf install -y perf
  3. # 使用Perf进行性能分析
  4. perf record -g ./your_program
  5. perf report
复制代码

构建系统配置

1. Make配置:
  1. # 安装Make和CMake
  2. sudo dnf install -y make cmake
  3. # 示例Makefile
  4. CC = gcc
  5. CFLAGS = -Wall -O2
  6. TARGET = myprogram
  7. SRCS = main.c utils.c
  8. OBJS = $(SRCS:.c=.o)
  9. all: $(TARGET)
  10. $(TARGET): $(OBJS)
  11.         $(CC) $(CFLAGS) -o $@ $^
  12. %.o: %.c
  13.         $(CC) $(CFLAGS) -c $< -o $@
  14. clean:
  15.         rm -f $(OBJS) $(TARGET)
  16. .PHONY: all clean
复制代码

1. CMake配置:

创建CMakeLists.txt文件:
  1. cmake_minimum_required(VERSION 3.10)
  2. project(MyProject)
  3. # 设置C++标准
  4. set(CMAKE_CXX_STANDARD 14)
  5. set(CMAKE_CXX_STANDARD_REQUIRED ON)
  6. # 添加编译选项
  7. add_compile_options(-Wall -Wextra -O2)
  8. # 查找依赖包
  9. find_package(Boost REQUIRED COMPONENTS system filesystem)
  10. # 添加可执行文件
  11. add_executable(myprogram main.cpp utils.cpp)
  12. # 链接库
  13. target_link_libraries(myprogram PRIVATE Boost::system Boost::filesystem)
  14. # 安装规则
  15. install(TARGETS myprogram DESTINATION bin)
复制代码

使用CMake构建项目:
  1. mkdir build
  2. cd build
  3. cmake ..
  4. make
复制代码

1. Autotools配置:
  1. # 安装Autotools
  2. sudo dnf install -y autoconf automake libtool
  3. # 创建configure.ac文件
  4. cat > configure.ac << EOF
  5. AC_INIT([myprogram], [1.0], [bug@example.com])
  6. AM_INIT_AUTOMAKE([-Wall -Werror foreign])
  7. AC_PROG_CXX
  8. AC_CONFIG_FILES([Makefile])
  9. AC_OUTPUT
  10. EOF
  11. # 创建Makefile.am文件
  12. cat > Makefile.am << EOF
  13. bin_PROGRAMS = myprogram
  14. myprogram_SOURCES = main.cpp utils.cpp
  15. myprogram_CPPFLAGS = -Wall -Wextra
  16. EOF
  17. # 生成配置脚本
  18. autoreconf --install
  19. ./configure
  20. make
复制代码

1. Ninja构建系统:
  1. # 安装Ninja
  2. sudo dnf install -y ninja-build
  3. # 使用CMake生成Ninja构建文件
  4. cmake -G Ninja ..
  5. ninja
复制代码

C/C++性能优化

1. 编译器优化选项:
  1. # 基本优化
  2. g++ -O2 -march=native your_program.cpp -o your_program
  3. # 激进优化
  4. g++ -O3 -march=native -flto your_program.cpp -o your_program
  5. # 针对特定CPU架构优化
  6. g++ -O3 -march=haswell -mtune=haswell your_program.cpp -o your_program
  7. # 链接时优化(LTO)
  8. g++ -O3 -flto -fuse-linker-plugin your_program.cpp -o your_program
复制代码

1. Profile-Guided Optimization (PGO):
  1. # 第一步:生成检测版本
  2. g++ -O2 -march=native -fprofile-generate your_program.cpp -o your_program_profile
  3. # 第二步:运行检测版本生成配置文件
  4. ./your_program_profile
  5. # 第三步:使用配置文件进行优化编译
  6. g++ -O2 -march=native -fprofile-use -fprofile-correction your_program.cpp -o your_program_optimized
复制代码

1. 使用Cache-友好数据结构:
  1. // 示例:优化数据结构以提高缓存局部性
  2. #include <vector>
  3. struct Data {
  4.     int id;
  5.     double value1;
  6.     double value2;
  7.     // 其他数据成员
  8. };
  9. // 使用连续内存容器
  10. void processData(const std::vector<Data>& data) {
  11.     // 处理数据
  12.     for (const auto& item : data) {
  13.         // 访问连续内存,提高缓存命中率
  14.         double result = item.value1 * item.value2;
  15.         // 其他处理...
  16.     }
  17. }
复制代码

1. 多线程并行化:
  1. // 使用OpenMP进行并行化
  2. #include <vector>
  3. #include <omp.h>
  4. void parallelProcess(std::vector<double>& data) {
  5.     #pragma omp parallel for
  6.     for (size_t i = 0; i < data.size(); ++i) {
  7.         data[i] = complexComputation(data[i]);
  8.     }
  9. }
  10. // 使用C++17并行算法
  11. #include <algorithm>
  12. #include <execution>
  13. #include <vector>
  14. void parallelSort(std::vector<int>& data) {
  15.     std::sort(std::execution::par, data.begin(), data.end());
  16. }
复制代码

1. SIMD向量化:
  1. // 使用编译器内置函数进行SIMD优化
  2. #include <immintrin.h>
  3. void vectorAdd(float* a, float* b, float* result, int size) {
  4.     // 处理不能被4整除的部分
  5.     int i = 0;
  6.     for (; i < size % 4; ++i) {
  7.         result[i] = a[i] + b[i];
  8.     }
  9.    
  10.     // 使用AVX指令集进行向量化计算
  11.     for (; i < size; i += 4) {
  12.         __m128 va = _mm_loadu_ps(&a[i]);
  13.         __m128 vb = _mm_loadu_ps(&b[i]);
  14.         __m128 vresult = _mm_add_ps(va, vb);
  15.         _mm_storeu_ps(&result[i], vresult);
  16.     }
  17. }
复制代码

其他编程语言环境

JavaScript/Node.js开发环境

1. Node.js安装:
  1. # 使用Fedora仓库安装Node.js
  2. sudo dnf install -y nodejs npm
  3. # 或使用NVM(Node Version Manager)管理多个Node.js版本
  4. curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.3/install.sh | bash
  5. source ~/.bashrc
  6. # 安装特定版本的Node.js
  7. nvm install 14
  8. nvm install 12
  9. # 切换Node.js版本
  10. nvm use 14
复制代码

1. Yarn包管理器:
  1. # 安装Yarn
  2. sudo dnf install -y yarn
  3. # 或通过npm安装
  4. npm install -g yarn
复制代码

1. 前端框架开发环境:
  1. # 安装Vue CLI
  2. npm install -g @vue/cli
  3. # 安装React开发工具
  4. npm install -g create-react-app
  5. # 安装Angular CLI
  6. npm install -g @angular/cli
复制代码

1. TypeScript配置:
  1. # 安装TypeScript
  2. npm install -g typescript ts-node
  3. # 创建tsconfig.json
  4. tsc --init
复制代码

Go开发环境

1. Go安装:
  1. # 使用Fedora仓库安装Go
  2. sudo dnf install -y golang
  3. # 或手动安装
  4. wget https://golang.org/dl/go1.15.linux-amd64.tar.gz
  5. sudo tar -C /usr/local -xzf go1.15.linux-amd64.tar.gz
复制代码

1. 配置Go环境变量(在~/.zshrc或~/.bashrc中):
  1. export PATH=$PATH:/usr/local/go/bin
  2. export GOPATH=$HOME/go
  3. export PATH=$PATH:$GOPATH/bin
复制代码

1. Go开发工具:
  1. # 安装Go工具链
  2. go get -u golang.org/x/tools/cmd/goimports
  3. go get -u golang.org/x/tools/cmd/godoc
  4. go get -u golang.org/x/tools/cmd/gorename
  5. go get -u golang.org/x/tools/cmd/guru
  6. go get -u github.com/go-delve/delve/cmd/dlv
复制代码

1. Go模块配置:
  1. # 启用Go模块
  2. export GO111MODULE=on
  3. # 初始化模块
  4. go mod init example.com/mymodule
  5. # 添加依赖
  6. go get github.com/gin-gonic/gin
复制代码

Rust开发环境

1. Rust安装:
  1. # 使用Rustup安装Rust
  2. curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
  3. source $HOME/.cargo/env
复制代码

1. 配置Rust工具链:
  1. # 查看已安装的工具链
  2. rustc --version
  3. cargo --version
  4. # 安装其他工具链
  5. rustup toolchain install nightly
  6. rustup toolchain install stable
  7. # 设置默认工具链
  8. rustup default stable
  9. # 切换工具链
  10. rustup default nightly
复制代码

1. Rust开发工具:
  1. # 安装Rustfmt(代码格式化工具)
  2. rustup component add rustfmt
  3. # 安装Clippy(代码检查工具)
  4. rustup component add clippy
  5. # 安装Rust Language Server(用于IDE支持)
  6. rustup component add rls rust-analysis rust-src
复制代码

1. Cargo配置:

创建~/.cargo/config文件:
  1. [source.crates-io]
  2. registry = "https://github.com/rust-lang/crates.io-index"
  3. # 替换为国内镜像
  4. replace-with = 'ustc'
  5. [source.ustc]
  6. registry = "https://mirrors.ustc.edu.cn/crates.io-index"
  7. [net]
  8. git-fetch-with-cli = true
复制代码

系统级性能优化

内核参数调整

1. 调整内核参数以优化性能:

编辑/etc/sysctl.d/99-performance.conf文件:
  1. # 增加文件句柄限制
  2. fs.file-max = 100000
  3. fs.inotify.max_user_watches = 524288
  4. # 优化网络设置
  5. net.core.rmem_max = 16777216
  6. net.core.wmem_max = 16777216
  7. net.ipv4.tcp_rmem = 4096 87380 16777216
  8. net.ipv4.tcp_wmem = 4096 65536 16777216
  9. net.ipv4.tcp_congestion_control = bbr
  10. net.ipv4.tcp_fastopen = 3
  11. net.ipv4.tcp_max_syn_backlog = 65536
  12. net.core.netdev_max_backlog = 65536
  13. # 优化虚拟内存管理
  14. vm.swappiness = 10
  15. vm.dirty_ratio = 60
  16. vm.dirty_background_ratio = 2
  17. # 优化调度器
  18. kernel.sched_min_granularity_ns = 10000000
  19. kernel.sched_wakeup_granularity_ns = 15000000
  20. kernel.sched_migration_cost_ns = 5000000
复制代码

应用更改:
  1. sudo sysctl -p /etc/sysctl.d/99-performance.conf
复制代码

1. 使用 tuned 进行系统优化:
  1. # 安装tuned
  2. sudo dnf install -y tuned
  3. # 启动并启用tuned服务
  4. sudo systemctl enable --now tuned
  5. # 查看可用的配置文件
  6. sudo tuned-adm list
  7. # 应用性能优化配置
  8. sudo tuned-adm profile throughput-performance
复制代码

文件系统优化

1. 选择合适的文件系统:

Fedora 32默认使用XFS文件系统,但根据你的需求,你可能需要考虑其他选项:

• XFS:适合大文件和高性能场景
• ext4:通用文件系统,稳定可靠
• Btrfs:适合需要快照和压缩功能的场景
• ZFS:适合需要高级数据保护和企业级功能的场景

1. 挂载选项优化:

编辑/etc/fstab文件,添加适当的挂载选项:
  1. # 示例:为SSD优化ext4文件系统
  2. UUID=your-uuid-here  /  ext4  defaults,noatime,discard,data=writeback  0  1
  3. # 示例:为性能优化XFS文件系统
  4. UUID=your-uuid-here  /data  xfs  defaults,noatime,largeio,inode64  0  2
复制代码

1. 使用fstrim定期优化SSD:
  1. # 启用并启动fstrim定时器
  2. sudo systemctl enable fstrim.timer
  3. sudo systemctl start fstrim.timer
复制代码

内存管理优化

1. 配置交换空间:
  1. # 创建交换文件
  2. sudo fallocate -l 4G /swapfile
  3. sudo chmod 600 /swapfile
  4. sudo mkswap /swapfile
  5. sudo swapon /swapfile
  6. # 使交换文件永久生效
  7. echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab
  8. # 调整交换参数(swappiness值)
  9. echo 'vm.swappiness=10' | sudo tee -a /etc/sysctl.conf
  10. sudo sysctl -p
复制代码

1. 配置透明大页(THP):
  1. # 禁用透明大页(对某些应用如数据库可能有益)
  2. echo 'never' | sudo tee /sys/kernel/mm/transparent_hugepage/enabled
  3. echo 'never' | sudo tee /sys/kernel/mm/transparent_hugepage/defrag
  4. # 使设置永久生效
  5. echo 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' | sudo tee -a /etc/rc.local
  6. echo 'echo never > /sys/kernel/mm/transparent_hugepage/defrag' | sudo tee -a /etc/rc.local
  7. sudo chmod +x /etc/rc.local
复制代码

1. 使用zRAM进行内存压缩:
  1. # 安装zRAM
  2. sudo dnf install -y zram-generator
  3. # 配置zRAM(创建/etc/systemd/zram-generator.conf)
  4. echo '[zram0]' | sudo tee /etc/systemd/zram-generator.conf
  5. echo 'zram-size = 4096' | sudo tee -a /etc/systemd/zram-generator.conf
  6. echo 'compression-algorithm = lz4' | sudo tee -a /etc/systemd/zram-generator.conf
  7. # 启用并启动zRAM
  8. sudo systemctl daemon-reload
  9. sudo systemctl start zram0
复制代码

容器化与虚拟化开发环境

Docker配置

1. 安装Docker:
  1. # 安装Docker CE
  2. sudo dnf config-manager --add-repo https://download.docker.com/linux/fedora/docker-ce.repo
  3. sudo dnf install -y docker-ce docker-ce-cli containerd.io
  4. # 启动并启用Docker服务
  5. sudo systemctl enable --now docker
复制代码

1. 配置Docker(创建/etc/docker/daemon.json):
  1. {
  2.   "registry-mirrors": [
  3.     "https://dockerhub.azk8s.cn",
  4.     "https://reg-mirror.qiniu.com"
  5.   ],
  6.   "insecure-registries": [],
  7.   "debug": false,
  8.   "experimental": false,
  9.   "storage-driver": "overlay2",
  10.   "log-driver": "json-file",
  11.   "log-opts": {
  12.     "max-size": "10m",
  13.     "max-file": "3"
  14.   }
  15. }
复制代码

1. 将用户添加到docker组:
  1. sudo usermod -aG docker $USER
  2. newgrp docker
复制代码

1. 安装Docker Compose:
  1. sudo dnf install -y docker-compose
复制代码

1. 开发容器示例:

创建Dockerfile:
  1. FROM python:3.8-slim
  2. WORKDIR /app
  3. COPY requirements.txt .
  4. RUN pip install --no-cache-dir -r requirements.txt
  5. COPY . .
  6. CMD ["python", "app.py"]
复制代码

创建docker-compose.yml:
  1. version: '3'
  2. services:
  3.   web:
  4.     build: .
  5.     ports:
  6.       - "5000:5000"
  7.     volumes:
  8.       - .:/app
  9.     environment:
  10.       - FLASK_ENV=development
  11.   
  12.   db:
  13.     image: postgres:12
  14.     environment:
  15.       - POSTGRES_USER=devuser
  16.       - POSTGRES_PASSWORD=devpass
  17.       - POSTGRES_DB=devdb
  18.     volumes:
  19.       - postgres_data:/var/lib/postgresql/data
  20. volumes:
  21.   postgres_data:
复制代码

虚拟机配置

1. 安装KVM/QEMU虚拟化:
  1. # 检查系统是否支持虚拟化
  2. grep -E 'vmx|svm' /proc/cpuinfo
  3. # 安装KVM和QEMU
  4. sudo dnf install -y @virtualization
  5. sudo systemctl enable --now libvirtd
  6. # 将用户添加到libvirt组
  7. sudo usermod -aG libvirt $(whoami)
复制代码

1. 安装Vagrant:
  1. # 安装Vagrant
  2. sudo dnf install -y vagrant
  3. # 安装Vagrant插件
  4. vagrant plugin install vagrant-libvirt
复制代码

1. 创建Vagrantfile:
  1. Vagrant.configure("2") do |config|
  2.   config.vm.box = "fedora/32-cloud-base"
  3.   
  4.   config.vm.provider "libvirt" do |libvirt|
  5.     libvirt.memory = "2048"
  6.     libvirt.cpus = 2
  7.   end
  8.   
  9.   # 配置开发环境
  10.   config.vm.provision "shell", inline: <<-SHELL
  11.     dnf update -y
  12.     dnf install -y @development-tools python3 python3-pip nodejs npm
  13.     pip3 install --user pipenv
  14.   SHELL
  15. end
复制代码

1. 启动虚拟机:
  1. vagrant up
  2. vagrant ssh
复制代码

总结与最佳实践

通过本文的详细指导,你应该能够在Fedora 32上构建一个功能强大、高效稳定的编程环境。以下是一些关键的最佳实践总结:

1. 系统维护:定期更新系统和软件包使用性能监控工具跟踪系统资源使用情况定期备份重要配置和数据
2. 定期更新系统和软件包
3. 使用性能监控工具跟踪系统资源使用情况
4. 定期备份重要配置和数据
5. 开发环境管理:使用版本管理器(如pyenv、SDKMAN等)管理多个语言版本为每个项目创建独立的开发环境使用容器化技术(如Docker)确保环境一致性
6. 使用版本管理器(如pyenv、SDKMAN等)管理多个语言版本
7. 为每个项目创建独立的开发环境
8. 使用容器化技术(如Docker)确保环境一致性
9. 性能优化:根据项目需求调整系统参数使用适当的编译器优化选项利用性能分析工具识别和解决瓶颈
10. 根据项目需求调整系统参数
11. 使用适当的编译器优化选项
12. 利用性能分析工具识别和解决瓶颈
13. 安全考虑:定期更新系统和依赖库以修复安全漏洞使用最小权限原则配置开发环境敏感信息使用安全存储(如密码管理器)
14. 定期更新系统和依赖库以修复安全漏洞
15. 使用最小权限原则配置开发环境
16. 敏感信息使用安全存储(如密码管理器)
17. 工作流程优化:自动化重复性任务(如构建、测试、部署)使用适当的IDE和编辑器插件提高开发效率采用版本控制最佳实践(如分支策略、代码审查)
18. 自动化重复性任务(如构建、测试、部署)
19. 使用适当的IDE和编辑器插件提高开发效率
20. 采用版本控制最佳实践(如分支策略、代码审查)

系统维护:

• 定期更新系统和软件包
• 使用性能监控工具跟踪系统资源使用情况
• 定期备份重要配置和数据

开发环境管理:

• 使用版本管理器(如pyenv、SDKMAN等)管理多个语言版本
• 为每个项目创建独立的开发环境
• 使用容器化技术(如Docker)确保环境一致性

性能优化:

• 根据项目需求调整系统参数
• 使用适当的编译器优化选项
• 利用性能分析工具识别和解决瓶颈

安全考虑:

• 定期更新系统和依赖库以修复安全漏洞
• 使用最小权限原则配置开发环境
• 敏感信息使用安全存储(如密码管理器)

工作流程优化:

• 自动化重复性任务(如构建、测试、部署)
• 使用适当的IDE和编辑器插件提高开发效率
• 采用版本控制最佳实践(如分支策略、代码审查)

Fedora 32作为一个现代化的Linux发行版,为开发者提供了丰富的工具和资源。通过合理配置和优化,你可以打造一个适合多种编程语言的高效开发环境,从而提高开发效率和代码质量。
「七転び八起き(ななころびやおき)」
回复

使用道具 举报

0

主题

1304

科技点

654

积分

候风辨气

积分
654
候风辨气 发表于 2025-9-17 08:49:57 | 显示全部楼层
感謝分享
温馨提示:看帖回帖是一种美德,您的每一次发帖、回帖都是对论坛最大的支持,谢谢! [这是默认签名,点我更换签名]
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则