控制台程序的标准输入输出的重定向
今天终于解决这个问题困扰我几个月的问题,心里很高兴!!!
在使用重定向技术需要注意以下几个问题:
1、子进程程序每一句输出代码后需要调用fflush(stdout)函数,这样把输出的内容放入缓冲区,父进程才能及时的读到输出数据
2、如果不是使用fflush(stdout)函数,子进程使用gets()函数会阻止子进程的线程运行
3、重定向最好使用完成端口,这样可以一个线程处理很多的重定向子进程,减少线程数量
下面是我测试的代码
// stdafx.h : 标准系统包含文件的包含文件,
// 或是常用但不常更改的项目特定的包含文件
//
#pragma once
#include <iostream>
#include <tchar.h>
#include <windows.h>
#include <process.h>
// TODO: 在此处引用程序要求的附加头文件
// ClientServ.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <deque>
using namespace std;
bool q=false;
unsigned int _stdcall ThreadOne(void* param)
{
int * id=(int*)param;
printf("线程%d运行/
今天终于解决这个问题困扰我几个月的问题,心里很高兴!!!
在使用重定向技术需要注意以下几个问题:
1、子进程程序每一句输出代码后需要调用fflush(stdout)函数,这样把输出的内容放入缓冲区,父进程才能及时的读到输出数据
2、如果不是使用fflush(stdout)函数,子进程使用gets()函数会阻止子进程的线程运行
3、重定向最好使用完成端口,这样可以一个线程处理很多的重定向子进程,减少线程数量
下面是我测试的代码
// stdafx.h : 标准系统包含文件的包含文件,
// 或是常用但不常更改的项目特定的包含文件
//
#pragma once
#include <iostream>
#include <tchar.h>
#include <windows.h>
#include <process.h>
// TODO: 在此处引用程序要求的附加头文件
// ClientServ.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <deque>
using namespace std;
bool q=false;
unsigned int _stdcall ThreadOne(void* param)
{
int * id=(int*)param;
printf("线程%d运行/