添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
std::shared_ptr 可共享指针对象,可以赋值给shared_ptr或weak_ptr。 通过引用计数的方式控制生命周期,当指针所指对象的所有的shared_ptr生命周期结束时(引用计数为0时)会被销毁。 std::weak_ptr 可以指向shared_ptr,但并不影响引用计数。 不影像所指对象的生命周期,在引用所指对象时,先用需要lock()才能使用。 Boost 不共享对象,类似于std::unique_ptr boost::scoped_ptr boost::scoped_array 共享对象,类似于std::shared_ptr boost::shared_ptr boost::shared_array 共享对象,但不改变对象引用计数,类似于std::weak_ptr boost::weak_ptr 侵入式引用计数,要求使用对象自己实现计数功能 boost::intrusive_ptr

下面给一个例子,说明一下std下的四种智能指针。
1、SmartPointerTest.cpp

#include <memory> #include <iostream> #include "MyTest.h" using namespace std; void test_auto_ptr() std::auto_ptr<MyTest> auto_ptr_01(new MyTest("tom", 20)); if (auto_ptr_01.get()) auto_ptr_01->sayHello(); auto_ptr_01.get()->_name = "jerry"; auto_ptr_01->sayHello(); (*auto_ptr_01)._age += 1; auto_ptr_01->sayHello(); //auto_ptr_02会抢占auto_ptr_01的对象 //此后auto_ptr_01不指向MyTest对象 std::auto_ptr<MyTest> auto_ptr_02 = auto_ptr_01; if (auto_ptr_01.get()) cout << "auto_ptr_01 is released" << endl; auto_ptr_02->sayHello(); //只是释放所有权,并不释放内存 //MyTest* test = auto_ptr_02.release(); //释放内存 auto_ptr_02.reset(); if (!auto_ptr_01.get()) cout <<"auto_ptr_02 is released"<< endl; void test_unique_ptr() //独占对象 //保证指针所指对象生命周期与其一致 unique_ptr<MyTest> unique_ptr_01(new MyTest("tom", 20)); unique_ptr_01->sayHello(); //不允许直接做右值 //unique_ptr<int> unique_ptr_02 = unique_ptr_01; //需要通过move来处理 unique_ptr<MyTest> unique_ptr_03 = move(unique_ptr_01); if (!unique_ptr_01)cout << "unique_ptr_01 is empty" << endl; unique_ptr_03->sayHello(); //释放指针 unique_ptr_03.reset(); if (!unique_ptr_03)cout << "unique_ptr_03 is empty" << endl; void test_shared_ptr() shared_ptr<MyTest> shared_ptr_01(make_shared<MyTest>("tom", 20)); shared_ptr<MyTest> shared_ptr_02 = shared_ptr_01; shared_ptr_01->sayHello(); shared_ptr_02->sayHello(); shared_ptr_01.reset(); if (!shared_ptr_01)cout << "shared_ptr_01 is empty" << endl; shared_ptr_02->sayHello(); shared_ptr_02.reset(); if (!shared_ptr_02)cout << "shared_ptr_02 is empty" << endl; void test_weak_ptr() shared_ptr<MyTest> shared_ptr_01(make_shared<MyTest>("tom", 20)); weak_ptr<MyTest> weak_ptr_01 = shared_ptr_01; shared_ptr_01->sayHello(); weak_ptr_01.lock()->sayHello(); weak_ptr_01.reset(); if (!weak_ptr_01.lock())cout << "weak_ptr_01 is empty" << endl; shared_ptr_01->sayHello(); weak_ptr<MyTest> weak_ptr_02 = shared_ptr_01; weak_ptr<MyTest> weak_ptr_03 = weak_ptr_02; if(weak_ptr_01.lock())weak_ptr_02.lock()->sayHello(); shared_ptr_01.reset(); if (!weak_ptr_01.lock())cout << "weak_ptr_02 is empty" << endl; int _tmain(int argc, _TCHAR* argv[]) test_auto_ptr(); test_unique_ptr(); test_shared_ptr(); test_weak_ptr(); return 0;

2、MyTest.h

#pragma once #include <iostream> #include <string> using namespace std; class MyTest public: MyTest(string name, int age); ~MyTest(); void sayHello(); public: string _name; int _age;

3、MyTest.cpp

#include "stdafx.h" #include "MyTest.h" MyTest::MyTest(string name, int age) _name = name; _age = age; MyTest::~MyTest() void MyTest::sayHello() cout << "Hello " << _name<< "! You are "<< _age <<" years old." << endl; 聪明的你有没有发下,CPP的智能指针,与JVM内存中的四种引用方式,强引用、软引用、弱引用,虚引用,有很多相似的地方呢?

CORBA::Object_var m_obj; // Resolved id to object reference CORBA::Object_var m_obj1; // Resolved and narrowed CORBA object for proxy calls HiCorba::Hi_var m_Data; class DS_ServerConnectionException{ public: DS_ServerConnectionException() { cerr << "CORBA COMM_FAILURE" << endl; }; class DS_SystemException{ public: DS_SystemException() { cerr << "CORBA Exception" << endl; }; class DS_FatalException{ public: DS_FatalException() { cerr << "CORBA Fatal Exception" << endl; }; class DS_Exception{ public: DS_Exception() { cerr << "Exception" << endl; };

HiClientImpl.cc

#include "assert.h" #include "HiClientImpl.hh" #include "Hi.hh" HiClientImpl::HiClientImpl() try { //------------------------------------------------------------------------ // Initialize ORB object. //------------------------------------------------------------------------ int argc=0; // Dummy variables to support following call. char** argv=0; CORBA::ORB_var orb = CORBA::ORB_init(argc, argv); //------------------------------------------------------------------------ // Bind ORB object to name service object. // (Reference to Name service root context.) //------------------------------------------------------------------------ //CORBA::Object_var obj = orb->resolve_initial_references("OmniNameService"); CORBA::Object_var obj = orb->resolve_initial_references("NameService"); assert (!CORBA::is_nil(obj.in())); cerr << "resolve_initial_reference OK" << endl; //------------------------------------------------------------------------ // Narrow this to the naming context (Narrowed reference to root context.) //------------------------------------------------------------------------ CosNaming::NamingContext_var nc = CosNaming::NamingContext::_narrow(obj.in()); assert (!CORBA::is_nil(nc.in())); cerr << "narrow ok" << endl; //------------------------------------------------------------------------ // The "name text" put forth by CORBA server in name service. // This same name ("DataServiceName1") is used by the CORBA server when // binding to the name server (CosNaming::Name). //------------------------------------------------------------------------ CosNaming::Name _corbaCosName; _corbaCosName.length(1); _corbaCosName[0].id=CORBA::string_dup("Hi"); //------------------------------------------------------------------------ // Resolve "name text" identifier to an object reference. //------------------------------------------------------------------------ CORBA::Object_var obj1 = nc->resolve(_corbaCosName); assert(!CORBA::is_nil(obj1.in())); cerr << "resolve OK" << endl; m_Data = HiCorba::Hi::_narrow(obj1.in()); if (CORBA::is_nil(m_Data.in())) cerr << "IOR is not an SA object reference." << endl; else{ cerr << "narrow OK" << endl; catch(CORBA::COMM_FAILURE& ex) { cerr << "Caught system exception COMM_FAILURE -- unable to contact the " << "object." << endl; throw DS_ServerConnectionException(); return; catch(CORBA::SystemException& ) { cerr << "Caught a CORBA::SystemException." << endl; throw DS_SystemException(); return; catch(CORBA::Exception& ) { cerr << "Caught CORBA::Exception." << endl; throw DS_Exception(); return; } catch(omniORB::fatalException& fe) { cerr << "Caught omniORB::fatalException:" << endl; cerr << " file: " << fe.file() << endl; cerr << " line: " << fe.line() << endl; cerr << " mesg: " << fe.errmsg() << endl; throw DS_FatalException(); return; catch(...) { cerr << "Caught unknown exception." << endl; throw DS_Exception(); return; return; HiClientImpl::~HiClientImpl() void HiClientImpl::TestAdd() CORBA::Long num1=70; CORBA::Long num2=80; CORBA::Long retNum; cout << "Values input to Server: " << num1 << " " << num2 << " " << endl; if( retNum = m_Data->add( num1, num2)) // This is the CORBA call which is to be executed remotely { // Ok cout << "Values returned by Server: " << num1 << "+" << num2 << "=" << retNum << endl;

HiClient.cc

#include "HiClientImpl.hh" int main(int argc, char** argv) HiClientImpl impl; impl.TestAdd(); return 0;

MakeClient

CC = /usr/bin/g++ CPPFLAGS = -g -c -I/usr/include -I/usr/include/omniORB4 LDFLAGS = -g -L/usr/lib -lomniORB4 -lomnithread -lomniDynamic4 OMNIIDL = /usr/bin/omniidl all: HiClient.bin HiClient.bin: HiClient.o HiClientImpl.o HiSK.o $(CC) $(LDFLAGS) -o HiClient.bin HiClient.o HiClientImpl.o HiSK.o HiSK.o: HiSK.cc Hi.hh $(CC) $(CPPFLAGS) $(INCLUDES) HiSK.cc HiClient.o: HiClient.cc HiClientImpl.hh $(CC) $(CPPFLAGS) HiClient.cc HiClientImpl.o: HiClientImpl.cc HiClientImpl.hh Hi.hh $(CC) $(CPPFLAGS) HiClientImpl.cc nidl: Hi.idl $(OMNIIDL) -bcxx Hi.idl clean: rm -f *.o make -f MakeClient

然后是运行

#首先检查OMNI Naming Service是否在运行,默认端口2809 ps -aux | grep omni root 1585 0.0 0.2 315608 4912 ? Sl 12:04 0:00 /usr/bin/omniNames -errlog /var/log/omniorb-nameserver.log neohope 1943 0.0 0.1 12720 2180 tty2 S+ 14:57 0:00 grep omni #运行服务端 ./HiServer #运行客户端 ./HiClient >>Values input to Server: 70 80 >>Values returned by Server: 70+80=150 apt-get install omniidl apt-get install libomniorb4-dev export OMNIORB_CONFIG=/etc/omniORB.cfg

然后修改配置文件/etc/omniORB.cfg,修改日志输出级别。

编译Hi.idl文件,将生成文件Hi.hh及HiSK.cc

omniidl -bcxx Hi.idl

首先完成服务端部分,分了三个文件:

HiServerImpl.hh

#include <CORBA.h> #include "Hi.hh" class HiServerImpl : public virtual POA_HiCorba::Hi, public virtual PortableServer::RefCountServantBase public: HiServerImpl(); ~HiServerImpl(); char* sayHiTo(const char* someone); ::CORBA::Long add(::CORBA::Long numa, ::CORBA::Long numb); void shutdown();

HiServerImpl.cc

#include <vector> #include <string> #include <string.h> #include <sys/types.h> #include <unistd.h> #include <stdio.h> #include <stdlib.h> #include <iostream> #include <fstream> #include <stdio.h> #include <sys/wait.h> #include "HiServerImpl.hh" using namespace HiCorba; HiServerImpl::HiServerImpl() HiServerImpl::~HiServerImpl() char* HiServerImpl::sayHiTo(const char* someone) ::CORBA::Long HiServerImpl::add(::CORBA::Long numa, ::CORBA::Long numb) return numa+numb; void HiServerImpl::shutdown()

HiServer.cc

#include <stdlib.h> #include <iostream> #include <string> #include <assert.h> #include <signal.h> #include <unistd.h> #include "HiServerImpl.hh" #include "Hi.hh" using namespace std; int main(int argc, char** argv) try { //------------------------------------------------------------------------ // Initialize CORBA ORB - "orb" //------------------------------------------------------------------------ CORBA::ORB_var orb = CORBA::ORB_init(argc, argv); //------------------------------------------------------------------------ // Servant must register with POA in order to be made available for client // Get reference to the RootPOA. //------------------------------------------------------------------------ CORBA::Object_var obj = orb->resolve_initial_references("RootPOA"); PortableServer::POA_var _poa = PortableServer::POA::_narrow(obj.in()); //------------------------------------------------------------------------ // Operations defined in object interface invoked via an object reference. // Instance of CRequestSocketStream_i servant is initialized. //------------------------------------------------------------------------ HiServerImpl* impl = new HiServerImpl(); //------------------------------------------------------------------------ // Servant object activated in RootPOA. // (Object id used for various POA operations.) //------------------------------------------------------------------------ PortableServer::ObjectId_var myOid = _poa->activate_object(impl); //------------------------------------------------------------------------ // Obtain object reference from servant and register in naming service(??) //------------------------------------------------------------------------ CORBA::Object_var SA_obj = impl->_this(); //------------------------------------------------------------------------ // Obtain a reference to the object, and print it out as string IOR. //------------------------------------------------------------------------ CORBA::String_var sior(orb->object_to_string(SA_obj.in())); cerr << "'" << (char*)sior << "'" << endl; //======================================================================== // Bind (rebind) object (orb) to name (SA_obj) //======================================================================== //------------------------------------------------------------------------ // Bind object to name service as defined by directive InitRef // and identifier "OmniNameService" in config file omniORB.cfg. //------------------------------------------------------------------------ //CORBA::Object_var obj1=orb->resolve_initial_references("OmniNameService"); CORBA::Object_var obj1=orb->resolve_initial_references("NameService"); assert(!CORBA::is_nil(obj1.in())); cerr << "resolve_initial_references successed" << endl; //------------------------------------------------------------------------ // narrow this to the naming context //------------------------------------------------------------------------ CosNaming::NamingContext_var nc = CosNaming::NamingContext::_narrow(obj1.in()); assert(!CORBA::is_nil(nc.in())); cerr << "narrow successed" << endl; //------------------------------------------------------------------------ // Bind to CORBA name service. Same name to be requested by client. //------------------------------------------------------------------------ CosNaming::Name name; name.length(1); name[0].id=CORBA::string_dup("Hi"); nc->rebind (name,SA_obj.in()); cerr << "rebind successed" << endl; //======================================================================== impl->_remove_ref(); //------------------------------------------------------------------------ // Activate the POA manager //------------------------------------------------------------------------ PortableServer::POAManager_var pmgr = _poa->the_POAManager(); pmgr->activate(); cerr << "poamanager activate successed" << endl; //------------------------------------------------------------------------ // Accept requests from clients //------------------------------------------------------------------------ orb->run(); //------------------------------------------------------------------------ // If orb leaves event handling loop. // - currently configured never to time out (??) //------------------------------------------------------------------------ orb->destroy(); free(name[0].id); // str_dup does a malloc internally catch(CORBA::SystemException&) { cerr << "Caught CORBA::SystemException." << endl; catch(CORBA::Exception&) { cerr << "Caught CORBA::Exception." << endl; catch(omniORB::fatalException& fe) { cerr << "Caught omniORB::fatalException:" << endl; cerr << " file: " << fe.file() << endl; cerr << " line: " << fe.line() << endl; cerr << " mesg: " << fe.errmsg() << endl; catch(...) { cerr << "Caught unknown exception." << endl; return 0;

