有一个集成TCL解释器的程序(就叫TT吧)执行带exec的脚本启动一个进程(PP),TT本身创建了SOCKET端口与其它程序进行通信。这时关闭TT,PP还在运行,使用netstat查看端口号,发现TT创建的端口号仍然存在,并且不能再创建此端口号。说明端口未关闭,可是TT已经退出了,很奇怪。于是查看exec的实现,发现是使用CreateProcess来创建进程的,它的第五个参数是设置继承句柄的,在exec的实现中被无条件设置成了TRUE。应该就是这个原因了,SOCKET句柄被子进程继承了,句柄是操作系统的资源,PP不退出当然也就不会释放了,所以TT创建的SOCKET端口一直被占用。
从上面这个问题想到使用CreateProcess时要注意的事项,如果不需要继续父进程的句柄就不要设置成TRUE,以免产生不必要的麻烦。同时,一般的启动进程也可以使用比较简单的几个API,如WinExec,ShellExecute。