fast-able 1.20.2

The world's martial arts are fast and unbreakable; 天下武功 唯快不破
Documentation
use fast_able::fast_thread_pool::utils::{use_last_core, use_last_core2};
use log::{error, info};
use std::{fs, fs::OpenOptions};

fn main() {
    // 简单打印日志,不使用env_logger初始化
    println!("开始测试核心分配逻辑: {}", file!());
    
    // 删除旧的核心亲和性文件以确保干净的测试环境
    println!("尝试删除旧的核心亲和性文件");
    fast_able::fast_thread_pool::init(true);
    
    // 测试多次调用核心分配函数,查看分配的顺序和重复情况
    println!("\n第一轮分配测试");
    
    // 测试分配多个核心
    // let core1 = use_last_core2("测试1多核心", 5);
    // let core1 = use_last_core2("测试11多核心", 5);
    // let core1 = use_last_core2("测试11多核心", 5);
    // println!("测试1分配的核心: {:?}", core1);
    
    // 测试单核心分配
    let core2 = use_last_core("测试2单核心");
    println!("测试2分配的核心: {:?}", core2);

    let core1 = use_last_core2("测试11多核心", 10);
    
    let core3 = use_last_core("测试3单核心");
    println!("测试3分配的核心: {:?}", core3);
    
    let core4 = use_last_core("测试4单核心");
    println!("测试4分配的核心: {:?}", core4);
    
    let core5 = use_last_core("测试5单核心");
    println!("测试5分配的核心: {:?}", core5);
    
    // 读取并显示.core_affinity文件内容
    println!("\n第一轮分配后的核心亲和性文件内容:");
    match fs::read_to_string(".core_affinity") {
        Ok(content) => {
            for line in content.lines() {
                println!("{}", line);
            }
        }
        Err(e) => println!("无法读取.core_affinity文件: {}", e),
    }
    
    println!("\n核心分配逻辑测试完成");
}