MakeServer

CC = /usr/bin/g++ CPPFLAGS = -g -c -I/usr/include -I/usr/include/omniORB4 LDFLAGS = -g -L/usr/lib -lomniORB4 -lomnithread -lomniDynamic4 OMNIIDL = /usr/bin/omniidl all: HiServer.bin HiServer.bin: HiSK.o HiServerImpl.o HiServer.o $(CC) $(LDFLAGS) -o HiServer.bin HiSK.o HiServerImpl.o HiServer.o HiSK.o: HiSK.cc Hi.hh $(CC) $(CPPFLAGS) $(INCLUDES) HiSK.cc HiServer.o: HiServer.cc Hi.hh $(CC) $(CPPFLAGS) $(INCLUDES) HiServer.cc HiServerImpl_i.o: HiServerImpl.cc HiServerImpl.hh Hi.hh $(CC) $(CPPFLAGS) $(INCLUDES) HiServerImpl.cc nidl: Hi.idl $(OMNIIDL) -bcxx Hi.idl clean: rm -f *.o rm -f *.bin make -f MakeServer
  • C示例实现(IOR下)
  • 要写一个静态绑定的CORBA程序,首先要完成的就是定义接口。CORBA采用的接口描述方式为IDL(Interface Description Language),IDL的语法规则类似于CPP。

    IDL与CPP常见类型映射关系如下:

    IDL Type C++ Type Word size and range short CORBA::Short 16 bit: -2^15 … +2^15 – 1 CORBA::Long 32 bit: -2^31 … +2^31 – 1 long long CORBA::LongLong 64 bit: -2^63 … +2^63 – 1 unsigned short CORBA::UShort 16 bit: 0 … 2^16 – 1 unsigned long CORBA::ULong 32 bit: 0 … 2^32 – 1 unsigned long long CORBA::ULongLong 64 bit: 0 … 2^64 float CORBA::Float 32 bit IEEE single precision floating point number double CORBA::Double 64 bit IEEE double precision floating point number long double CORBA::LongDouble CORBA::Char 8 bit wchar CORBA::WChar (Wide Char) string CORBA::char * wstring CORBA::WChar * boolean CORBA::Boolean true/false octet CORBA::Octet (unsigned char) 8 bit raw. No conversion. CORBA::Any Arbitrary

    比如,下面就是一个很简单的IDL文件:
    hi.idl

    module HiCorba interface Hi string sayHiTo(in string someone); long add(in long numa, in long numb); oneway void shutdown();
  • C示例实现(IOR下)
  • CORBA(Common Object Request Broker Architecture),即公用对象请求代理程序体系结构,是一种为解决分布式处理环境中硬件和软件系统的互连而提出的一种解决方案。其基本架构如下:

    Object Services,即对象服务,是为使用和实现对象而提供的基本对象集合,这些服务应独立于应用领域。主要的CORBA服务有:名录服务(Naming Service)、事件服务(Event Service)、生命周期服务(Life Cycle Service)、关系服务(Relationship Service)以及事务服务(Transaction Service)等。这些服务几乎包括分布系统和面向对象系统的各个方面,每个组成部分都非常复杂。

    IDL(Interface Description Language),即接口定义语言,是用来描述软件组件接口的一种规范语言。用户可以定义模块、接口、属性、方法、输入输出参数,甚至异常等等。IDL在不同的语言下都有相应的实现,可以把IDL描述的接口编译为目标语言,包括客户端代理和服务器端框架,以及相应的帮助类等等。

    ORB(Object Request Broker),即对象请求代理,是一个中间件,在对象间建立客户-服务器的关系。通过 ORB,一个客户可以很简单地使用服务器对象的方法而不论服务器是在同一机器上还是通过一个网络访问。ORB 截获调用然后负责找到一个对象实现这个请求,传递参数和方法,最后返回结果。客户不用知道对象在哪里,是什么语言实现的,他的操作系统以及其他和对象接口无关的东西。

    CORBA按接口绑定方式,分为两大类,一类为动态绑定,一类为静态绑定。这里主要讲的是静态绑定。
    在静态绑定时,客户端需要实现IDL Stubs,服务端需要实现IDL Skeleton。
    在静态绑定中,CORBA在服务端实现IDL接口有两种方式,一种为继承模式(分为标准模式POA及兼容模式ImplBase),另一种为为委托模式(分为标准模式POA/Tie及兼容模式ImplBase/Tie)。各模式的区别主要在于生成IDL代码时,输入的参数不同,从而生成的接口不同,实现方式也略有区别。这里主要讲的为标准模式。

    一次典型的CORBA调用,流程如下图所示:

    GIOP(General Inter-ORB Protocol),即通用对象请求代理间通信协,提供了一个标准传输语法(低层数据表示方法)和ORB之间通信的信息格式集。GIOP只能用在ORB与ORB之间,而且,只能在符合理想条件的面向连接传输协议中使用。它不需要使用更高一层的RPC机制。这个协议是简单的(尽可能简单,但不是简单化),可升级的,使用方便。它被设计为可移动的、高效能的表现、较少依靠其它的低层传输协议。当然,由于不同传输使用不同版本的GIOP,它们可能不能直接协作工作,但它能很容易的连接网络域。

    IIOP (Internet Inter-ORB Protocol),即Internet对象代理间通信协议,指出如何通过TCP/IP连接交换GIOP信息。IIOP为Internet提供了一个标准的协作工作协议,它使兼容的ORB能基于现在流行的协议和产品进行“out of the box”方式的协作工作。它也能被用于两个半桥(half-bridges )之间的协议。该协议能用于任何ORB与IP(Internet Protocol)域之间的协作工作,除非ORB选择了特殊的协议。这时,它是TCP/IP环境下基本的inter-ORB 协议,最普遍的传输层。

    GIOP 不基于任何特别的网络协议,OMG 在最广泛使用的通信传输平台 — TCP/IP 上标准化 GIOP,GIOP 加 TCP/IP 等于 IIOP。

    由于服务程序授权与用户桌面授权互不影响,所以即使在用户桌面映射了NAS盘符,在Windows服务程序下仍然是不可以访问的。

    一般来说有这样几种做法来访问NAS或共享盘:
    1、加入域,通过“域用户认证”或“通过将NAS资源设置对某台计算机授权”来达到访问NAS的目的
    2、不加域,在Windows中添加与NAS相同的用户名及密码,服务程序通过该用户名密码登录,可以访问NAS
    3、不加域,通过调阅API的方式来获得访问NAS的权限
    A、VC实现如下:

    DWORD AcessNetDrtive(TCHAR* szRemotePath, TCHAR* szLocalDriver, const TCHAR* szUsername, const TCHAR* szPassword) DWORD dwRetVal; DWORD dwFlags; NETRESOURCE nr; memset(&nr, 0, sizeof(NETRESOURCE)); nr.dwScope = RESOURCE_GLOBALNET; nr.dwType = RESOURCETYPE_ANY; nr.lpLocalName = szLocalDriver; nr.lpRemoteName = szRemotePath; nr.lpProvider = NULL; //CONNECT_REDIRECT;CONNECT_UPDATE_PROFILE; dwFlags = 0; dwRetVal = WNetAddConnection2(&nr, szPassword, szUsername, dwFlags); retrun dwRetVal;

    B、C#实现如下:

    public class NetworkDrive public enum ResourceScope RESOURCE_CONNECTED = 1, RESOURCE_GLOBALNET, RESOURCE_REMEMBERED, RESOURCE_RECENT, RESOURCE_CONTEXT public enum ResourceType RESOURCETYPE_ANY, RESOURCETYPE_DISK, RESOURCETYPE_PRINT, RESOURCETYPE_RESERVED public enum ResourceUsage RESOURCEUSAGE_CONNECTABLE = 0x00000001, RESOURCEUSAGE_CONTAINER = 0x00000002, RESOURCEUSAGE_NOLOCALDEVICE = 0x00000004, RESOURCEUSAGE_SIBLING = 0x00000008, RESOURCEUSAGE_ATTACHED = 0x00000010, RESOURCEUSAGE_ALL = (RESOURCEUSAGE_CONNECTABLE | RESOURCEUSAGE_CONTAINER | RESOURCEUSAGE_ATTACHED), public enum ResourceDisplayType RESOURCEDISPLAYTYPE_GENERIC, RESOURCEDISPLAYTYPE_DOMAIN, RESOURCEDISPLAYTYPE_SERVER, RESOURCEDISPLAYTYPE_SHARE, RESOURCEDISPLAYTYPE_FILE, RESOURCEDISPLAYTYPE_GROUP, RESOURCEDISPLAYTYPE_NETWORK, RESOURCEDISPLAYTYPE_ROOT, RESOURCEDISPLAYTYPE_SHAREADMIN, RESOURCEDISPLAYTYPE_DIRECTORY, RESOURCEDISPLAYTYPE_TREE, RESOURCEDISPLAYTYPE_NDSCONTAINER [StructLayout(LayoutKind.Sequential)] private class NETRESOURCE public ResourceScope dwScope = 0; public ResourceType dwType = 0; public ResourceDisplayType dwDisplayType = 0; public ResourceUsage dwUsage = 0; public string lpLocalName = null; public string lpRemoteName = null; public string lpComment = null; public string lpProvider = null; [DllImport("mpr.dll")] private static extern int WNetAddConnection2(NETRESOURCE lpNetResource, string lpPassword, string lpUsername, int dwFlags); public static int MapNetworkDrive(string remotePath, string localDrive, string userName, string passWord) NETRESOURCE myNetResource = new NETRESOURCE(); myNetResource.lpLocalName = localDrive; myNetResource.lpRemoteName = remotePath; myNetResource.lpProvider = null; int result = WNetAddConnection2(myNetResource, passWord, userName, 0); return result; Windows 安装服务无法安装升级修补程序,因为被升级的程序可能会丢失或是升级修补程序可能更新此程序的一个不同版本。请确认要被升级的程序在您的计算机上且您的升 级修补程序是正确的。 串绑定无效。 绑定句柄类型不正确。 绑定句柄无效。 不支持 RPC 协议序列。 RPC 协议序列无效。 字符串通用唯一标识 (UUID) 无效。 终结点格式无效。 网络地址无效。 找不到终结点。 超时值无效。 找不到对象通用唯一标识(UUID)。 对象通用唯一标识 (UUID)已注册。 类型通用唯一标识 (UUID)已注册。 RPC 服务器已在侦听。 未登记任何协议序列。 RPC 服务器未在侦听。 未知的管理器类型。 未知的界面。 没有任何链接。 无任何协议顺序。 无法创建终结点。 资源不足,无法完成此操作。 RPC 服务器不可用。 RPC 服务器过忙以致无法完成此操作。 网络选项无效。 在此线程中, 没有使用中的远程过程调用。 远程过程调用失败。 远程过程调用失败且未运行。 远程过程 调用(RPC)协议出错。 RPC 服务器不支持传送语法。 不支持通用唯一标识(UUID)类型。 标记无效。 数组边界无效。 链接不包含项目名称。 名称语法无效。 不支持名称语法。 没有可用来创建通用唯一标识 (UUID)的网络地址。 终结点是一份备份。 未知的验证类型。 调用的最大个数太小。 字符串太长。 找不到 RPC 协议顺序。 过程号超出范围。 绑定不包含任何验证信息。 未知的验证服务。 未知的验证级别。 安全上下文无效。 未知的授权服务。 项目无效。 服务器终结点无法运行操作。 终结点映射表中无更多的可用终结点。 未导出任何界面。 项目名称不完整。 版本选项无 效。 没有其他成员。 没有内容未导出。 接口没有找到。 项目已存 在。 找不到项目。 无可用的名称服务。 网络地址族无效。 不支持请求的操作。 无可用的安全上下文以允许模拟。 远程过程调用(RPC)中发生内部 错误。 RPC 服务器试图以零除整数。 RPC 服务器中发生地址错误。 RPC 服务器上的浮点操作导至以零做除数。 RPC 服务器上发生浮点下溢。 RPC 服务器上发生浮点上溢。 自动句柄绑定的可用 RPC 服务器列表已用完。 无法打开字符翻译表文件。 包含字符翻译表的文件少于512 字节。 在远程过程调用时,将空的上下文句柄从客户传递到主机。 在远程过程调用时,上下文句柄已更改。 传递到远程过程调用的绑定句柄不相符。 承接体无法获得远程过程调用句柄。 传递空引用指针到承接体。 列举值超出范围。 字节计数太小。 承接体接收到坏数据。 提供给请求操作的用户缓冲区无 效。 磁盘媒体无法识别。可能未被格式化。 工作站没有信任机密。 服务器上的安全数据库 没有此工作站信任关系的计算机帐户。 主域和受信域间的信任关系失败。 此工作站和主域间的信任关系失败。 网络登录失败。 此线程的远程过程调用已在进行中。 试图登录,但是网络登录服务没有启动。 用户帐户到期。 转发程序已被占用且无法卸载。 指定的打印机驱动程序已安装。 指定的端 口未知。 未知的打印机驱动程序。 未知的打印机处理器。 指定的分隔页文件无效。 指定的优先级无效。 打印机名无效。 打印机已存在。 打印机命令无效。 指定的数据类型无效。 指定的环境无效。 没有更多的绑定。 所用帐户为域间信任帐户。请 使用您的全局用户帐户或本地用户帐户来访问这台服务器。 所用帐户是一个计算机帐户。使用您的全局用户帐户或本地用户帐户来访问此服 务器。 已使用的帐户为服务器信任帐户。使用您的全局用户帐户或本地用户帐户来访问此服务器。 指定域的名称或 安全标识(SID)与该域的信任信息不一致。 服务器在使用中且无法卸载。 指定的映像文件不包含资源区域。 找不到映像文件中指定的资源类型。 找不到映像文件中指定的资源名。 找不到映像文件中指定的资源语言标识。 配额不足,无法处理此命令。 未登记任何界面。 远程过程调用被取消。 绑定句柄不包含所 有需要的信息。 在远程过程调用过程中通讯失败。 不支持请求的验证级别。 未登记任何主 名称。 指定的错误不是有效的 Windows RPC 错误码。 已配置一个只在这部计算机上有效的 UUID。 发生一个安全包特有的错误。 线程未取消。 无效的编码/解码句柄操作。 序列化包装的版本不兼容。 RPC 承接体的版本不兼容。 RPC 管道对象无效或已损坏。 试图在 RPC 管道物件上进行无效操作。 不被支持的 RPC 管道版本。 找不到该组成员。 无法创建 终结点映射表数据库项。 对象通用唯一标识 (UUID) 为 nil UUID。 指定的时间无效。 指定的格式名称无效。 指定的格式大小无效。 指定的打印机句柄正等候在 已删除指定的打 印机。 打印机的状态无效。 在第一次登录之前,必须更改用户密码。 找不到此域的域控制 器。 引用的帐户当前已锁定,且可能无法登录。 没有发现指定的此对象导出者 没有发现指 定的对象。 没有发现指定的对象解析器。 一些待发数据仍停留在请求缓冲区内。 无效的异 步远程过程调用句柄。 这个操作的异步 RPC 调用句柄不正确。 RPC 管道对象已经关闭。 在 RPC 调用完成之前全部的管道都已处理完成。 没有其他可用的数据来自 RPC 管道。 这个机器没有可 用的站点名。 系统无法访问此文件。 系统无法辨识文件名。 项目不是所要的类型。 无法将所有对象的 UUID 导出到指定的项。 无法将界面导出到指定的项。 无法添加指定的配置文件项。 无法添加指定的配置文件元素。 无法删除指定的配置文件元素。 无法添加组元素。 无法删 除组元素。 无效的像素格式。 指定的驱动程序无效。 窗口样式或类别属性对此操作无效。 不支持请求的图元操作。 不支持请求的变换操作。 不支持请求的剪切操作。 指定的颜色管 理模块无效。 制定的颜色文件配置无效。 找不到指定的标识。 找不到所需的标识。 指定的标识已经存在。 指定的颜色文件配置与任何设备都不相关。 找不到该指定的颜色文件配置 指定的颜色空间无效。 图像颜色管理没有启动。 在删除该颜色传输时有一个错误。 该指定 的颜色传输无效。 该指定的变换与位图的颜色空间不匹配。 该指定的命名颜色索引在配置文件中不存在。 没有安装工作站驱动程序。 无法定位服务器。 发生内部错误,网络无法访问共享内存段。 网络资源不足。 工作站不支持这项操作。 设备没有连接。 网络连接已成功,但需要提示用 户输入一个不同于原始指定的密码。 没有启动服务器服务。 设备或目录不存在。 无法在重定向的资源上执行这项操作。 名称已经共享。 服务器当前无法提供所需的资源。 额外要求的项目超过允许的上限。 对等服务只支持两个同时操作的用户 。 API 返回缓冲区太小。 远程 API 错误。 打开或读取配置文件时出错。 发生一般网络错误。 工作站服务的状态不一致。重新启动工作站服务之前,请先重新启动计算机。 工作站服务没有启动。 所需信息不可 用。 发生 Windows 2000 内部错误。 服务器没有设置事务处理。 远程服务 器不支持请求的 API。 事件名无效。 网络上已经有此计算机名。请更名后重新启动。 配置信息中找不到指定的组件。 配置信息中找不到指定的参数。 配置文件中有一个命令行太长。 打印机不存在。 打印作业不存在。 打印机目标找不到。 打印机目标已经存在。 打印机队列已经存在。 无法添加其它的打印机。 无法添加其它的打印作业。 无法添加其它 的打印机目标。 此打印机目标处于空闲中,不接受控制操作。 此“打印机目标请求”包含无效的控制函数。 打印处理程序没有响应。 后台处理程序没有运行。 打印目标当前的状况,无法执行这项操作。 打印机队列当前的状况,无法执行这项操作。 打印作业当前的状况,无法执行这项操作。 无法为后台处理程序分配 内存。 设备驱动程序不存在。 打印处理程序不支持这种数据类型。 没有安装打印处理程 序。 锁定服务数据库。 服务表已满。 请求的服务已经启动。 这项 服务没有响应控制操作。 服务仍未启动。 服务名无效。 服务没有响应控制功能。 服务控制处于忙碌状态。 配置文件包含无效的服务程序名。 在当前的状况下无法控制服务。 服务异常终止。 这项服务无法接受请求的 “暂停” 或 “停止” 操作。 服务控制“计划程序”在“计划表” 中找不到服务名。 无法读取服务控制计划程序管道。 无法创建新服务的线程。 此工作站已 经登录到局域网。 工作站没有登录到局域网。 指定的用户名无效。 密码参数无效。 登录处理器没有添加消息别名。 登录处理器没有添加消息别名。 注销处理器没有删除消息别名。 注销处理器没有删除消息别名。 暂停网络登录。 中心登录服务器发生冲突。 服务器没有设 置正确的用户路径。 加载或运行登录脚本时出错。 没有指定登录服务器,计算机的登录状态是单机操作。 登录服务器找不到。 此计算机已经有一个登录域。 登录服务器无法验证登录。 安全数据库 找不到。 组名找不到。 用户名找不到。 资源名找不到。 组已经存 在。 帐户已经存在。 资源使用权限清单已经存在。 此操作只能在该域的主域控制器上执 行。 安全数据库没有启动。 用户帐户数据库中的名称太多。 磁盘 I/O 失败。 已经超过每个资源 64 个项目的限制。 不得删除带会话的用户。 上层目录找不到。 无 法添加到安全数据库会话高速缓存段。 这项操作不能在此特殊的组上执行。 用户帐户数据库会话高速缓存没有记录 此用户。 用户已经属于此组。 用户不属于此组。 此用户帐户尚未定义。 此用户帐户已过期。 此用户不得从此工作站登录网络。 这时候不允许用户登录网络。 此用 户的密码已经过期。 此用户的密码无法更改。 现在无法使用此密码。 密码不满足密码策略 的需要。检查最小密码长度、密码复杂性和密码历史的需求。 此用户的密码最近才启用,现在不能更改。 安全数据 库已损坏。 不需要更新此副本复制的网络/本地安全数据库。 此副本复制的数据库已过时;请同步处理其中的数 据。 此网络连接不存在。 此 asg_type 无效。 此设备当前正在共享中。 计算机名无法作为消息别名添加。网络上可能已经有此名称。 信使服务已经启动。 信使服务启动失败。 网络上找不到此消息别名。 此消息别名已经转发出去。 已经添加了此消息别名,但是仍被转发。 此消息别名已在本地存在。 添加的消息别名已经超过数目上限。 无法删除计算机名。 消息 无法转发回到同一个工作站。 域消息处理器出错。 消息已经发送出去,但是收件者已经暂停信使服务。 消息已经发送出去,但尚未收到。 消息别名当前正在使用中。请稍候片刻再试。 信使服务尚未启动。 该名称不在本地计算机上。 网络上找不到转发的消息别名。 远程通讯站的消息别名表已经满了。 此别名的消息当前没有在转发中。 广播的消息被截断。 设备名无效。 写入出错。 网络上的消息别名重复。 此消息别名会在稍后删除。 没有从所有的网络删除消息别名。 这 项操作无法在使用多种网络的计算机上执行。 此共享的资源不存在。 设备没有共享。 带此 计算机名的会话不存在。 没有用此识别号打开的文件。 执行远程管理命令失败。 打开远程 临时文件失败。 从远程管理命令返回的数据已经被截断成 64K。 此设备无法同时共享为后台处理资源和非后台 处理资源。 服务器清单中的信息可能不正确 计算机在此域未处于活动状态 在删除共享之 前,需要将该共享从分布式文件系统中删除。 无法在此设备执行这项操作 此设备无法共享。 此设备未打开。 此设备名清单无效。 队列优先级无效。 没有任何共享的通讯设备。 指定的队列不存在。 此设备清单无效。 请求的设备无效。 后台处理程序正在使用此设备。 此设备已经被当成通讯设备来使用。 此 计算机名无效。 指定的字符串及前缀太长。 此路径组成部分无效。 无法判断输入类型。 类型缓冲区不够大。 配置文件不得超过 64K。 初始偏移量越界。 系统无法删除当前到 网络资源的连接。 系统无法分析此文件中的命令行。 加载配置文件时出错。\ 保存配置文 件时出错,只部份地保存了配置文件。 此日志文件在前后两次读取之间已经发生变化。 资源路径不可以是目录。 资源路径无效。 目标路径无效。 源路径及目标路径分属不同的服务器。 请求的 Run 服务器现在暂停。 与 Run 服务器通讯时出错。 启动后台处理时出错。 找不到您连接 的共享资源。 LAN 适配器号码无效。 此网络连接有文件打开或请求挂起。 使用中的连 接仍存在。 此共享名或密码无效。 设备正由活动进程使用,无法断开。 此驱动器号已在本 地使用。 指定的客户已经在指定的事件注册。 警报表已满。 发出的警报名称无效或不存 在。 警报接收者无效。 用户的登录时间长短不再合法。所以已经删除用户与该服务器的会话。 日志文件中没有请求的记录号。 用户帐户数据库没有正确配置。 当 Netlogon 服务正在运行时,不允许执行这项操作。 这项操作无法在最后的管理帐户上执行。 找不到此域的域控制器。 无法设置此用户的登录信息。 Netlogon 服务尚未启动。 无法添加到用户帐户数据库。 此服务器的时钟与主域控制器的时钟不一致。 检测到密码不匹配。 服务器识别码没有指定有效的服务器。 会话标识没有指定有效的会话。 连接识别码没有指定有效的连接。 可用服务器表中无法再加上其它项。 服务器已经到了支持的会话数目上限。 服务器已经到了支持的连接数目上限。 服务器打开的文件到了上限,无法打 开更多文件。 这台服务器没有登记替换的服务器。 请用低级的 API (远程管理协议)。 UPS 服务无法访问 UPS 驱动程序。 UPS 服务设置错误。 UPS 服务无法访问指定通讯端口 (Comm Port)。 UPS 显示线路中断或电池不足,服务没有启动。 UPS 服务无法执行系统关机的操作。 下面的程序返回一个 MS-DOS 错误码: 下面的程序需要更多的内存: 下面程序调用了不支持的 MS-DOS 函数: 工作站无法启动。 下面的文件已损坏。 启动块定义文件中没有指定 引导程序。 NetBIOS 返回错误: NCB 及 SMB 数据转储。 磁盘 I/O 错误。 无 法替换映像参数。 跨越磁盘扇区范围的映像参数太多。 不是从用 /S 格式化的 MS-DOS软盘产生的映像。 稍后会从远程重新启动。 无法调用远程启动服务器。 无法 连接到远程启动服务器。 无法打开远程启动服务器上的映像文件。 正在连接到远程启动服务器… 正在连接到远程启动服务器… 远程启动服务已经停止,请检测错误记录文件,查明出错的原因。 远程启动失败,请 检查错误日志文件,查明出错的原因。 不允许第二个远程启动 (Remoteboot) 资源连接。 浏览服务 设置成 MaintainServerList=No。 因为没有网卡与这项服务一起启动,所以无法启动服务。 因为注册表中的启动信息不正确,所以无法启动服务。 无法启动服务,原因是它的数据库找不到或损坏。 因为找不 到 RPLFILES 共享的资源,所以无法启动服务。 因为找不到 RPLUSER 组,所以无法启动服务。 无法枚举服务记录。 工作站记录信息已损坏。 工作站记录找不到。 其它的工作站正在使用 此工作站名。 配置文件记录已损坏。 配置文件记录找不到。 其它的配置文件正在使用此名 称。 有很多工作站正在使用此配置文件。 配置记录已损坏。 配置记录找不到。 适配器识别记录已损坏。 内部服务出错。 供应商识别记录已损坏。 启动块记录已损坏。 找不到此工作站的用户帐户记录。 RPLUSER 本地组找不到。 找不到启动块记录。 所选的配置文件与此工作站不兼容。 其它的工作站正在使用所选的网卡。 有些配置文件正在使用此配置。 有数个工作站、配置文件或配置正在使用此启动块。 服务无法制作远程启动数据库的备份。 找不到适配器记录。 找不到供应商记录。 其它供应商记录正在使用此供应商名称。 其它的启动区记录正在使用启动名称或供应商识别记 录。 其它的配置正在使用此配置名称。 由 Dfs 服务所维护的内部数据库已损坏 内部 数据库中的一条记录已 损坏 输入项路径与卷路径不匹配 给定卷名已存在 指定的服务器共 享已在 Dfs 中共享 所显示的服务器共享不支持所显示的 Dfs 卷 此操作在非叶卷上无效。 此操作在叶卷上无效。 此操作不明确,因为该卷存在多服务器。 无法创建连接点 该服务器 不是 Dfs 可识别的 指定的重命名目标路径无效。 指定 Dfs 卷脱线 指定的服务 器不为此卷服务 检测到 Dfs 名中的环路 在基于服务器的 Dfs 上不支持该操作 这个卷已经受该指定服务器共享支持 无法删除这个卷的上一个服务器共享支持 Inter-Dfs 卷不支持该操作 Dfs 服务的内部状态已经变得不一致 Dfs 服务已经安装在指定的服务器上 被协调的 Dfs 数据是一样的 无法删除 Dfs 根目录卷 – 如需要请卸载 Dfs 该共享的子目录或父目录已经存在在一个 Dfs 中 Dfs 内部错误 这台机器已经加入域 。 这个机器目前未加入域。 这台机器是域控制器,而且 无法从域中退出。 目标域控制器不支持在 OU 中创建的机器帐户。 指定的工作组名无效 指定的计算机名与域控制器上使用的默认语言不兼容。 找不到指定的计算机帐户。 这是 NERR 范围内的最后一个错误。 指定了未知的打?嗍悠鳌? 指定的打印机驱动程序当前正在使用。 找不到缓冲文件。 未发送 StartDocPrinter 调用。 未发送 AddJob 调用。 指定的打印处理器已经安装。 指定的打?嗍悠饕丫沧啊? 该指定的打?嗍悠鞑痪弑杆蟮墓δ堋!? 该指定的打?嗍悠髡谑褂弥小? 当打印机有作业排成队列时此操作请求是不允许的。 请求的操作成功。直到重新 启动系统前更改将不会生效。 请求的操作成功。直到重新启动服务前更改将不会生效。 找不到打印机。 用户指定的关机命令文件,它的配置有问题。不过 UPS 服务已经启动。 因为用户帐户数据库 (NET.ACC) 找不到或损坏,而且也没有可用的备份数据库,所以不能启动本地安全机制。系统不安全! @I *登录小时数 已 经超过一个目录中文件的副本复制的限制。 已经超过副本复制的目录树深度限制。 无法登录。用户当前已经登录, 同时参数 TRYUSER设置为 NO。 命令行或配置文件中没有提供必要的参数。 无法满足资源的请求。 系统配置有问题。 系统出错。 发生内部一致性的错误。 配置文件或命令行的选项不明确。 配置文件或命令行的参数重复。 服务没有响应控制,DosKillProc 函数已经停止服务。 运行服务程序 时出错。 无法启动次级服务。 文件有问题。 安全性失败。 LAN Manager 根目录不正确或找不到。 未安装网络软件。 服务器未启动。 服务器无法访问用户帐户数据库 (NET.ACC)。 LANMAN 树中安装的文件不兼容。 LANMAN\LOGS 目录无效。 指定的域无法使用。 另 一计算机正将此计算机名当作消息别名使用。 宣布服务器名失败。 用户帐户数据库没有正确配置。 服务器没有运行用户级安全功能。 工作站设置不正确。 查看您的错误日志文件以了解详细信息。 无法写入此文件。 ADDPAK 文件损坏。请删除 LANMAN\NETPROG\ADDPAK.SER后重新应用所有的 ADDPAK。 因为没有运行 CACHE.EXE,所以无法启动 LM386 服务器。 安全数据库中找不到这台计算机的帐户。 这台计算机 不是 SERVERS 组的成员。 SERVERS 组没有在本地安全数据库中。 此 Windows NT 计算机被设置为某个组的成员,并不是域的成员。此种配置下不需要运行 Netlogon 服务。 找不到此域的 Windows NT 域控制器。 服务无法与主域控制器进行验证。 安全数据库文件创建日期或序号有问题。 因为网络软件出错,所以无法执行操作。 这项服务无法长期锁定网络控制块 (NCB) 的段。错误码就是相关数据。 这项服务无法解除网络控制块 (NCB) 段的长期锁定。错误码就是相关数据。 收到意外的网络控制块 (NCB)。NCB 就是相关数据。 网络没有启动。 NETWKSTA.SYS 的 DosDevIoctl 或 DosFsCtl 调用失败。显示的数据为以下格式:DWORD 值代表调用 Ioctl 或 FsCtl 的 CS:IP WORD 错误代码WORD Ioctl 或 FsCtl 号 发生意外的 NetBIOS 错误。错误码就是相关数据。 收到的服务器消 息块 (SMB) 无效。SMB 就是相关数据。 因为缓冲区溢出,所以错误日志文件中部份的项目丢失。 控制 网络缓冲区以外资源用量的初始化参数被设置大小,因此需要的内存太多。 服务器无法增加内存段的大小。 服务器 启动失败。三个 chdev参数必须同时为零或者同时不为零。 服务器无法更新 AT 计划文件。文件损坏。 服务器调用 NetMakeLMFileName 时出错。错误码就是相关数据。 无法长期锁定服务器缓冲区。请检查交换磁盘的可用 空间,然后重新启动系统以启动服务器。 因为多次连续出现网络控制块 (NCB) 错误,所以停止服务。最后一个坏的 NCB 以原始数据形式出现。 因为消息服务器共享的数据段被锁住,所以消息服务器已经停止运行。 因为 VIO 调用出错,所以无法弹出显示消息。错误码就是相关数据。 收到的服务器消息块 (SMB) 无效。SMB 就是相关数据。 工作站信息段大于 64K。大小如下(以 DWORD 值的格式): 工作站无法取得计算机的名称号码。 工作 站无法初始化 Async NetBIOS 线程。错误码就是相关数据。 工作站无法打开最前面的共享段。错误码就是相关数据。 工作站主机表已满。 收到的邮筒服务器消息块 (SMB) 有问题,SMB 就是相关数据。 工作站启动用户帐 户数据库时出错。错误码就是相关数据。 工作站响应 SSI 重新验证请求时出错。函数码及错误码就是相关数据。 服务器无法读取 AT 计划文件。 服务器发现错误的 AT 计划记录。 服务器找不到 AT 计划文件,所以创建一个计划文件。 因为用户帐户数据库 (NET.ACC) 找不到或损坏,而且也没有可用的备份数据库,所以不能启动本地安全机制。系统不安全! 服务器无法创建线程。CONFIG.SYS 中的 THREADS 参数必须加大。 已经超过一个目录中文件的 副本复制的限制。 已经超过副本复制的目录树深度限制。 邮筒中收到的消息无法识别。 无 法登录。用户当前已经登录,同时参数 TRYUSER设置为 NO。 检测到服务器的电源中断。 UPS 服务已经关掉服务器。 UPS 服务没有完成执行用户指定的关机命令文件。 无法打开 UPS 驱动程序。错误码就是相关数据。 电源已经恢复。 用户指定的关机命令文件有问题。 该项 服务的动态链接库发生无法修复的错误。 系统返回意外的错误码。错误码就是相关数据。 容错错误日志文件 – LANROOT\LOGS\FT.LOG超过 64K。 容错错误日志文件 – LANROOT\LOGS\FT.LOG,在被打开时就已设置更新进度位,这表示上次使用错误日志时,系统死机。 Remote IPC Remote Admin Logon server share 网络出错。 内存不足,无法启动工作站服务。 读取 LAMAN.INI 文件的 NETWORKS 项目出错。 LAMAN.INI 文件中的 NETWORKS 项目太多。 程序无法用在此操作系统。 已经安装转发程序。 安装 NETWKSTA.SYS 时出错。请按 ENTER 继续。 求解程序链接问题。 您已经打开文件或设 备,强制断开会造成数据丢失。 内部用的默认共享 命令成功完成。 使用的选项无效。 命令包含无效的参数个数。 命令运行完毕,但发生一个或多个错误。 使 用的选项数值不正确。 命令使用了冲突的选项。 软件需要新版的操作系统。 数据多于 Windows 2000 所能够返回的。 此命令只能用在 Windows 2000 域控制器。 这个指令 不能用于一个 Windows 2000 域控制器。 已经启动以下 Windows 2000 服务: 停止 工作站服务也会同时停止服务器服务 。 工作站有打开的文件。 服务正在启动或停止中,请稍候片刻后再试一次。 服务没有报告任何错误。 正在控制设备时出错。 这些工作站在这台服务器上有会话: 这些 工作站有会话打开了此台服务器上的文件: 消息别名已经转发出去。 您有以下的远程连接: 继续运行会取消连接。 会记录新的网络连接。 不记录新的网络连接。 保存配置文件时出 错,原先记录的网络连接状态没有更改。 读取配置文件时出错。 没有启动任何网络服务。 清单是空的。 工作站服务已经在运行中,Windows 2000 会忽略工作站的命令选项。 在打印作业正在 后台处理到队列时,无法删除共享的队列。 打开帮助文件时出错。 帮助文件是空的。 帮助 文件已经损坏。 这是专为那些安装旧版软件的系统提供的操作。 设备类型未知。 日志文件 已经损坏。 程序文件名后必须以 .EXE 结束。 找不到匹配的共享,因此没有删除。 用户记录中的 “单位/星期” 的值不正确。 删除共享时出错。 用户名无效。 密码无 效。 密码不匹配。 永久连接没有完全还原。 计算机名或域名错误。 无法设置该资源的默认权限。 没有输入正确的密码。 没有输入正确的名称。 该资源无法共 享。 权限字符串包含无效的权限。 您只能在打印机或通讯设备上执行这项操作。 服务器没 有设置远程管理的功能。 这台服务器上没有用户的会话。 响应无效。 没有提供有效的响 应。 提供的目标清单与打印机队列目标清单不匹配。 指定的时间范围中结束的时间比开始的时间早。 提供的时间不是整点。 12 与 24 小时格式不能混用。 提供的日期格式无效。 提供 的日期范围无效。 提供的时间范围无效。 NET USER 的参数无效。请检查最短的密码长度和/或提供参数。 ENABLESCRIPT 的值必须是 YES。 提供的 国家(地区)代码无效。 用户已经创建成功,但是无法添加到USERS 本地组中。 提供的用户上下文无效。 文件发送功能已不再支持。 您可能没有指定 ADMIN$ 及 IPC$ 共享的路径。 只有磁盘共享可以标记 为可以缓存。 此计划日期无效。 LANMAN 根目录无法使用。 SCHED.LOG 文件无法打开。 服务器服务尚未启动。 AT 作业标识不存在。 AT 计划文件已损坏。 因为 AT 计划文件发生问题,所以无法运行删除操作。 命令行不得超过 259 个字符。 因为磁盘已满,所 以 AT 计划文件无法更新。 AT 计划文件无效。请删除此文件并创建新的文件。 AT 计划文件已经删除。 此命令的语法是:AT [id] [/DELETE]AT 时间 [/EVERY:日期 | /NEXT:日期] 命令AT 命令会在以后的指定日期及时间,安排程序在服务器上运行。它也会显示安排运行的程序及命令的清单。您可以将日期指定为M、T、W、Th、F、Sa、Su 或 1-31 的格式。您可以将时间指定为HH:MM的二十四小时格式。 AT 命令已经超时。请稍后再试一次。 用户帐户的密码使用最短期限不得大于密码最长使用期限。 指定的数值与安装下层软件的服务器不兼容。请指定较小的值。 **** 意外到达消息的结尾 **** 请按 ESC 退出 找不到时间服务器。 无法判断用户的主目录。 没有指定用户的主目录。 已经没有可用的驱动器号。 这台计算机 目前没有配置成使用一个指定的 SNTP 服务器。 语法错误。 指定的文件号码无效。 指定的打印作业号码无效。 指定的用户或组帐户找不到。 已添加用户,但 NetWare 的文件和打印服务无法启用。 没有安装 NetWare 的文件和打印服务。 无法为 NetWare 的文件和打印服务设置用户属性。 NetWare 兼容登录 WINS 在处理命令时遇到错误。 本地的 WINS 不能删除。 文件导入操作失败。 备份操作失败。是否先前已作过完整备份? 备份操作失败。请检查您备份数据库的目录。 WINS 数据库中没有这个名称。 不允许复制一个尚未配置的伙 伴。 DHCP 客户获得一个在网上已被使用的 IP 地址。 直到 DHCP 客户可以获得新的地址前,本地接口将被禁用。 无法识别传来的 GUID 是否为有效的 WMI 数据提供程序。 无法识别传来的实例名是否为有效的 WMI 数据提供程序。 无法识别传来的数据项目标识符是否为有效的 WMI 数据提供程序。 无法完成 WMI 请求,应该重试一次。 找不到 WMI 数据提供程序。 WMI 数据提供程序引用到一个未注册的实例组。 WMI 数据块或事件通知已启用。 WMI 数据块不再可用。 WMI 数据服务无法使用。 WMI 数据提供程序无法完成要求。 WMI MOF 信息无效。 WMI 注册信息无效。 WMI 数据块或事件通知已禁用。 WMI 数据项目或数据块为只读。 WMI 数据项目或数据块不能更改。 媒体标识符没有表示一个有效的媒体。 库标识符没有表示一个有效的库。 媒体缓冲池标识符没有表示一个有效的媒 体缓冲池。 驱动器和媒体不兼容或位于不同的库中。 媒体目前在脱机库中,您必须联机才能运行这个操作。 操作无法在脱机库中运行。 库、驱动器或媒体缓冲池是空的。 库、磁盘或媒体缓冲池必须是空的,才能运行这个操 作。 在这个媒体缓冲池或库中目前没有可用的媒体。 这个操作所需的资源已禁用。 媒体标 识符没有表示一个有效的清洗器。 无法清洗驱动器或不支持清洗。 对象标识符没有表示一个有效的对象。 无法读取或写入数据库。 数据库已满。 媒体与设备或媒体缓冲池不兼容。 这个操作所需的 资源不存在。 操作标识符不正确。 媒体未被安装,或未就绪。 设备未就绪。 操作员或系统管理员拒绝了请求。 驱动器标识符不代表一个有效的驱动器。 程序库已满。没有可使用的插槽。 传输程序不能访问媒体。 无法将媒体加载到驱动器中。 无法检索有关驱动器的状态。 无法 检索有关插槽的状态。 无法检索传输的状态。 因为传输已在使用中,所以无法使用。 无法 打开或关闭弹入/弹出端口。 因为媒体在驱动器中,无法将其弹出。 清洗器插槽已被保留。 没有保留清洗器插槽。 清洗器墨盒已进行了最大次数的驱动器清洗。 意外媒体标识号。 在 这个组或源中最后剩下的项目不能被删除。 提供的消息超过了这个参数所允许的最大尺寸。 该卷含有系统和页面文 件。 由于库中至少有一个驱动器可以支持该媒体类型,不能从库中删除媒体类型。 由于没有可以使用的已被启动的 驱动器,无法将该脱机媒体装入这个系统。 (Y/N) [Y] (Y/N) [N] (找不到) 远程存储服务无法撤回文件。 远程存储服务此时不可操作。 远程存储服务遇到一个媒体错误。 请键入密码: 请键入用户 的密码: 请键入共享资源的密码: 请键入您的密码: 请再键入一次密码以便确认: 请键入用户的旧密码: 请键入用户的新密码: 请键入您的新密码: 请键入复制器服务密 码: 请键入您的用户名: 打印作业详细信息 控制下列正在运行的服务: 统计数据可用于正在运行的下列服务: 此命令的语法是: 此命令的选项是: 请键入主域控 制器的名称: Sunday Monday Tuesday Wednesday Thursday 此文件或目录不是一个重解析点。 重解析点的属性不能被设置,因为它与已有的属性冲突。 在重解析点缓冲区中的 数据无效。 在重解析点缓冲区中的标签无效。 请求中指定的标签 用户的注释 国家 (地区)代码 操作员权限 上次设置密码 密码可更改 允许的工作站 磁盘空间上限 本地组会员 全局组成员 可允许的登录小时数 用户可以更改密码 用户配置文件 工作站活动在 Windows NT 根目录 工 作站域 COM 打开超时 (秒) COM 发送计数 (字节) COM 发送超时 (毫秒) DOS 会话打印超时 (秒) 错误日 志文件大小上限 (K) 高速缓存上限 (K) 网络缓冲区数 字符缓冲区数 域缓冲区大小 字符缓冲区大小 计算机全名 工作站域 DNS 名称 Windows 2000 服务器名称 服务器注释 发送管理警报到 对等服务器 Windows NT 服务器等级 Windows NT Server 服务器正运行于 服务器已隐藏 零备份存储在这个卷上不可用。 登录的用户数量上限 同时可并存的管理员数量上限 资源共享数量上限 资源连接数量上限 服务器打开的文件数量 上限 每个会话打开的文件数量上限 文件锁定数量上限 空闲的会话时间 (分) 未限制的服务器 强制用户在时间到期之后多久必须注销?: 多少次密码不正确后锁住帐户?: 密码最短使用期限 (天): 密码最长使用期限 (天): 密码长度下限: 保持的密码历史记录长度: 计算机角色: 工作站域的主域控制器: 锁定阈值: 锁定持续时间(分): 锁定观测窗口(分): 统计开始于 接受的会话 发送的 KB 接收的 KB 平均响应时间 (毫秒) 访问的文件 后台处理的打印作业 访问的通讯设备 会话已启动 重新连接的会话 会话启动失败 断开的会话 网络 I/O 执行 文 件及管道被访问 时间缓冲区耗尽 请求缓冲区 接收的字节数 接收的服务器消息块 (SMB) 传输的字节数 传输的服务器消息块 (SMB) 拒绝原始读取 拒绝原始写入 服务器断开 会话已启动 失败的会话 使用计数失败 消息名称转发已经取消。 密码已经更改成功。 消息已经发给网络上所有的用 户。 消息已经送到此服务器上的所有用户。 Windows NT Server Windows NT Workstation MS-DOS 增强型工作站 服务器名称 注释 资源共 享名 类型 用途 注释 (UNC) Domain 其它可用的 网络: Print 状态 本地 远程 网络 正在重新连接 共享名 资源 注释 识别码 路径 用户名 # 锁定 文件识别 码 计算机 用户名 客户类型 打开空闲时间 资源共享名 类型 # 打开 来宾登 录 脱机缓存被启用:手动恢复 脱机缓存被启用:自动恢复 脱机缓存被启用:用户之间没有 共享 脱机缓存被停用 已经从下列位置转发给您 这台服务器的用户 用户已经按 Ctrl+Break 中断网络发送。 名称 作业编号 大小 状态 打印处理程序 打印机活动中 打印机搁置 打印机出错 正在删除打印机 打印机状态未知 正在提交用户 作业数据类型 搁置于队列 正在后台处理 用户名 类型 日期 服务器已启动 服务器已暂停 服务器已继续操作 服务器已停止 登录管理员 注销自动断开 注销管理员断开 注销受登录限制 已修改帐户系统设置 超过限制: 未知 超过限制: 登录时间 超过限制: 帐户过期 超过限制: 工作站识别码无效 超过限制: 帐户停用 超过限制: 帐户已删除 密码不正确 需要管理员特权 持续时间: 持续时间: 无效 持续时间: 1 秒以下 登录到网络 程序 消息 时间 管理员已解除帐户的锁定状态 因为其它资源需要它,不能将群 集资源移到另一个组。 找不到此群集资源的依存。 因为已经处于依存状态,此群集资源不能依存于指定的资源。 此群集资源未联机。 此操作没有可用的群集节点。 没有群集资源。 找不到群集资源。 正在关闭群集。 因为联机,群集节点无法从群集中脱离。 对象已存在。 此对象已在列表 中。 新请求没有可用的群集组。 找不到群集组。 因为群集组未联机,此操作不能完成。 群集节点不是此资源的所有者。 群集节点不是此资源的所有者。 群集资源不能在指定的资源监视器中创建。 群集资源不能通过资源监视器来联机。 因为群集资源联机,此操作不能完成。 由于是仲裁资源,群集资源不能被删 除或脱机。 由于没有能力成为仲裁资源,此群集不能使指定资源成为仲裁资源。 群集软件正关闭。 组或资源的状态不是执行请求操作的正确状态。 属性已被存储,但在下次资源联机前,不是所有的修改将生效。 由 于不属于共享存储类别,群集不能使指定资源成为仲裁资源。 由于是内核资源,无法删除群集资源。 仲裁资源联机 失败。 无法成功创建或装入仲裁日志。 群集日志损坏。 由于该日志已超出最大限量,无法 将记录写入群集日志。 群集日志已超出最大限量。 群集日志没有发现检查点记录。 不满足 日志所需的最小磁盘空间。 群集节点未能控制仲裁资源,因为它被另一个活动节点拥有。 这个操作的群集网络无 效。 此操作没有可用的群集节点。 所有群集节点都必须运行才能执行这个操作。 群集资源 失败。 该群集节点无效。 该群集节点已经存在。 一个节点正在加入该群集。 找不到群集节点。 找不到群集本地节点信息。 群集网络已经存在。 找不到群集网络。 群集网络界面已经存在。 找不到群集网络界面。 群集请求在这个对象中无效。 群集网络提 供程序无效。 群集节点坏了。 无法连接到群集节点。 该群集节点不是群集的一个成员。 群集加入操作正在进行中。 该群集网络无效。 该群集节点可以使用。 该群集 IP 地址已在使用中。 该群集节点没有中止。 没有有效的群集安全上下文。 该 群集网络不是为内部群集通讯配置的。 群集节点已经开始。 群集节点已经坏了。 群集网络 已经联机。 群集网络已经脱机。 群集节点已经是该群集的成员。 该群集网络是唯一个为两 个或更多活动群集节点进行内部群集通讯的配置。不能从网络上删除内部通讯能力。 一个或更多的群集资源依靠网络来向客户提供服务。不 能从网络上删除客户访问能力。 该操作不能在群集资源上作为仲裁资源执行。您不能将仲裁资源脱机或修改它的所有者名单。 该群集仲裁资源不允许有任何依存关系。 该群集节点暂停。 群集资源不能联机。所有者节点不能在这个资源上运 行。 群集节点没有准备好,不能执行所请求的操作。 群集节点正在关闭。 放弃群集节点加 入操作。 由于加入节点和支持者之间的软件版本不兼容,该群集加入操作失败。 由于该群集已经到达其所能监督的 资源限制,不能创建这个资源。 系统配置在群集加入或形成操作时已更改。放弃加入或形成操作。 找不到指定的资 源种类。 指定的节点不支持这种资源,这也许是由于版本不一致或是由于在这个节点上没有资源 DLL。 该资源 DLL 不支持指定的资源名称。这可能是由于一个提供给源 DLL 名称是错误的(或经过更改的)。 不能在 RPC 服务器上注册任何身份验证包。 由于组的所有者不在组的首选列表中,不能将组联机。要改变组的所有者节点,请移动组。 群集数据库的系列号已改变,或者与锁定程序节点不相容,因此加入操作没有成功。如果在加入操作期间群集数据库有任何改动,这都可能发生。 资源在其当前状态下,资源监视器不允许执行失败操作。资源处于挂起状态时,这都可能发生。 非锁定程序代码收到一个为全局更新保留锁 定的请求。 群集服务找不到仲裁磁盘。 已备份的群集数据库可能已损坏。 DFS 根目录已在这个群集节点中。 由于与另一个现有属性冲突,未能修改资源属性。 UPS 服务即将执行最后的关机操作。 工作站必须用 NET START 才能启动。 远程 IPC NETUS.HLP NET.HLP 网络控制块 (NCB) 请求运行成功。NCB 是相关数据。 SEND DATAGRAM、SEND BROADCAST、ADAPTER STATUS 或 SESSION STATUS 的网络控制块 (NCB) 缓冲区长度无效。NCB 是相关数据。 网络控制块 (NCB) 指定的数据描述数组无效。NCB 是相关数据。 网络控制块 (NCB) 指定的命令无效。NCB 是相关数据。 网络控制块 (NCB) 指定的消息交换码无效。NCB 是相关数据。 网络控制块 (NCB) 命令超时。会话可能异常终止。NCB 是相关数据。 接收的网络控制块 (NCB) 消息不完整。NCB 是相关数据。 网络控制块 (NCB) 指定的缓冲区无效。NCB 是相关数据。 网络控制块 (NCB) 指定的会话号码没有作用。NCB 是相关数据。 网卡没有任何资源可用。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 网络控制块 (NCB) 指定的会话已经关闭。NCB 是相关数据。 网络控制块 (NCB) 命令已经取消。NCB 是相关数据。 网络控制块 (NCB) 指定的消息块不合逻辑。NCB 是相关数据。 该名称已经存在于本地适配器名称表中。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 网卡名称表已满。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 网络名称已经有活动的会话,现在取消注册。网络控制块 (NCB) 命令运行完毕。NCB 是相关数据。 先前发出的 Receive Lookahead 命令对此会话仍起作用。网络控制块 (NCB) 命令被拒绝。NCB 是相关数据。 本地会话 表已满。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 拒绝打开网络控制块 (NCB) 会话,远程计算机上没有侦听命令在执行。NCB 是相关数据。 网络控制块 (NCB) 指定的名称号码无效。NCB 是相关数据。 网络控制块 (NCB) 中指定的调用名称找不到,或者没有应答。NCB 是相关数据。 网络控制块 (NCB) 中指定的名称找不到。无法将“*”或00h 填入 NCB 名称。NCB 是相关数据。 网络控制块 (NCB) 中指定的名称正用于远程适配器。NCB 是相关数据。 网络控制块 (NCB) 中指定的名称已经删除。NCB 是相关数据。 网络控制块 (NCB) 中指定的会话异常终止。NCB 是相关数据。 网络协议在网络上检测两个或数个相同的名称。 网络控制块 (NCB) 是相关数据。 收到意外的协议数据包。远程设备可能不兼容。网络控制块 (NCB) 是相关数据。 NetBIOS 界面正忙。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 未完成的网络控制块 (NCB) 命令太多。NCB 请求被拒绝。NCB 是相关数据。 网络控制块 (NCB) 中指定的适配器号无效。NCB 是相关数据。 网 络控制块 (NCB) 命令在取消的同时运行完毕。NCB 是相关数据。 网络控制块 (NCB) 指定的名称已经保留。NCB 是相关数据。 网络控制块 (NCB) 命令无法取消。NCB 是相关数据。 同一个会话有多个网络控制块 (NCB)。NCB 请求被拒绝。NCB 是相关数据。 网卡出错。唯一可能发出的 NetBIOS 命令是 NCB RESET。网络控制块 (NCB) 是相关数据。 超过应用程序数目上限。网络控制区 (NCB) 请求被拒绝,NCB 是相关数据。 请求的资源无法使用。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 系统出错。网 络控制块 (NCB) 请求被拒绝。NCB 即为数据。 “ROM 校验和”失败。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 RAM 测试失败。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 数字式环回失 败。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 模拟式环回失败。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 界面失败。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 收到的网络控制块 (NCB) 返回码无法识别。NCB 是相关数据。 网卡故障。网络控制块 (NCB) 请求被拒绝。NCB 是相关数据。 网络控制块 (NCB) 命令仍然处于搁置状态。NCB 是相关数据。 Windows 2000 无法按指定的配置启动,将换用先前可工作的配置。 无法共享用户或脚本路径。 计算机的密码在本地安全数据库中 找不到。 访问计算机的本地或网络安全数据库时,发生内部错误。 Netlogon 服务用于记录数据库更改数据的日志高速缓存已损坏。Netlogon 服务正在复位更改日志文件。 无法加载任何传输。 此域的全局组数目超过可以复制到 LanMan BDC 的限制。请删除部分的全局组或删除域中的 LanManBDC。 服务无法 检索必要的消息,所以无法运行远程启动客户。 服务发生严重的错误,无法从远程启动3Com 3Start 远程启动客户。 服务发生严重的系统错误,即将关机。 服务在分析 RPL 配置时出错。 服务在创建所有配置的 RPL 配置文件时出错。 服务在访问注册表时出错。 服务在替换可能过期的 RPLDISK.SYS 时出错。 服务在添加安全帐户或设置文件权限时出错。这些帐户是独立 RPL 工作站的 RPLUSER 本地组以及用户帐户。. 服务无法备 份它的数据库。 服务无法从它的数据库初始化。数据库可能找不到或损坏。服务会试图从备份数据库恢复该数据库。 服务无法从备份数据库还原它的数据库。服务将不启动。 服务无法从备份数据库还原它的数据库。 服务无法从它还 原的数据库初始化。服务将不启动。 远程启动数据库采用 NT 3.5 / NT 3.51 格式。NT 正在转换其为 NT 4.0 格式。完成转换后,JETCONV 转换器将写出应用事件日志。 该 DC 的 DNS 服务器不支持动态 DNS。将文件 $SystemRootSystem32Config etlogon.dns$中的 DNS 记录添加到伺服那个文件中引用的域的 DNS 服务器。 由于没有可以使用的 DNS 服务器,一个或更多 DNS 记录的动态注册和注销未成功。 无法加密指定的文件。 指定的文件无法解密。 指定的文件已加密,而且用户没有能力解密。 这个系统没有有效的加密恢复策略配置。 所需的加密驱动程序并未加载到系统中。 文件加密所使用的加密驱动程序与目前加载的加密驱动程序不同。 没有为 用户定义的 EFS 关键字。 指定的文件并未加密。 指定的文件不是定义的 EFS 导出格式。 指定的文件是只读文件。 已为加密而停用目录。 不信任服务器来进行远程加密操作。 此工 作组的服务器列表当前无法使用 要正常运行,任务计划程序服务的配置必须在系统帐户中运行。单独的任务可以被配置成在其他帐户中运 行。 指定的会话名称无效。 指定的协议驱动程序无效。 在系统路径上找不到指定的协议驱 动程序。 在系统路径上找不到指定的终端连接。 不能为这个会话创建一个事件日志的注册键。 同名的一个服务已经在系统中存在。 在会话上一个关闭操作挂起。 没有可用的输出缓冲器。 找不到 MODEM.INF 文件。 在 MODEM.INF 中没有找到调制解调器名称。 调制解调器没有接 受发送给它的指令。验证配置的调制解调器与连接的调制解调器是否匹配。 调制解调器没有接受发送给它的指令。验证该调制解调器是否接 线正确并且打开了电源开关。 运载工具检测失败或者由于断开连接,运载工具已被丢弃。 在要求的时间内没有发现 拨号音。 确定电话线连接正确并可使用。 在远程站点回叫时检测到了占线信号。 在回叫时远程站点上检测到了声 音。 传输驱动程序错误 找不到指定的会话。 指定的会话名称已处于使用中。 由于终端连接目前正在忙于处理一个连接、断开连接、复位或删除操作,无法完成该请求的操作。 试图连接到其视频模式不受当前客户支持 的会话。 应用程序尝试启动 DOS 图形模式。不支持 DOS 图形模式。 您的交互式登录权限已被禁用。请 与您的管理员联系。 该请求的操作只能在系统控制台上执行。这通常是一个驱动程序或系统 DLL 要求直接控制台访问的结果。 客户未能对服务器连接消息作出响应。 不支持断开控制台会话。 不支持重新将一个断开的会话连接到控制台。 远程控制另一个会话的请求被拒绝。 拒绝请求的会话访问。 指定的终端连接驱动程序无效。 不能远程控制该请求的会话。这也许是由于该会话被中断或目前没有一个用户登录。而且,您不能从该系统控制台远程控制一个会话或远程控制系统控制台。并且, 您不能远程控制您自己的当前会话。 该请求的会话没有配置成允许远程控制。 拒绝连接到这个终端服务器。终端服 务器客户许可证目前正在被另一个用户使用。请与系统管理员联系,获取一份新的终端服务器客户,其许可证号码必须是有效的、唯一的。 拒绝连接到这个终端服务器。还没有为这份终端服务器客户输入您的终端服务器客户许可证号码。请与系统管理员联系,为该终端服务器客户输入一个有效的、唯一 的许可证号码。 系统已达到其授权的登录限制。请以后再试一次。 您正在使用的客户没有使用该系统的授权。您的 登录请求被拒绝。 系统许可证已过期。您的登录请求被拒绝。 文件复制服务 API 被错误调用。 无法启动文件复制服务。 无法停止文件复制服务。 文件复制服务 API 终止了请求。事件日志可能有详细信息。 该文件复制服务中断了该请求。事件日志可能有详细信息。 无法联系文件 复制服务。事件日志可能有详细信息。 由于该用户没有足够特权,文件复制服务不能满足该请求。事件日志可能有详细信息。 由于验证的 RPC 无效,文件复制服务不能满足该请求。事件日志可能有详细信息。 由于该用户在域控制器上没有足够特权,文件复制 服务不能满足该请求。事件日志可能有详细信息。 由于在域控制器上的验证的 RPC 无效,文件复制服务不能满足该请求。事件日志可能有详细信息。 该文件复制服务无法与在域控制器上的文件复制服务通讯。事件日志可能 有详细信息。 在域控制器上的文件复制服务无法与这台计算机上的文件复制服务通讯。事件日志可能有详细信息。 由于内部错误,该文件复制服务不能进入该系统卷中。事件日志可能有详细信息。 由于内部超时,该文件复制服务不能进入该系统卷中。事 件日志可能有详细信息。 该文件复制服务无法处理此请求。该系统卷仍在忙于前一个请求。 由于内部错误,该文件 复制服务无法停止复制该系统卷。事件日志可能有详细信息。 该文件复制服务检测到一个无效参数。 在安装目录服 务时出现一个错误。有关详细信息,请查看事件日志。 目录服务在本地评估组成员身份。 指定的目录服务属性或值 不存在。 指定给目录服务的属性语法无效。 指定给目录服务的属性类型未定义。 指定的目 录服务属性或值已经存在。 目录服务忙。 该目录服务无效。 目录服务无法分配相对标识 号。 目录服务已经用完了相对标识号池。 由于目录服务不是该类操作的主控,未能执行操作。 目录服务无法初始化分配相对标识号的子系统。 该请求的操作没有满足一个或多个与该对象的类别相关的约束。 目 录服务只可以在一个页状对象上运行要求的操作。 目录服务不能在一个对象的 RDN 属性上执行该请求的操作。 目录服务检测出修改对象类别的尝试。 不能执行请求的通过域的移动操作。 无法联系全局编录服务器。 策略对象是共享的并只可在根目录上修改。 策略对象不存在。 请求的策略信息只在目录服务中。 域控制器升级目前正在使用中。 域控制器升级目前不在使用中 出现一个操作错误。 出现一 个协议错误。 已经超过这个请求的时间限制。 已经超过这个请求的大小限制。 已经超过这 个请求的管理限制。 比较的响应为假。 比较的响应为真。 这个服务器不支持请求的身份验 证方式。 这台服务器需要一个更安全的身份验证方式。 不适当的身份验证。 未知的身份验 证机制。 从服务器返回了一个建议。 该服务器不支持该请求的关键扩展。 这个请求需要一 个安全的连接。 不恰当的匹配。 出现一个约束冲突。 在服务器上没有这样一个对象。 有一个别名问题。 指定了一个无效的 dn 语法。 该对象为叶对象。 有一个别名废弃问 题。 该服务器不愿意处理该请求。 检查到一个循环。 有一个命名冲突。 结果设置太大。 该操作会影响到多个 DSA。 该服务器不可操作。 出现一个本地错误。 出现一个编码错误。 出现一个解码错误。 无法识别寻找筛选器。 一个或多个参数非法。 不支持指定的方式。 没有返回结果。 该服务器不支持该指定的控制。 客户检测到一个参考 循环。 超过当前的参考限制。 根目录对象必须是一个命名上下文的头。该根目录对象不能有实例父类。 不能执行添加副本操作。名称上下文必须可写才能创建副本。 出现一个对架构中未定义的一个属性的参考。 超过了 一个对象的最大尺寸。 尝试向目录中添加一个已在使用中的名称的对象。 尝试添加一个对象,该对象属于那类在架 构中没有一个 RDN 定义的类别。 尝试添加一个使用 RDN 的对象,但该 RDN 不是一个在架构中定义的 RDN 。 在对象中找不到任何请求的属性。 用户缓冲区太小。 在操作中指定的属性不出现在对象上。 修改操作非法。不允许该修改的某个方面。 指定的对象太大。 指定的实例类别无效。 操作 必须在主控 DSA 执行。 必须指定对象类别属性。 一个所需的属性丢失。 尝试修改一 个对象,将一个对该类别来讲是非法的属性包括进来。 在对象上指定的属性已经存在。 指定的属性不存在或没有 值。 为只有一个值的属性指定了多个值。 属性值不在接受范围内。 指定的值已存在。 由于不存在于对象上,不能删除该属性。 由于不存在于对象上,不能删除该属性值。 指定的根对象不能是子参考。 不允许链接。 不允许链接的评估。 由于对象的父类不是未实例化就是被删除了,所以不能执行操作。 不允许有一个用别名的父类。别名是叶对象。 对象和父类必须是同一种类,不是都是原件就是都是副本。 由于子对 象存在,操作不能执行。这个操作只能在叶对象上执行。 没有找到目录对象。 别名对象丢失。 对象名语法不对。 不允许一个别名参考另一个别名。 别名不能解除参考。 操作超出范围。 不能删除 DSA 对象。 出现一个目录服务错误。 操作只能在内部主控 DSA 对象上执行。 对象必须为 DSA 类别。 访问权不够不能执行该操作。 由于父类不在可能的上级列表上,不能添加该对象。 由于该属性处于“安全帐户管理器” (SAM),不允许访问该属性。 名称有太多部分。 名称太长。 名称值太长。 目录服务遇到了一个错误分列名称。 目录服务找不到一个名称的属性种类。 该名称不能识别一个对象; 该名称识别一个幻象。 安全描述符太短。 安全描述符无效。 为删除的对象创建名称失败。 一个新子参考的父类必须存在。 该对象必须是一个命名上下文。 不允许添加一个不属于系统的属性。 对象的类别必须是有结构的; 您不能实例化一个抽象的类别。 找不到架构的 对象。 有这个 GUID (非活动的的或活动的)的本地对象已经存在。 操作不能在一个后部链接上执行。 找不到指定的命名上下文的互交参考。 由于目录服务关闭,操作不能执行。 目录服务请求无效。 无法读?巧姓呤粜浴? 请求的 FSMO 操作失败。不能连接当前的 FSMO 盒。 不允许跨过一个命名 上下文修改 DN。 由于属于系统,不能修改该属性。 只有复制器可以执行这个功能。 指 定的类别没有定义。 指定的类别不是一个子类别。 名称参考无效。 交叉参考已经存在。 不允许删除一个主控交叉参考。 只在 NC 头上支持子目录树通知。 通知筛选器太复杂。 架构更新失败: 重复的 RDN。 架构更新失败: 重复的 OID。 架构更新失败: 重复的 MAPI 识别符。 架构更新失败: 复制架构 id GUID。 架构更新失败: 重复的 LDAP 显示名称。 架构更新失败: 范围下部少于范围上部。 架构更新失败: 语法不匹配。 架构更新失败: 属性在必须包含中使用。 架构更新失败: 属性在可能包含中使用。 架构更新失败: 可能包含中的属性不存在。 架构更新失败:必须包含中的属性不存在。 架构更新失败: 在辅助类别列表中的类别不存在或不是一个辅助类别。 架构更新失败: poss-superior 中的类别不存在。 架构更新失败: 在 subclassof 列表中的类别不存在或不能满足等级规则。 架构更新失败: Rdn-Att-Id 语法不对。 架构更新失败: 类别作为辅助类别使用。 架构更新失败: 类别作为子类别使用。 架构更新失败: 类别作为 poss superior 使用。 架构更新在重新计算验证缓存时失败。 目录树删除没有完成。要继续删除目录树,必须 再次发出请求。 不能执行请求的删除操作。 不能读?芄辜锹脊芾砝啾鹗侗鸱? 属性架构 语法不对。 不能缓存属性。 不能缓存类别。 不能从缓存删除属性。 无法从缓存中删除类别。 无法读取特殊名称的属性。 丢失一个所需的子参考。 不能检索范 例种类属性。 出现一个内部错误。 出现一个数据错误。 丢失一个属性 GOVERNSID。 丢失一个所需要的属性。 指定的命名上下文丢失了一个交叉参考。 出现一个安全检查错误。 没有加载架构。 架构分配失败。请检查机器内存是否不足。 为属 性架构获得所需语法失败。 全局编录验证失败。全局编录无效或不支持操作。目录的某些部分目前无效。 由于有关 服务器之间的架构不匹配,复制操作失败。 找不到 DSA 对象。 找不到命名上下文。 在缓存中找不到命名上下文。 无法检索子对象。 由于安全原因不允许修改。 操作不能替换 该隐藏的记录。 等级无效。 尝试建立等级表失败。 目录配置参数在注册中丢失。 尝试计算地址簿索引失败。 等级表的分配失败。 目录服务遇到一个内部失败。 目录服务遇 到一个未知失败。 根对象需要一个 $top$ 类别。 这个目录服务器已关闭,并且不能接受新上浮单一主机操 作角色的所有权。 目录服务没有必需的配置信息,并且不能决定新上浮单一主机操作角色的所有权。 该目录服务无 法将一个或多个上浮单一主机操作角色传送给其它服务器。 复制操作失败。 为这个复制操作指定了一个无效的参 数。 目录服务太忙,现在无法完成这个复制操作。 为这个复制操作指定的单一名称无效。 为这一个复制操作所指定的命名上下文无效。 为这个复制操作指定的单一名称已经存在。 复制系统遇到一个内部错 误。 复制操作遇到数据库不一致问题。 不能连接到为这个复制操作指定的服务器上。 复制 操作遇到一个有无效范例类型的对象。 复制操作无法分配内存。 复制操作遇到一个邮件系统错误。 目标服务器的复制参考信息已经存在。 目标服务器的复制参考信息不存在。 由于是由另一台服务器上复制的,因此 不能删除命名上下文。 复制操作遇到一个数据库错误。 命名上下文要被删除或没有从指定的服务器上复制。 复制访问被拒绝。 这个版本的目录服务不支持请求的操作。 取消复制远程过程呼叫。 源服 务器目前拒绝复制请求。 目标服务器当前拒绝复制请求。 由于对象名称冲突,复制操作失败。 复制源已被重新安装。 由于一个所需父对象丢失,复制操作失败。 复制操作被抢先。 由于 缺乏更新,放弃复制同步尝试。 由于系统正在关闭,复制操作被中断了。 由于目标部分属性设置不是一个源部分属 性设置的子设置,复制同步尝试失败。 由于主复制尝试从部分复制同步,复制同步尝试失败。 已经与为这个复制操 作的指定的服务器联系,但是该服务器无法与完成这个操作所需的另外一个服务器联系。 在副本安装时,检测到一个使用的源和内部版本之 间的架构不匹配,不能安装该副本。 架构更新失败: 有同一连接标识符的属性已经存在。 名称翻译: 常见处理错误。 名称翻译: 不能找到该名称或权限不够,不能看到名称。 名称翻译: 输入名称映射到多个输出名称。 名称翻译: 找到输出名称,但是找不到相应的输出格式。 名称翻译: 不能完全解析,只找到了域。 名称翻译: 不接到线上,无法在客户机上执行纯粹的语法映射。 不允许一个构造 att 修改。 指定的 OM-Object 类别对指定语法的一个属性是不正确的。 复制请求已暂停; 等待回答。 要求的操作需要一个目录服务,但没有可用的。 类别或属性的 LDAP 显示名称含有非 ASCII 字符。 请求的查找操作只支持基本查找。 查找未能从数据库检索属性。 架构 更新操作试图添加一个反向链接,但该反向链接没有相应的正向链接。 跨域移动的来源和目标在对象日期上不一致。或者是来源,或者是目 标没有对象的最后一个版本。 跨域移动的来源和目标在对象当前的名称上不一致。或者是来源,或者是目标没有对象的最后一个版本。 域间移动的来源和目标是一样的。调用程序应该使用本地移动操作,而不是域间移动操作。 域间移动的来源和目标与目录林中的命名上下文 不一致。来源或目标没有分区容器的最近版本。 跨域移动的目标不是目标命名上下文的权威。 跨域移动的来源和目 标提供的来源对象的身份不一样。 来源或目标没有来源对象的最近版本。 跨域移动的对象应该已经被目标服务器删除。来源服务器没有来 源对象的最近版本。 要求对 PDC FSMO 的专门访问权的另一个操作正在进行中。 跨域移动没有成功,导 致被移动对象有两个版本 – 一个在来源域,一个在目标域。需要删除目标对象,将系统还原到一致状态。 因为不允许这个类别的跨域移 动,或者对象有一些特点,如: 信任帐户或防止移动的受限制的 RID;所以不能将该对象跨域移动。 一旦移动,不能将带有成员身份 的对象跨域移动,这会侵犯帐户组的成员身份条件。从帐户组成员身份删除对象,再试一次。 命名上下文标题必须是另一个命名上下文标题 的直接子标题,而不是一个内节点的子标题。 因为目录没有提议的命名上下文上面的命名上下文的副本,所以无法验证所提议的命名上下文 的名称。请保证充当域命名主机的服务器已配置成全局编录服务器,并且服务器及其复制伙伴是最新的。 目标域必须在本机模式中。 因为服务器在指定域中没有基?峁谷萜鳎晕薹ㄖ葱胁僮鳌? 不允许跨域移动帐户组。 不允许跨域移动资源组。 属性的搜索标志无效。ANR 位只在 Unicode 或 Teletex 字符串的属性上有效。 不允许在将 NC 头作为子体的对象开始删除目录树。 因为目录树在使用中,目录服务未能为删除目录树而将其锁定。 删除目录树 时,目录服务未能识别要删除的对象列表。 只有管理员才能修改管理组的成员列表。 不能改变域控制器帐户的主要 组 ID。 试图修改基?芄埂? 不允许进行下列操作: 为现有类别添加新的强制属性;从现有类别删除强制属性;为没有向回链接属性的特殊类别 “Top” 添加可选属性,向回链接属性指的是直接或通过继承。例如: 添加或删除附属类别。 该域控制器上不允许架构更新。没有设置注册表项, 或者 DC 不是架构 FSMO 角色所有者。 无法在架构容器下创建这个类别的对象。在架构容器下,您只能创建属性架构和类别架构 对象。 副本/子项安装未能获取源 DC 上的架构容器的 objectVersion 属性。架构容器上的属性不存在,或者提供的凭据没有读取属性的权限。 副本/子项安装未能读取 system32 目录中的文件 schema.ini 的 SCHEMA 段中的 objectVersion 属性。 指定的组类型无效。 如果域是安全启用的,在混合型域中不能嵌套全局组。 如果域是安全启用的,在混合型域中不能嵌套本地组。 全局 组不能将本地组作为成员。 全局组不能将通用组作为成员。 通用组不能将本地组作为成员。 全局组不能有跨域成员。 本地组不能将另一个跨域本地组作为成员。 包含主要成员的组不能改变为安全停用的组。 架构缓冲加载未能转换类架构对象上的字符串默认值 SD。 只有配置成全局编录服务器的 DSAs 才能充当域命名主机 FSMO 的角色。 由于 DNS 查找故障,DSA 操作无法进行。 处理一个对象的 DNS 主机名改动时,服务主要名称数值无法保持同步。 未能读取安全描述符属性。 没有找到请求的对象,但找到了具有 那个密钥的对象。 正在添加的链接属性的语法不正确。正向链接只能有语法 2.5.5.1、2.5.5.7 和 2.5.5.14,而反向链接只能有语法 2.5.5.1 安全帐户管理员需要获得启动密码。 安全帐户管理员 需要从软盘获得启动密钥。 目录服务无法启动。 未能启动目录服务。 客户和服务器之间的 连接要求数据包保密性。 来源域跟目标域不在同一个目录林中。 目标域必须在目录林中。 该操作要求启用目标域审核。 该操作无法为来源域找到 DC。 来源对象必须是一个组或用户。 来源对象的 SID 已经在目标目录林中。 来源对象和目标对象必须属于同一类型。 在复制请求中不能包括架构 信息。 由于架构不兼容性,无法完成复制操作。 由于前一个架构的不兼容性,无法完成复制操作。 因为源和目标都没有收到有关最近跨域启动操作的信息,所以无法应用复制更新。 因为还有主控这个域的域控制器,所以无法删除请求的 域。 只能在全局编录服务器上执行请求的操作。 本地组只能是同一个域中其他本地组的成员。 外部安全主要成员不能是通用组的成员。 出于安全,无法将属性复制到 GC。 由于目前正在处理的修改太多,无 法采取 PDC 的检查点。 操作需要启用那个源域审核。 安全主要对象仅能在域命名环境菜单中创建。 服务主要名称(SPN) 无法建造,因为提供的主机名格式不适合。 筛选器已传递建造的属性。 unicodePwd 属性值必须括在双引号中。 您的计算机无法加入域。已超出此域上允许创建的计算机帐户的最大值。请同系统管理员联系,复位或增加此 限定值。 由于安全原因,操作必须在目标 DC 上运行。 由于安全原因,源 DC 必须是 Service Pack 4 或更新版本。 在树目录删除的操作中不能删除“关键目录服务系统”对象。数目录删除操作可能只进行了一部分。 DNS 服务器无法解释格式。 DNS 服务器失败。 DNS 名称不存在。 名称服务器不支持 DNS 请求。 拒绝 DNS 操作。 不应该存在的 DNS 名称仍然存在。 不应该 存在的 DNS RR 集仍然存在。 应该存在的 DNS RR 集不存在。 DNS 服务器对区域没有权威。 在更新或 prereq 中的 DNS 名称不在区域中。 DNS 签名验证失败。 DNS 不正确密钥。 DNS 签名验证过期。 为 DNS 查询找不到记录。 无效 DNS 包。 没有 DNS 包。 DNS 错误,请检查 rcode。 为保险的 DNS 包。 无效的 DNS 种类。 无效的 IP 地址。 无效的属性。 稍后再试一次 DNS 操作。 给出的记录名称和种类不是单一的。 DNS 名称不符合 RFC 说明。 DNS 名称是一个完全合格的 DNS 名称。 DNS 名称以“.”分隔(多标签)。 DNS 名称是单一部分名称。 DNS 名称含有无效字符。 DNS 名称完全是数字的。 DNS 区域不存在。 DNS 区域信息无效。 DNS 区域无效操作。 无效 DNS 区域配置。 DNS 区域没有颁发机构记录的开始(SOA)。 DNS 区域没有“名称服务器” (NS)的记录。 DNS 区域已锁定。 DNS 区域创建失败。 DNS 区域已经存在。 DNS 自动区域已经存在。 无效的 DNS 区域种类。 次要 DNS 区域需要主 IP 地址。 DNS 区域不是次要的。 需要一个次要 IP 地址 WINS 初始化失败。 需要 WINS 服务器。 NBTSTAT 初始化呼叫失败。 颁发机构起始(SOA)删除无效 主要 DNS 区域需要数据文件。 DNS 区域的无效数据文件名称。 为 DNS 区域打开数据文件失败。 为 DNS 区域写数据文件失败。 为 DNS 区域读取数据文件时失败。 DNS 记录不存在。 DNS 记录格式错误。 DNS 中节点创建失败。 未知 DNS 记录类型。 DNS 记录超时。 名称不在 DNS 区域。 检测到 CNAME 循环。 节点为一个 CNAME DNS 记录。 指定名称的 CNAME 记录已经存在。 记录不在 DNS 区域根目录。 DNS 记录已经存在。 次要 DNS 区域数据错误。 不能创建 DNS 缓存数据。 DNS 名称不存在。 不能创建指针(PTR)记录。 DNS 域没有被删除。 该目录服务无 效。 DNS 区域已经在目录服务中存在。 DNS 服务器没有为目录服务集合 DNS 区域创建或读取启动文件。 完成 DNS AXFR (区域复制)。 DNS 区域复制失败。 添加了本地 WINS 服务器。 安全更新呼叫需要继续更新请求。 TCP/IP 没有安装网络协议。 没有为本地系统配置 DNS 服务器。 10004 一个封锁操作被对 WSACancelBlockingCall 的调用中断。 10009 提供的文件句柄无效。 10013 以一种访问权限不允许的方式做了一个访问套接字的尝试。 10014 系统检测到在一个调用中尝 试使用指针参数时的无效指针地址。 10022 提供了一个无效的参数。 10024 打开的套接字太多。 10035 无法立即完成一个非阻挡性套接字操作。 10036 目前正在执行一个阻挡性操作。 10037 在一个非阻挡套接字上尝试了一个已 经在进行的操作。 10038 在一个非套接字上尝试了一个操作。 10039 请求的地址在一个套接字中从操作中忽略。 10040 一个在数据报套接字上发送的消息大于内部消息缓冲器或其它一些网络限制,或该用户用于接收数据报的缓冲器比数据报小。 10041 在套接字函 数调用中指定的一个协议不支持请求的套接字类别的语法。 10042 在 getsockopt 或 setsockopt 调用中指定的一个未知的、无效的或不受支持的选项或层次。 10043 请求的协议还没有在系统中配置,或者没有它存在的迹象。 10044 在这个地址家族中不存在对指定的插槽种类的支持。 10045 参考的对象种类不支持尝试的操作。 10046 协议家族尚未配置到 系统中或没有它的存在迹象。 10047 使用了与请求的协议不兼容的地址。 10048 通常每个套接字地址 (协议/网络地址/端口)只允许使用一次。 10049 在其上下文中,该请求的地址无效。 10050 套接字操作遇到了一个已死 的网络。 10051 向一个无法连接的网络尝试了一个套接字操作。 10052 当该操作在进行中,由于保持活动的操作检测到一个 故障,该连接中断。 10053 您的主机中的软件放弃了一个已建立的连接。 10054 远程主机强迫关闭了一个现有的连接。 10055 由于系统缓冲区空间不足或列队已满,不能执行套接字上的操作。 10056 在一个已经连接的套接字上做了一个连接请求。 10057 由于套接字没有连接并且 (当使用一个 sendto 调用发送数据报套接字时) 没有提供地址,发送或接收数据的请求没有被接受。 10058 由于以前的关闭调用,套接字在那个方向已经关闭,发送或接收数据的请求没有被接受。 10059 对某个内核对象的引用过多。 10060 由于连接方在一段时间后没有正确的答复或连接的主机没有反应,连接尝试失败。 10061 不能做任何连接,因为目标机器积极地拒绝它。 10062 无法翻译名称。 10063 名称组件或名称太长。 10064 由于目标主机坏了,套接字操作失败。 10065 套接 字操作尝试一个无法连接的主机。 10066 不能删除目录,除非它是空的。 10067 一个 Windows 套接字操作可能在可以同时使用的应用程序数目上有限制。 10068 超过限额。 10069 超过磁盘限额。 10070 文件句柄引用不再有效。 10071 项目在本地不可用。 10091 因为它使用提供网络服务的系统目前无 效,WSAStartup 目前不能正常工作。 10092 不支持请求的 Windows 套接字版本 10093 应用程序没有 调用 WSAStartup,或者 WSAStartup 失败。 10101 由 WSARecv 或 WSARecvFrom 返回表示远程方面已经开始了关闭步骤。 10102 WSALookupServiceNext 不能返回更多的结果。 10103 在处理这个调用时,就开始调用 WSALookupServiceEnd。该调用被删除。 10104 过程调用无效。 10105 请求的服务提供程序无效。 10106 没有加载或初始化请求的服务提供程序。 10107 从来不应失败的系统调用失败了。 10108 没有已知的此服务。在指定的名称空间中找不这个服务。 10109 找不到指定的类别。 10110 WSALookupServiceNext 不能返回更多的结果。 10111 在处理这个调用时,就开始调用 WSALookupServiceEnd。该调用被删除。 10112 由于被拒绝,数据查询失败。 11001 不知道这样的主机。 11002 这是在主机名解析时常出现的暂时错误,并且意味着本地服 务器没有从权威服务器上收到响应。 11003 在数据寻找中出现一个不可恢复的错误。 11004 请求的名称有效并且是在数据库 中找到,但是它没有相关的正确的数据。 11005 至少到达了一个保留。 11006 至少到达了一个路径。 11007 没有发送方。 11008 没有接受方。 11009 保留已经确认。 11010 错误是由于资源不足造成。 11011 由于管理原因被拒绝 – 无效凭据。 11012 未知或有冲突类型。 11013 某一部分的 filterspec 或 providerspecific 缓冲区有问题。 11014 flowspec 的某部分有问题。 11015 一般性 QOS 错误。 11016 在流程规格中发现一个无效的或不可识别的服务类型。 11017 在 QOS 结构中发现一个无效的或不一致的流程规格。 11018 无效的 QOS 提供程序特定缓冲区。 11019 使用了无效的 QOS 筛选器样式。 11020 使用了无效的 QOS 筛选器类型。 11021 FLOWDESCRIPTOR 中指定的 QOS FILTERSPEC 数量不正确。 11022 在 QOS 提供程序特定缓冲区中指定了一个 ObjectLength 字符域无效的对象。 11023 QOS 结构中指定的流程描述符数量不正确。 11024 在 QOS 提供程序特定缓冲区中发现一个不可识别的对象。 11025 在 QOS 提供程序特定缓冲区中发现一个无效的策略对象。 11026 在流程描述符列表中发现一个无效的 QOS 流程描述符。 11027 在 QOS 提供程序特定缓冲区中发现一个无效的或不一致的流程规格。 11028 在 QOS 提供程序特定缓冲区中发现一个无效的 FILTERSPEC。 11029 在 QOS 提供程序特定缓冲区中发现一个无效的波形丢弃模式对象。 11030 在 QOS 提供程序特定缓冲区中发现一个无效的成形速率对象。 11031 在 QOS 提供程序特定缓冲区中发现一个保留的策略因素

    今天写了两个简单的Activex控件,一个用的MFC,一个用的ATL

    用MFC的控件,编译后,直接引用就可以使用了。

    用ATL写的控件,编译后,可以添加到VC程序中使用,但在WinForm程序中不可以使用,从工具箱拖拽到form后会报下面的错误:

    Failed to create component 'AxHost'. The error message follows: 'System.InvalidOperationException: Unable to initialize component. at System.Windows.Forms.AxHost.DepersistControl() at System.Windows.Forms.AxHost.ActivateAxControl() at System.Windows.Forms.AxHost.TransitionUpTo(Int32 state) at System.Windows.Forms.AxHost.CreateHandle() at System.Windows.Forms.Control.CreateControl(Boolean fIgnoreVisible) at System.Windows.Forms.Control.CreateControl() at System.Windows.Forms.Control.ControlCollection.Add(Control value) at System.Windows.Forms.Form.ControlCollection.Add(Control value) at System.Windows.Forms.Design.ParentControlDesigner.AddChildControl(Control newChild) at System.Windows.Forms.Design.ParentControlDesigner.AddControl(Control newChild, IDictionary defaultValues) at System.Windows.Forms.Design.ControlDesigner.InitializeNewComponent(IDictionary defaultValues) at System.Windows.Forms.Design.AxHostDesigner.InitializeNewComponent(IDictionary defaultValues)'

    查找了半天,有人说用AxImp.exe生产一个代理类可以解决这个问题。
    尝试了SDK7.0,SDK7.1,SDK8.0,SDK8.1的AxImp.exe,可以成功生成dll,但是仍然没法使用。

    也有人说,可以通过降低.NetFramework版本解决这个问题,2.0,3.0,3.5我都试了下,都不行。

    试了VS2010和VS2013都不行,累了,回去了。。。

    明天有空再弄吧。。。

    今天试了一下,微软你大爷的,同样的操作,VS2008上(XP和Win7)就是好的。。。
    真够坑爹啊。。。

    再次测试表明:
    1、VS2008的ATL控件在高版本的VS上可以插入到WinForm
    2、VS2010以上的ATL控件,不能插入到VS2008以上任何版本的WinForm

    VS2010以上的ATL控件,插入VS2008时,报的错误与上面不同

    Debug Assertion Failed! Program:....... File:......vc\atlmfc\include\atlctl.h Expression:pClientSite == 0 || m_spClientSite == 0 For information on how ....

    微软,你自己的产品,兼容性做好一些,你能死啊。。。

    这两个类的使用步骤如下:
    1、使用向导生成MFC ActiveX控件,(假设控件类为NControlCtrl)
    2、工程中添加上面两个文件,ActivDoc.cpp和ActivDoc.h
    3、将控件的基类,从COleControl换为CActiveXDocControl,在NControlCtrl.h中添加ActivDoc.h的引用
    4、将NControlCtrl控件类中的COleControl全部替换为CActiveXDocControl
    5、去掉NControlCtrl的OnDraw函数
    5、将自己的Document类,View类,Frame类,添加到项目中,(假设为NDocument,NView,NFrame)
    6、在NControlCtrl类中,添加NDocument,NView,NFrame的引用
    7、在类的构造函数中,添加一行代码

    AddDocTemplate(new CActiveXDocTemplate( RUNTIME_CLASS(NDocument), RUNTIME_CLASS(NMainFrame), RUNTIME_CLASS(NView)));

    8、这样SDI就可以用了。如果你原来的项目比较复杂的话,就要将资源文件进行拷贝及合并了,注意ID不要重复哦。

    尝试了直接将NMainFrame进行分栏,但整个框架对于NDocument和NView比较依赖,会有报错。
    最近比较忙,只好有空再搞下了。

    最近写了几个Windows服务,整理了一下服务模板,以备以后使用。
    说实话,这些代码是n年前写的了,用了也n久了,但还是发现了一个明显的bug。
    其中,有些内容,写的并不好,如静态指针pThis,大家还是尽量不要使用了。

    1、服务入口myXXX.cpp

    //=================================================== //XXX入口函数 //=================================================== #include <windows.h> #include <tchar.h> #include <stdio.h> #include "XXX.h" //=================================================== //入口函数 int WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR lpCmdLine,int nCmdShow) UNREFERENCED_PARAMETER(hInstance); UNREFERENCED_PARAMETER(hPrevInstance); UNREFERENCED_PARAMETER(nCmdShow); //获取可执行文件路径 TCHAR szPath[MAX_PATH]; TCHAR szLog[MAX_PATH]; GetModuleFileName(NULL,szPath,MAX_PATH); //生成日志目录 TCHAR *p = _tcsrchr(szPath, '\\'); if(p!=NULL)*p='\0'; if (_tcslen(szPath) + _tcslen(TEXT("Log\\")) <= MAX_PATH) _stprintf_s(szLog, TEXT("%s\\%s"), szPath, TEXT("Log\\")); return -1; //判断运行参数 XXX myService(szLog, true); myService.ParseParameters(lpCmdLine); return 0; //=================================================== &#91;/code&#93; 2、服务类XXX.h &#91;code lang="cpp"&#93; //=================================================== //XXX 服务类封装 #include <windows.h> //=================================================== //预定义 #define MAX_THREAD_COUNT 64 //=================================================== //XXX CLASS class XXX private: HANDLE hSemaphore; CRITICAL_SECTION cs; bool m_bLog; const TCHAR *m_szLogPath; LPCTSTR lpServiceName; LPCTSTR lpDisplayName; SERVICE_STATUS_HANDLE gSvcStatusHandle; SERVICE_STATUS gSvcStatus; HANDLE ghSvcStopEvent; static XXX *pThis; bool m_bFinished; //构造与析构函数 public: XXX(); XXX(const TCHAR *cLogPath,const bool bLog); ~XXX(); //服务相关函数 private: static void WINAPI ServiceMain(DWORD dwArgc,LPTSTR *lpszArgv); static void WINAPI SvcCtrlHandler(DWORD dwCtrl); void SvcInitAndRun(DWORD dwArgc,LPTSTR *lpszArgv); void Show_Me_Err(); public: int AddService(); int DelService(); void LogEvent(LPCTSTR lpMsg); void ParseParameters(LPSTR lpCmdLine); //===================================================

    2、服务类XXX.cpp

    //=================================================== //XXX服务类的封装实现 //=================================================== //头文件 #include "XXX.h" //=================================================== //静态成员 XXX *XXX::pThis = NULL; //=================================================== //构造函数 XXX::XXX(const TCHAR *cLogPath,const bool bLog) hSemaphore=NULL; m_bLog=bLog; lpServiceName=TEXT("XXX"); lpDisplayName=TEXT("XXX"); ghSvcStopEvent=NULL; m_szLogPath=cLogPath; m_bFinished = false; pThis=this; //=================================================== //析构函数 XXX::~XXX() //=================================================== //入口函数 void XXX::ParseParameters(LPSTR lpCmdLine) //判断运行参数 //设置SERVICE_TABLE_ENTRY SERVICE_TABLE_ENTRY DispatchTable[]= {TEXT("XXX"),(LPSERVICE_MAIN_FUNCTION)ServiceMain}, {NULL,NULL} //处理输入参数 if((0==_stricmp(lpCmdLine,"/i")) || 0==_stricmp(lpCmdLine,"-i")) //安装服务"/i -i" AddService(); return; else if((0==_stricmp(lpCmdLine,"/u")) || 0==_stricmp(lpCmdLine,"-u")) //删除服务"/u -u" DelService(); return; else if((0==_stricmp(lpCmdLine,"/h")) || 0==_stricmp(lpCmdLine,"-h")) //提示运行参数"/h -h" MessageBox(NULL,TEXT(" Install Service : -i /i\n UnInstall Service: -u /u"),TEXT("XXX"),MB_OK); return; //设置调试断点 //DebugBreak(); //StartServiceCtrlDispatcher运行服务 if(!StartServiceCtrlDispatcher(DispatchTable)) LogEvent(TEXT("XXX: Failed To Start!")); LogEvent(TEXT("XXX: Started!")); return; //=================================================== //添加服务 int XXX::AddService() //SCMD与Service的句柄 SC_HANDLE hSCManager=NULL; SC_HANDLE hService=NULL; //连接到SCM,打开SCMD hSCManager=OpenSCManager(NULL,NULL,SC_MANAGER_CREATE_SERVICE); if(NULL==hSCManager) MessageBox(NULL,TEXT("OpenSCManager Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); return 1; //检查服务是否安装 hService=OpenService(hSCManager,lpServiceName,SERVICE_ALL_ACCESS); if(NULL==hService) //若服务不存在,创建服务 TCHAR szFilePath[MAX_PATH]; GetModuleFileName(GetModuleHandle(NULL),szFilePath,MAX_PATH); //自动启动 hService=CreateService(hSCManager,lpServiceName,lpDisplayName,SERVICE_ALL_ACCESS, SERVICE_WIN32_OWN_PROCESS | SERVICE_INTERACTIVE_PROCESS, SERVICE_AUTO_START,SERVICE_ERROR_NORMAL,szFilePath,NULL,NULL,NULL,NULL,NULL); if(NULL==hService) MessageBox(NULL,TEXT("CreateService Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); CloseServiceHandle(hSCManager); return 1; MessageBox(NULL,TEXT("Service Already Installed!"),TEXT("XXX"),MB_OK); CloseServiceHandle(hService); CloseServiceHandle(hSCManager); return 1; //关闭句柄 CloseServiceHandle(hService); CloseServiceHandle(hSCManager); LogEvent(TEXT("XXX: AddService Successed!")); //ForDebug //MessageBox(NULL,TEXT("AddService Successed!"),TEXT("XXX"),MB_OK); return 0; //=================================================== //删除服务 int XXX::DelService() //SCMD与Service的句柄 SC_HANDLE hSCManager=NULL; SC_HANDLE hService=NULL; SERVICE_STATUS ServiceStatus; //获取SCM句柄,打开SCMD hSCManager=OpenSCManager(NULL,NULL,SC_MANAGER_CREATE_SERVICE); if(NULL==hSCManager) MessageBox(NULL,TEXT("OpenSCManager Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); return 1; //打开服务句柄 hService=OpenService(hSCManager,lpServiceName,SERVICE_ALL_ACCESS|DELETE); if(NULL==hService) MessageBox(NULL,TEXT("OpenService Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); CloseServiceHandle(hSCManager); return 1; //查询服务状态 if(0==QueryServiceStatus(hService,&ServiceStatus)) MessageBox(NULL,TEXT("QueryServiceStatus Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); CloseServiceHandle(hService); CloseServiceHandle(hSCManager); return 1; //如果服务正在运行,则停止 if(SERVICE_STOPPED!=ServiceStatus.dwCurrentState) if(0==ControlService(hService,SERVICE_CONTROL_STOP,&ServiceStatus)) MessageBox(NULL,TEXT("ControlService Failed"),TEXT("XXX"),MB_OK); Show_Me_Err(); CloseServiceHandle(hService); CloseServiceHandle(hSCManager); return 1; //删除服务 if(0==DeleteService(hService)) MessageBox(NULL,TEXT("DeleteService Fialed!"),TEXT("XXX"),MB_OK); Show_Me_Err(); CloseServiceHandle(hService); CloseServiceHandle(hSCManager); return 1; CloseServiceHandle(hService); CloseServiceHandle(hSCManager); LogEvent(TEXT("XXX: DelService Successed!")); //ForDebug //MessageBox(NULL,TEXT("DelService Successed!"),TEXT("XXX"),MB_OK); return 0; //=================================================== //服务入口函数 void WINAPI XXX::ServiceMain(DWORD dwArgc,LPTSTR *lpszArgv) //注册服务控制程序 pThis->gSvcStatusHandle=RegisterServiceCtrlHandler(pThis->lpServiceName,SvcCtrlHandler); if(0==pThis->gSvcStatusHandle) //注册失败,返回 pThis->LogEvent(TEXT("XXX: RegisterServiceCtrlHandler Failed")); return; //设置服务状态SERVICE_START_PENDING pThis->gSvcStatus.dwServiceType=SERVICE_WIN32_OWN_PROCESS; pThis->gSvcStatus.dwCurrentState=SERVICE_START_PENDING; pThis->gSvcStatus.dwControlsAccepted=0; pThis->gSvcStatus.dwWin32ExitCode=NO_ERROR; pThis->gSvcStatus.dwServiceSpecificExitCode=0; pThis->gSvcStatus.dwCheckPoint=0; pThis->gSvcStatus.dwWaitHint=10000; SetServiceStatus(pThis->gSvcStatusHandle,&(pThis->gSvcStatus)); //运行服务函数 pThis->SvcInitAndRun(dwArgc, lpszArgv); //停止服务 pThis->gSvcStatus.dwCurrentState=SERVICE_STOPPED; pThis->gSvcStatus.dwWaitHint=0; pThis->gSvcStatus.dwControlsAccepted=SERVICE_ACCEPT_STOP; pThis->gSvcStatus.dwCheckPoint=0; SetServiceStatus(pThis->gSvcStatusHandle,&(pThis->gSvcStatus)); //=================================================== //服务函数 void XXX::SvcInitAndRun(DWORD dwArgc,LPTSTR *lpszArgv) UNREFERENCED_PARAMETER(dwArgc); UNREFERENCED_PARAMETER(lpszArgv); //创建事件 ghSvcStopEvent=CreateEvent(NULL,TRUE,FALSE,NULL); if(ghSvcStopEvent==NULL) //创建事件失败,停止服务,返回 gSvcStatus.dwCurrentState=SERVICE_STOPPED; gSvcStatus.dwWaitHint=0; gSvcStatus.dwControlsAccepted=SERVICE_ACCEPT_STOP; gSvcStatus.dwCheckPoint=0; SetServiceStatus(gSvcStatusHandle,&gSvcStatus); return; //设置服务状态SERVICE_RUNNING gSvcStatus.dwCurrentState=SERVICE_RUNNING; gSvcStatus.dwWaitHint=0; gSvcStatus.dwControlsAccepted=SERVICE_ACCEPT_STOP; gSvcStatus.dwCheckPoint=0; SetServiceStatus(gSvcStatusHandle,&gSvcStatus); //设置断点 while (!IsDebuggerPresent()) Sleep(100); DebugBreak(); //创建信号量 hSemaphore=CreateSemaphore(NULL,MAX_THREAD_COUNT,MAX_THREAD_COUNT,TEXT("NAS_TEST_SEMAPHORE")); if(NULL==hSemaphore) return; //初始化关键区 InitializeCriticalSection(&cs); //处理请求 while(!m_bFinished) //进入关键区 EnterCriticalSection(&cs); while (!m_bFinished) if(WAIT_TIMEOUT==WaitForSingleObject(ghSvcStopEvent,100)) //这里处理你的线程逻辑 //每个线程启动的时候WaitForSingleObject占用一个信号量 //线程退出时ReleaseSemaphore释放信号量 LogEvent(TEXT("XXX is gonging down.")); m_bFinished = true; //退出关键区 LeaveCriticalSection(&cs); if (!m_bFinished) //等待线程0.2秒 Sleep(200); //等待所有线程结束 WaitForMultipleObjects(MAX_THREAD_COUNT, &hSemaphore, true, 10000L); //WaitForMultipleObjects(1,&hSemaphore,true,INFINITE); //释放信号量 CloseHandle(hSemaphore); //释放关键区 DeleteCriticalSection(&cs); return; //=================================================== //服务控制函数 void WINAPI XXX::SvcCtrlHandler(DWORD dwCtrl) switch(dwCtrl) case SERVICE_CONTROL_STOP: //设置服务状态SERVICE_ACCEPT_STOP pThis->gSvcStatus.dwCurrentState=SERVICE_STOP_PENDING; pThis->gSvcStatus.dwControlsAccepted=SERVICE_ACCEPT_STOP; pThis->gSvcStatus.dwCheckPoint=0; pThis->gSvcStatus.dwWaitHint=10000; SetServiceStatus(pThis->gSvcStatusHandle,&(pThis->gSvcStatus)); //触发事件 SetEvent(pThis->ghSvcStopEvent); break; case SERVICE_CONTROL_PAUSE: break; case SERVICE_CONTROL_CONTINUE: break; case SERVICE_CONTROL_INTERROGATE: break; case SERVICE_CONTROL_SHUTDOWN: break; default: pThis->LogEvent(TEXT("XXX: Bad Service Request!")); //=================================================== //在事件查看器中记录消息 void XXX::LogEvent(LPCTSTR lpMsg) HANDLE hEventSource; LPCTSTR lpszStrings[1]; lpszStrings[0]=lpMsg; //在“事件查看器->应用程序->信息”中进行记录 hEventSource=RegisterEventSource(NULL,lpServiceName); if(NULL!=hEventSource) ReportEvent(hEventSource,EVENTLOG_INFORMATION_TYPE,0,0,NULL,1,0,lpszStrings,NULL); DeregisterEventSource(hEventSource); //=================================================== //输出GetLastErr()信息 void XXX::Show_Me_Err() if(!m_bLog)return; DWORD dwErrNo; LPTSTR lpBuffer; dwErrNo=GetLastError(); FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER|FORMAT_MESSAGE_IGNORE_INSERTS|FORMAT_MESSAGE_FROM_SYSTEM, NULL,dwErrNo,LANG_NEUTRAL,(LPTSTR)&lpBuffer,0,NULL); MessageBox(NULL,lpBuffer,TEXT("XXX GetLastError"),MB_OK); LocalFree(lpBuffer); //===================================================