c#启动程序时使用异步读取输出避免假死

某次调用某个exe,在cmd命令中调用正常,但是一旦使用代码调用则直接假死。

后来了解到原来是输出流阻塞导致的假死,这个时候只需要使用异步读取输出就可以了,直接上代码:

cs 复制代码
        public static bool ExecuteFileConvertHelper(string sPara)
        {
            try
            {
                // 获取当前程序所在的目录
                string exeDir = AppDomain.CurrentDomain.BaseDirectory;
                // 拼接 FileConvert.exe 的完整路径
                string exePath = Path.Combine(exeDir, "FileConvert.exe");

                // 检查文件是否存在
                if (!File.Exists(exePath))
                {
                    LibLogger.LogManager.GetManager().WriteCommon($"FileConvert.exe not found at: {exePath}");
                    return false;
                }

                // 创建一个新的进程启动信息
                ProcessStartInfo startInfo = new ProcessStartInfo
                {
                    FileName = exePath,
                    Arguments = sPara,
                    RedirectStandardOutput = true,
                    RedirectStandardError = true,
                    UseShellExecute = false,
                    CreateNoWindow = true // 不创建窗口
                };

                // 启动进程
                using (Process process = Process.Start(startInfo))
                {
                    // 确保进程不是 null
                    if (process == null)
                    {
                        return false;
                    }

                    // 异步读取标准输出
                    process.OutputDataReceived += (sender, e) =>
                    {
                        if (!string.IsNullOrEmpty(e.Data))
                        {
                            // 可以在这里处理输出数据,例如记录日志
                            //LibLogger.LogManager.GetManager().WriteCommon(e.Data);
                        }
                    };

                    // 异步读取标准错误
                    process.ErrorDataReceived += (sender, e) =>
                    {
                        if (!string.IsNullOrEmpty(e.Data))
                        {
                            // 可以在这里处理错误数据,例如记录错误日志
                            //LibLogger.LogManager.GetManager().WriteCommon(e.Data);
                        }
                    };

                    // 开始异步读取
                    process.BeginOutputReadLine();
                    process.BeginErrorReadLine();

                    // 等待进程退出
                    process.WaitForExit();

                    // 检查退出代码
                    if (process.ExitCode == 0)
                    {
                        // 成功执行
                        return true;
                    }
                    else
                    {
                        // 执行失败
                        return false;
                    }
                }
            }
            catch (Exception ex)
            {
                // 可以在这里记录异常日志
                LibLogger.LogManager.GetManager().WriteCommon(ex.Message);
                return false;
            }
    }

谨此纪念。

相关推荐
摇滚侠1 小时前
npm 设置了阿里云镜像,然后全局安装了 pnpm,pnpm 还需要设置阿里云镜像吗
前端·阿里云·npm
程序员清洒7 小时前
Flutter for OpenHarmony:GridView — 网格布局实现
android·前端·学习·flutter·华为
VX:Fegn08957 小时前
计算机毕业设计|基于ssm + vue超市管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
0思必得07 小时前
[Web自动化] 反爬虫
前端·爬虫·python·selenium·自动化
徐徐同学8 小时前
cpolar为IT-Tools 解锁公网访问,远程开发再也不卡壳
java·开发语言·分布式
LawrenceLan8 小时前
Flutter 零基础入门(二十六):StatefulWidget 与状态更新 setState
开发语言·前端·flutter·dart
秋秋小事8 小时前
TypeScript 模版字面量与类型操作
前端·typescript
2401_892000528 小时前
Flutter for OpenHarmony 猫咪管家App实战 - 添加提醒实现
前端·javascript·flutter
Yolanda948 小时前
【项目经验】vue h5移动端禁止缩放
前端·javascript·vue.js
Mr.朱鹏9 小时前
Nginx路由转发案例实战
java·运维·spring boot·nginx·spring·intellij-idea·jetty