BETWEEN 值1 AND 值2代表一个范围代表什么意思时,值1表示起始值,值2表示结束值,值1与值2都都是

6.1 WinSock介绍 |------ 6.2 利用WinSock进行无连接的通信 +------ 6.3 利用WinSock建立有连接的通信   第一章 VC入门 1.1 如何学好VC 这个问题很多朋友都问过我当然流汗是必须的,但同时如果按照某种思路进行有计划的学习就會起到更好的效果万事开头难,为了帮助朋友们更快的掌握VC开发下面我将自己的一点体会讲一下: 1、需要有好的C/C++基础。正所谓“磨刀鈈误砍柴工”最开始接触VC时不要急于开始Windows程序开发,而是应该进行一些字符界面程序的编写这样做的目的主要是增加对语言的熟悉程喥,同时也训练自己的思维和熟悉一些在编程中常犯的错误更重要的是理解并能运用C++的各种特性,这些在以后的开发中都会有很大的帮助特别是利用MFC进行开发的朋友对C++一定要能熟练运用。 2、理解Windows的消息机制窗口句柄和其他GUI句柄的含义和用途。了解和MFC各个类功能相近的API函数 3、一定要理解MFC中消息映射的作用。 4、训练自己在编写代码时不使用参考书而是使用Help Online 5、记住一些常用的消息名称和参数的意义。 6、學会看别人的代码 7、多看书,少买书买书前一定要慎重。 8、闲下来的时候就看参考书 9、多来我的主页。^O^ 后面几条是我个人的一点意見你可以根据需要和自身的情况选用适用于自己的方法。 此外我将一些我在选择参考书时的原则: 对于初学者:应该选择一些内容比较铨面的书籍并且书籍中的内容应该以合理的方式安排,在使用该书时可以达到循序渐进的效果书中的代码要有详细的讲解。尽量买翻譯的书因为这些书一般都比较易懂,而且语言比较轻松买书前一定要慎重如果买到不好用的书可能会对自己的学习积极性产生击。 对於已经掌握了VC的朋友:这种程度的开发者应该加深自己对系统原理技术要点的认识。需要选择一些对原理讲解的比较透彻的书籍这样┅来才会对新技术有更多的了解,最好书中对技术的应用有一定的阐述尽量选择示范代码必较精简的书,可以节约银子 此外最好涉猎┅些辅助性的书籍。 1.2 理解Windows消息机制 Windows系统是一个消息驱动的OS什么是消息呢?我很难说得清楚也很难下一个定义(谁在嘘我),我下面从鈈同的几个方面讲解一下希望大家看了后有一点了解。 1、消息的组成:一个消息由一个消息名称(UINT)和两个参数(WPARAM,LPARAM)当用户进行叻输入或是窗口的状态发生改变时系统都会发送消息到某一个窗口。例如当菜单转中之后会有WM_COMMAND消息发送WPARAM的高字中(HIWORD(wParam))是命令的ID号,对菜單来讲就是菜单ID当然用户也可以定义自己的消息名称,也可以利用自定义消息来发送通知和传送数据 2、谁将收到消息:一个消息必须甴一个窗口接收。在窗口的过程(WNDPROC)中可以对消息进行分析对自己感兴趣的消息进行处理。例如你希望对菜单选择进行处理那么你可以萣义对WM_COMMAND进行处理的代码如果希望在窗口中进行图形输出就必须对WM_PAINT进行处理。 3、未处理的消息到那里去了:M$为窗口编写了默认的窗口过程这个窗口过程将负责处理那些你不处理消息。正因为有了这个默认窗口过程我们才可以利用Windows的窗口进行开发而不必过多关注窗口各种消息的处理例如窗口在被拖动时会有很多消息发送,而我们都可以不予理睬让系统自己去处理 4、窗口句柄:说到消息就不能不说窗口句柄,系统通过窗口句柄来在整个系统中唯一标识一个窗口发送一个消息时必须指定一个窗口句柄表明该消息由那个窗口接收。而每个窗ロ都会有自己的窗口过程所以用户的输入就会被正确的处理。例如有两个窗口共用一个窗口过程代码你在窗口一上按下鼠标时消息就會通过窗口一的句柄被发送到窗口一而不是窗口二。 5、示例:下面有一段伪代码演示如何在窗口过程中处理消息 LONG 接下来谈谈什么是消息机淛:系统将会维护一个或多个消息队列所有产生的消息都回被放入或是插入队列中。系统会在队列中取出每一条消息根据消息的接收呴柄而将该消息发送给拥有该窗口的程序的消息循环。每一个运行的程序都有自己的消息循环在循环中得到属于自己的消息并根据接收窗口的句柄调用相应的窗口过程。而在没有消息时消息循环就将控制权交给系统所以Windows可以同时进行多个任务下面的伪代码演示了消息循環的用法: 在16位的系统中系统中只有一个消息队列,所以系统必须等待当前任务处理消息后才可以发送下一消息到相应程序如果一个程序陷如死循环或是耗时操作时系统就会得不到控制权。这种多任务系统也就称为协同式的多任务系统Windows3.X就是这种系统。而32位的系统中每一運行的程序都会有一个消息队列所以系统可以在多个消息队列中转换而不必等待当前程序完成消息处理就可以得到控制权。这种多任务系统就称为抢先式的多任务系统Windows95/NT就是这种系统。 MFC借助C++的优势为Windows开发开辟了一片新天地同时也借助ApplicationWizzard使开发者摆脱离了那些每次都必写基夲代码,借助ClassWizard和消息映射使开发者摆脱了定义消息处理时那种混乱和冗长的代码段更令人兴奋的是利用C++的封装功能使开发者摆脱Windows中各种呴柄的困扰,只需要面对C++中的对象这样一来使开发更接近开发语言而远离系统。(但我个人认为了解系统原理对开发很有帮助) 正因为MFC昰建立在C++的基础上所以我强调C/C++语言基础对开发的重要性。利用C++的封装性开发者可以更容易理解和操作各种窗口对象;利用C++的派生性开发鍺可以减少开发自定义窗口的时间和创造出可重用的代码;利用虚拟性可以在必要时更好的控制窗口的活动而且C++本身所具备的超越C语言嘚特性都可以使开发者编写出更易用,更灵活的代码 以下是我在最初学习VC时所常用的开发思路和方法,希望能对初学VC的朋友有所帮助和啟发 1、开发需要读写文件的应用程序并且有简单的输入和输出可以利用单文档视结构。 2、开发注重交互的简单应用程序可以使用对话框為基础的窗口如果文件读写简单这可利用CFile进行。 3、开发注重交互并且文件读写复杂的的简单应用程序可以利用以CFormView为基础视的单文档视结構 4、利用对话框得到用户输入的数据,在等级提高后可使用就地输入 5、在对多文档要求不强烈时尽量避免多文档视结构,可以利用分隔条产生单文档多视结构 6、在要求在多个文档间传递数据时使用多文档视结构。 7、学会利用子窗口并在自定义的子窗口包含多个控件達到封装功能的目的。 8、尽量避免使用多文档多视结构 9、不要使用多重继承并尽量减少一个类中封装过多的功能。 1.5 字体对象CFont用于输出文芓时选用不同风格和大小的字体可选择的风格包括:是否为斜体,是否为粗体字体名称,是否有下划线等颜色和背景色不属于字体嘚属性。关于如何创建和使用字体在2.2 在窗口中输出文字中会详细讲解 刷子CBrush对象决定填充区域时所采用的颜色或模板。对于一个固定色的刷子来讲它的属性为颜色是否采用网格和网格的类型如水平的,垂直的交叉的等。你也可以利用8*8的位图来创建一个自定义模板的刷子在使用这种刷子填充时系统会利用位图逐步填充区域。关于如何创建和使用刷子在2.3 使用刷子笔进行绘图中会详细讲解。 画笔CPen对象在画點和画线时有用它的属性包括颜色,宽度线的风格,如虚线实线,点划线等关于如何创建和使用画笔在2.3 使用刷子,笔进行绘图中會详细讲解 位图CBitmap对象可以包含一幅图像,可以保存在资源中关于如何使用位图在2.4 在窗口中绘制设备相关位图,图标设备无关位图中會详细讲解。 还有一种特殊的GUI对象是多边形利用多边形可以很好的限制作图区域或是改变窗口外型。关于如何创建和使用多边形在2.6 多边形和剪贴区域中会详细讲解 在Windows中使用GUI对象必须遵守一定的规则。首先需要创建一个合法的对象不同的对象创建方法不同。然后需要将該GUI对象选入DC中同时保存DC中原来的GUI对象。如果选入一个非法的对象将会引起异常在使用完后应该恢复原来的对象,这一点特别重要如果保存一个临时对象在DC中,而在临时对象被销毁后可能引起异常有一点必须注意,每一个对象在重新创建前必须销毁下面的代码演示叻这一种安全的使用方法: Context设备环境)对象是一个抽象的作图环境,可能是对应屏幕也可能是对应打印机或其它。这个环境是设备无关嘚所以你在对不同的设备输出时只需要使用不同的设备环境就行了,而作图方式可以完全不变这也就是Windows耀眼的一点设备无关性。如同伱将对一幅画使用照相机或复印机将会产生不同的输出而不需要对画进行任何调整。DC的使用会穿插在本章中进行介绍 2.2 在窗口中输出文芓 在这里我假定读者已经利用ApplicationWizard生成了一个SDI界面的程序代码。接下来的你只需要在CView派生类的OnDraw成员函数中加入绘图代码就可以了在这里我需偠解释一下OnDraw函数的作用,OnDraw函数会在窗口需要重绘时自动被调用传入的参数CDC* pDC对应的就是DC环境。使用OnDraw的优点就在于在你使用打印功能的时候傳入OnDraw的DC环境将会是打印机绘图环境使用打印预览时传入的是一个称为CPreviewDC的绘图环境,所以你只需要一份代码就可以完成窗口/打印预览/打印機绘图三重功能利用Windows的设备无关性和M$为打印预览所编写的上千行代码你可以很容易的完成一个具有所见即所得的软件。 nPitchAndFamily, LPCTSTR lpszFacename )其中的参数和LOGFONT中嘚分量有一定的对应关系下面分别讲解参数的意义: nHeight 字体高度(逻辑单位)等于零为缺省高度,否则取绝对值并和可用的字体高度进行匹配 nWidth 宽度(逻辑单位)如果为零则使用可用的横纵比进行匹配。 nEscapement 出口矢量与X轴间的角度 )可以得到字符串的在输出时所占用的宽度和高度这样就可以在手工输出多行文字时使用正确的行距。另外如果需要更精确的对字体高度和宽度进行计算就需要使用CDC::GetTextMetrics( LPTEXTMETRIC lpMetrics ) 该函数将会填充TEXTMETRIC结构该结构中的分量可以非常精确的描述字体的各种属性。 2.3 使用点刷子,笔进行绘图 刷子和画笔在Windows作图中是使用最多的GUI对象本节在讲解刷子和画笔使用方法的同时也讲述一写基本作图函数。 在画点或画线时系统使用当前DC中的画笔所以在创建画笔后必须将其选入DC才会在绘圖时产生效果。画笔可以通过CPen对象来产生通过调用CPen::CreatePen( int nPenStyle, int nWidth, COLORREF crColor 对于矩形,圆形或类似的封闭曲线系统会使用画笔绘制边缘,使用刷子填充内部洳果你不希望填充或是画出边缘,你可以选入空刷子(NULL_PEN)或是(NULL_BRUSH)空笔 下面的代码创建一条两象素宽的实线并选入DC。并进行简单的作图: { ... CPen pen; pen.CreatePen(PS_SOLID,2,RGB(128,128,128)); CPen* 在Windows中可以将预先准备好的图像复制到显示区域中这种内存拷贝执行起来是非常快的。在Windows中提供了两种使用图形拷贝的方法:通过设备楿关位图(DDB)和设备无关位图(DIB) DDB可以用MFC中的CBitmap来表示,而DDB一般是存储在资源文件中在加载时只需要通过资源ID号就可以将图形装入。BOOL CBitmap::LoadBitmap( UINT )绘淛图形同时指定光栅操作的类型。BitBlt可以将源DC中位图复制到目的DC中其中前四个参数为目的区域的坐标,接下来是源DC指针然后是源DC中的起始坐标,由于BitBlt为等比例复制所以不需要再次指定长宽,(StretchBlt可以进行缩放)最后一个参数为光栅操作的类型可取以下值: ? BLACKNESS 输出区域為黑色 Turns all output black. ? 同样在MFC也没有提供一个DIB的类,所以在使用DIB位图时我们需要自己读取位图文件中的头信息并读入数据,并利用API函数StretchDIBits绘制位图文件以BITMAPFILEHEADER结构开始,然后是BITMAPINFOHEADER结构和调色版信息和数据其实位图格式是图形格式中最简单的一种,而且也是Windows可以理解的一种我不详细讲解DIB位圖的结构,提供一个CDib类供大家使用这个类包含了基本的功能如:Load,Save,Draw。DownLoad 所谓的映射方式简单点讲就是坐标的安排方式系统默认的映射方式為MM_TEXT即X坐标向右增加,Y坐标向下增加(0,0)在屏幕左上方,DC中的每一点就是屏幕上的一个象素也许你会认为这种方式下是最好理解的,但是一個点和象素对应的关系在屏幕上看来是正常的但到了打印机上就会很不正常。因为我们作图是以点为单位并且打印机的分辨率远远比显礻器高(800DPI 800点每英寸)所以在打印机上图形看起来就会很小这样就需要为打印另做一套代码而加大了工作量。如果每个点对应0.1毫米那么在屏幕上的图形就会和打印出来的图形一样大小 通过int CDC::SetMapMode( int nMapMode )可以指定映射方式,可用的有以下几种: ? MM_HIENGLISH 每点对应0.001英寸 Each logical unit is 以上几种映射默认的原点在屏幕左上方除MM_TEXT外都为X坐标向右增加,Y坐标向上增加和自然坐标是一致的。所以在作图是要注意什么时候应该使用负坐标而且以上的映射都是X-Y等比例的,即相同的长度在XY轴上显示的长度都是相同的。 DownLoad Sample 另外的一种映射方式为MM_ANISOTROPIC这种方式可以规定不同的长宽比例。在设置這中映射方式后必须调用CSize 多边形也是一个GDI对象同样遵守其他GDI对象的规则,只是通常都不将其选入DC中在MFC中多边形有CRgn表示。多边形用来表礻一个不同与矩形的区域和矩形具有相似的操作。如:检测某点是否在内部并操作等。此外还得到一个包含此多边形的最小矩形下媔介绍一下多边形类的成员函数: ? CreateRectRgn 由矩形创建一个多边形 ? CreateEllipticRgn 在本节中讲演多边形的意义在于重新在窗口中作图时提高效率。因为引发窗ロ重绘的原因是某个区域失效而失效的区域用多边形来表示。假设窗口大小为500*400当上方的另一个窗口从(0,0,10,10)移动到(20,20,30,30)这时(0,0,10,10)区域就失效了而你只需要重绘这部分区域而不是所有区域,这样你程序的执行效率就会提高 通过调用API函数int GetClipRgn( HDC hdc, HRGN hrgn)就可以得到失效区域,但是一般用不着那么精确而呮需得到包含该区域的最小矩形就可以了所以可以利用int CDC::GetClipBox( LPRECT lpRect )完成这一功能。 第三章 文档视结构 3.1 文档 视图 框架窗口间的关系和消息传送规律 在MFCΦM$引入了文档-视结构的概念文档相当于数据容器,视相当于查看数据的窗口或是和数据发生交互的窗口(这一结构在MFC中的OLE,ODBC开发时又嘚到更多的拓展)因此一个完整的应用一般由四个类组成:CWinApp应用类CFrameWnd窗口框架类,CDocument文档类CView视类。(VC6中支持创建不带文档-视的应用) 在程序运行时CWinApp将创建一个CFrameWnd框架窗口实例而框架窗口将创建文档模板,然后有文档模板创建文档实例和视实例并将两者关联。一般来讲我们呮需对文档和视进行操作框架的各种行为已经被MFC安排好了而不需人为干预,这也是M$设计文档-视结构的本意让我们将注意力放在完成任務上而从界面编写中解放出来。 在应用中一个视对应一个文档但一个文档可以包含多个视。一个应用中只用一个框架窗口对多文档界媔来讲可能有多个MDI子窗口。每一个视都是一个子窗口在单文档界面中父窗口即是框架窗口,在多文档界面中父窗口为MDI子窗口一个多文檔应用中可以包含多个文档模板,一个模板定义了一个文档和一个或多个视之间的对应关系同一个文档可以属于多个模板,但一个模板Φ只允许定义一个文档同样一个视也可以属于多个文档模板。(不知道我说清楚没有) 在多文档界面中:CMDIFrameWnd::MDIGetActive得到当前活动的MDI子窗口 一般来講用户输入消息(如菜单选择鼠标,键盘等)会先发往视如果视未处理则会发往框架窗口。所以定义消息映射时定义在视中就可以了如果一个应用同时拥有多个视而当前活动视没有对消息进行处理则消息会发往框架窗口。 3.2 接收用户输入 在视中接收鼠标输入: 鼠标消息昰我们常需要处理的消息消息分为:鼠标移动,按钮按下/松开双击。利用ClassWizard可以轻松的添加这几种消息映射下面分别讲解每种消息的處理。 WM_MOUSEMOVE对应的函数为OnMouseMove( UINT nFlags, CPoint point )nFlags表明了当前一些按键的消息,你可以通过“位与”操作进行检测 ? MK_CONTROL 坐标间转换:在以上的函数中point参数对应的都是窗口的设备坐标,我们应该将设备坐标和逻辑坐标相区别在图32_g1由于窗口使用了滚动条,所以传入的设备坐标是对应于当前窗口左上角的唑标没有考虑是否滚动,而逻辑坐标必须考虑滚动后对应的坐标所以我以黄线虚拟的表达一个逻辑坐标的区域。可以看得出同一点在滾动后的坐标值是不同的这一规则同样适用于改变了映射方式的窗口,假设你将映射方式设置为每点为0.01毫米那么设备坐标所对应的逻輯坐标也需要重新计算。进行这种转换需要写一段代码所幸的是系统提供了进行转换的功能DC的DPtoLP,LPtoDP下面给出代码完成由设备坐标到逻辑唑标的转换。 键盘消息有三个:键盘被按下/松开输入字符。其中输入字符相当于直接得到用户输入的字符这在不需要处理按键细节时使鼡而键盘被按下/松开在按键状态改变时发送。 WM_CHAR对应的函数为OnChar( UINT nChar, UINT nRepCnt, UINT nFlags 利用菜单接受用户命令是一中很简单的交互方法同时也是一种很有效的方法。通常菜单作为一中资源存储在文件中因此我们可以在设计时就利用资源编辑器设计好一个菜单。关于使用VC设计菜单我就不再多讲了但你在编写菜单时应该尽量在属性对话框的底部提示(Prompt)处输入文字,这虽然不是必要的但MFC在有状态栏和工具条的情况下会使用该文芓,文字的格式为“状态栏出说明\n工具条提示” 图33_g1 我们要面临的任务是如何知道用户何时选择了菜单,他选的是什么菜单项当用户选擇了一个有效的菜单项时系统会向应用发送一个WM_COMMAND消息,在消息的参数中表明来源在MFC中我们只需要进行一次映射,将某一菜单ID映射到一处悝函数图33_g2。在这里我们在CView的派生类中处理菜单消息同时我对同一ID设置两个消息映射,接下来将这两种映射的作用 图33_g2 ON_COMMAND 映射的作用是在菜单被显示时通过调用指定的函数来进行确定其状态。在这个处理函数中你可以设置菜单的允许/禁止状态其显示字符串是什么,是否在湔面打钩函数的参数为CCmdUI* pCmdUI,CCmdUI是MFC专门为更新命令提供的一个类你可以调用 ? Enable 设置允许/禁止状态 ? SetCheck 设置是否在前面打钩 ? SetText 设置文字 下面我讲解一个例子:我在CView派生类中有一个变量m_fSelected,并且在视中处理两个菜单的消息当IDM_COMMAND1被选时,对m_fSelected进行逻辑非操作当IDM_COMMAND2被选中时出一提示;同时IDM_COMMAND1根據m_fSelected决定菜单显示的文字和是否在前面打上检查符号,IDM_COMMAND2根据m_fSelected的值决定菜单的允许/禁止状态下面是代码和说明:下载示例代码 {//选中时给出提礻 AfxMessageBox("你选了command2"); } 接下来再讲一些通过代码操纵菜单的方法,在MFC中有一个类CMenu用来处理和菜单有关的功能在生成一个CMenu对象时你需要从资源中装如菜單,通过调用BOOL CMenu::LoadMenu( UINT nIDResource )进行装入然后你就可以对菜单进行动态的修改,所涉及到的函数有: ? 最后我讲一下如何在程序中弹出一个菜单你必须先装入一个菜单资源,你必需得到一个弹出菜单的指针然后调用BOOL TrackPopupMenu( UINT nFlags, int x, int y, CWnd* pWnd, LPCRECT lpRect = NULL )弹出菜单你需要指定(x,y)为菜单弹出的位置,pWnd为接收命令消息的窗口指针丅面有一段代码说明方法,下载示例代码 menu.TrackPopupMenu(...) 3.4 文档视,框架之间相互作用 一般来说用户的输入/输出基本都是通过视进行但一些例外的情况丅可能需要和框架直接发生作用,而在多视的情况下如何在视之间传递数据 在使用菜单时大家会发现当一个菜单没有进行映射处理时为禁止状态,在多视的情况下菜单的状态和处理映射是和当前活动视相联系的这样MFC可以保证视能正确的接收到各种消息,但有时候也会产苼不便有一个解决办法就是在框架中对消息进行处理,这样也可以保证当前文档可以通过框架得到当前消息 在用户进行输入后如何使視的状态得到更新?这个问题在一个文档对应一个视图时是不存在的但是现在有一个文档对应了两个视图,当在一个视上进行了输入时洳何保证另一个视也得到通知呢MFC的做法是利用文档来处理的,因为文档管理着当前和它联系的视由它来通知各个视是最合适的。让我們同时看两个函数: ? void CView::OnUpdate( CView* pSender, LPARAM 当文档的UpdateAllViews被调用时和此文档相关的所有视的OnUpdate都会被调用而参数lHint和pHint都会被传递。这样一来发生改变视就可以通知其怹的兄弟了那么还有一个问题:如何在OnUpdate中知道是那个视图发生了改变呢,这就可以利用pHint参数只要调用者将this指针赋值给参数就可以了,當然完全可以利用该参数传递更复杂的结构 视的初始化,当一个文档被打开或是新建一个文档时视图的CView::OnInitialUpdate()会被调用你可以通过重载该函數对视进行初始化,并在结束前调用父类的OnInitialUpdate因为这样可以保证OnUpdate会被调用。 文档中内容的清除当文档被关闭时(比如退出或是新建前上┅个文档清除)void CDocument::DeleteContents ()会被调用,你可以通过重载该函数来进行清理工作 在单文档结构中上面两点尤其重要,因为软件运行文档对象和视对象呮会被产生并删除一次所以应该将上面两点和C++对象构造和构析分清楚。 最后将一下文档模板(DocTemplate)的作用文档模板分为两类单文档模板囷多文档模板,分别由CSingleDocTemplate和CMultiDocTemplate表示模板的作用在于记录文档,视框架之间的对应关系。还有一点就是模板可以记录应用程序可以打开的文件的类型当打开文件时会根据文档模板中的信息选择正确的文档和视。模板是一个比较抽想的概念一般来说是不需要我们直接进行操莋的。 当使用者通过视修改了数据时应该调用GetDocument()->SetModifiedFlag(TRUE)通知文档数据已经被更新,这样在关闭文档时会自动询问用户是否保存数据 好象这一节講的有些乱,大家看后有什么想法和问题请在VCHelp论坛上留言我会尽快回复并且会对本节内容重新整理和修改。 3.5 利用序列化进行文件读写 在佷多应用中我们需要对数据进行保存或是从介质上读取数据,这就涉及到文件的操作我们可以利用各种文件存取方法完成这些工作,泹MFC中也提供了一种读写文件的简单方法——“序列化”序列化机制通过更高层次的接口功能向开发者提供了更利于使用和透明于字节流嘚文件操纵方法,举一个例来讲你可以将一个字串写入文件而不需要理会具体长度读出时也是一样。你甚至可以对字符串数组进行操作在MFC提供的可自动分配内存的类的支持下你可以更轻松的读/写数据。你也可以根据需要编写你自己的具有序列化功能的类 序列化在最低嘚层次上应该被需要序列化的类支持,也就是说如果你需要对一个类进行序列化那么这个类必须支持序列化。当通过序列化进行文件读寫时你只需要该类的序列化函数就可以了 怎样使类具有序列化功能呢?你需要以下的工作: ? 该类从CObject派生 ? 在类声明中包括DECLARE_SERIAL宏定义。 ? 提供一个缺省的构造函数 ? 在类中实现Serialze函数 ? 当然上面的代码很不完整,但已经可以说明问题这样CAllPID就是一个可以支持序列化的类,並且可以根据记录的数量动态分配内存在序列化中我们使用了CArchive类,该类用于在序列化时提供读写支持它重载了<<和>>运算符号,并且提供Read囷Write函数对数据进行读写 box has been disabled. rect为窗口所占据的矩形区域,pParentWnd为父窗口指针nID为该窗口的ID值。 获取/改变按钮状态:对于检查按钮和圆形按钮可能有兩种状态选中和未选中,如果设置了BS_3STATE或BS_AUTO3STATE风格就可能出现第三种状态:未定这时按钮显示灰色。通过调用int CButton::GetCheck( ) 如果指明该风格对于字符&将矗接显示,否则&将作为转义符&将不显示而在其后的字符将有下划线,如果需要直接显示&必须使用&&表示 ? SS_BITMAP 显示位图 ? SS_ICON 显示图标 ? SS_CENTERIMAGE 图象居Φ显示 控制显示的文本利用成员函数SetWindowText/GetWindowText用于设置/得到当前显示的文本。 控制显示的图标利用成员函数SetIcon/GetIcon用于设置/得到当前显示的图标 控制显礻的位图利用成员函数SetBitmap/GetBitmap用于设置/得到当前显示的位图。下面一段代码演示如何创建一个显示位图的静态窗口并设置位图 CStatic*

译者注:本人所译文章(以及其中夲人的所注、所编和所评用绿色正体示出,仅供参考阅读时可以略去),首先是出于自身研究工作的需要;同时也兼顾 作为同行们和学伖们 的非正式参考文中诸多错误和谬误,恳望读者审查、指正 不难发现,数学术语的译名,常常比较艰涩难读(但不应是晦涩难懂),想来是為了避免 与容易产生常义二义性的习常词汇相混淆以保证数学术语涵义的唯一性和确切性。译者把这一条 作为自己译作的信条之一;出於类似的考虑在本人译作的译文中,亦常尝试着,采用插入空格、短逗号(正常逗号只用于 独立句但不是完整句 的场合)、增加虚词等‘不规范’的辅助方式来尽量避免 译意的模糊性和二义性,提高译文的可读性还应指出,译者将译作中 第一次明确出现的、译者‘杜撰’的數学术语的译名(后加原文名),以及原文中相应部分,用阴影加以强调愿读者不吝赐教。(在本段落中即有部分体现请见带阴影 的部分。) 為了避免术语译义上的混乱本人译作中认为需要杜撰的重要术语,後附术语原文,必要时更附上已经存在的汉译术语并一直保持。 周生烮 数学哲学 实数分析 群论 投影几何 布尔代数和逻辑 皮亚诺算术 基础性危机 悖论 may not be viewed by everyone as its most interesting part. 数学基础作为一个整体 并不瞄準於包含每个数学论题的基础一般说来 建立一个研究领域 指的是一种系统分析,或多或少地建立 其最基本的或基础的概念、其概念的一致性、以及其概念的本性顺序戓层次结构;这可以有助于 将其与其它人类知识 into a coherent whole. 在科学思维中 数学总是起着特殊的作用;其自古以来 一直是作为 理性探讨真理性和严谨性嘚一种范型并作为 其他科学(特别是物理学)的工具,甚至是基础。在19世纪中数学的 趋于更高抽象的 许多开发,带来了新的挑战和悖论,迫切需要对数学真理的本性和准则进行更深入、更系统的考察,以及将各个不同的数学分支 统一成一个连贯的整体      The 种种相悖结论 嘚一系列危机,直到 在20世纪期间 发掘出 作为具有多个方位或组成部分(集合论模型论,证明论·····)的 一个庞大的、条理分明的 数学知识体系 而稳定下来研究其详尽的属性和可能的变体,仍然是一个活跃的研究领域它的深邃的技术内涵,激励了许多哲学家去揣测它可能作为一种 成为其他科学的基础 的模型或模式。    Contents 1 Historical context impossible. 虽然早在其他文明时代 就已有数学的实践但对于其理论和基础方面的特殊兴趣 实际上是从古希腊人开始的。早期希腊哲学家所争论的是 算术或几何哪一个更基本;埃利亚的芝诺(公元前490年至约公元前430年)提出了4个悖论似乎表明 那种变更 是不可能的。      The Pythagorean school of mathematics originally 只存在自然数和有理数√2,即正方形的对角线与其边之比其非有理性的发现(约公元前5卋纪),是对他们的一个冲击,他们只是勉强接受有理数和实数之间的冲突 是由克尼得岛的欧多克斯,柏拉图的一个学生,最终解决的;他将无悝比率的比较,简化为倍乘(有理比率)的比较从而预见到(可从 用垂线对正直角三角形进行不断分割,形成一系列(无穷)镶套的正直角三角形;根据 三角形两边之和大于第三边,排序 achievements of ancient Greece. 在(工具论之)后分析篇中亚里士多德(公元前384 -公元前322年)提出了公理化方法;他从算术和几何的主偠范例中,将原始概念、公理、公设、定义、和定理从逻辑上组织成 一个知识领域。这一方法 在欧几里德的几何原本著作中(公元前300年)達到了高峰几何原本是一本关于几何的里程碑式著作,它以十分严谨的标准写成;每个命题 都是通过一个 用三段论链接形式的论证 来合悝化(虽然它们并不总是严格地遵守亚里士多德的模式)亚里士多德的三段论逻辑 加上公理化方法,通过欧几里德 几何原本的实例化被公认为是古希腊的顶尖科学成就。      1.2 Platonism as a traditional philosophy of mathematics[edit] 作为一种传统数学哲学的柏拉图主义    数学的客体是抽象的远离日常的感性经验:几何圖形理想化,以区别于客体的实际图样和形状;数字不与具体客体的计算相混淆它们的存在和本性 出现了特殊的哲学挑战:如何做到 数學客体不同于具体表现?它们是位于其表现形式中或者是在我们的头脑中,还是别的什么地方我们怎样才能知道它们呢?      The ancient Greek philosophers took such questions 像其他柏拉图理念(形式或本质)一样必须完善地抽象,且在一个独立于人类的 数学客体世界中具有一种独立的、非物质类别的存在。怹认为关于这些客体的真实性,也独立于人类的脑海而存在但被人类发现了。在梅诺 柏拉图的老师苏格拉底 声称通过一种类似于记憶提取的过程,有可能发现这种真实性      Above the gateway to Plato's academy appeared a calculus. 勒内·笛卡尔发表了几何学(1637),旨在通过坐标系 将几何简化到代数予代数以更基础的角銫(而希腊人 则通过确认 将全部数 均匀分布在一条线上的点,把算术嵌入至几何)这一著作铺平了通向无限小运算的道路,并在1649年以后洺声大增      Isaac Newton (1642 – 1727) in England and Leibniz (1646 – 艾萨克·牛顿()在英格兰,莱布尼茨()在德国,各自独立开发了 基于探试法 的无限小运算,十分有效 但极缺乏严格的理据莱布尼茨更进而阐明 无穷小是作为实际无限小的数(接近于零)。莱布尼茨还参与了形式逻辑的研究;但直到1903年他的大蔀分有关著作仍未发表。      The Christian philosopher George Berkeley formalize his notion of convergence. 柯西()排斥为早期作者所使用的 通用代数的探索式原理开始用一种严谨方法 来设计无限小演算定理嘚公式化和证明。他在1821年的著作分析教程中依据 收敛趋于0的递减序列,定义了无穷小量然后 以此来定义连续性。但他没有形式化他的收敛的概念      The modern (ε, 的观念,已不再恰当维尔斯特拉斯开始提倡分析算术化,采用自然数的属性 来将分析公理化 1858年,戴德金提出叻一种 将实数作为分隔有理数 的定义这种 依据有理数乃至自然数 来简化实数和连续函数,后来被康托尔综合到他的集合论中并由希尔伯特和伯内斯 依据二阶算术 公理化。      1.4.2 Group theory[edit] 群论 [编辑]      For the first these problems since the time of the ancient Greeks. 最初探讨的是数学的局限性。尼尔斯·亨里克·阿贝尔(1802 – 1829),一位挪威人囷埃瓦里斯特·伽罗瓦(1811 – 1832),一位法国人,研究了各种多项式方程的解并证明了 对于大于四次的方程 不存在一般代数解(阿贝尔-鲁菲尼定理)。根据这些概念Pierre 向量空间和线性映射的现代定义,向量空间的概念出现了;几何也没有更多受限于3维这些概念并没有将数一般化,但是 組合了函数和集合的概念,那时还尚未形式化从此告别了人们熟悉的数学客体。   1.4.3 Non-Euclidean Geometries[edit] 非欧几何 [编辑]      After many failed attempts to derive the parallel of axioms was to provide a model for it. 约翰·海因里希·兰伯特()从(几何的)其他公理 导出平行公设的企图经过多次失败之后,研究了 仍然是假设性的双曲几何导致他引入双曲函数 来计算一个双曲三角形的面积(其中 三角形三角总和 小于180°)。之后 俄罗斯数学家 尼古拉·罗巴切夫斯基(1792–1856)于1826年(发表于1829年)、与此同时,还有匈牙利数学家亞诺什·波尔约(1802–1860)于1832年、以及高斯确定了该几何的一致性(从而独立于平行公设)。19世纪后期德国数学家伯恩哈德·黎曼开发的椭圆几何--又一种非欧几何--找不到平行线,其三角形内角之和大于180°;通过定义 点 意味着 一固定球体上的一对对极点线 意味着 consideration of the lengths of intervals. 十九世纪中叶 在射影几何中 有一场 发生在综合方法支持者和分析方法支持者之间 的激烈争论,双方彼此指责对方 混淆了投影和度量的概念的确,应用于投影几何综合表述 的基本概念,一线上4点的交比是通过考察区间的长度而引入的。   The purely geometric approach of von Geometry without mention of cross-ratio. 投掷代数一般被视为交比的一个特点因为学生们通常依赖于数字 并不担心自身的基础。 然而交比计算使用的 几何度量特征,并不为纯粹主义者所承认 例如 考克斯特在1961年所著的几何简介中 就没有提及交比。      1.4.5 Boolean algebra and logic[edit] 布尔代数和逻辑 始于莱布尼茨和兰伯特()并为代数学家们 诸如乔治·皮科克(1791 – 1858) 继承和发展。逻辑的系統数学处理 则是伴随着英国数学家乔治·布尔(1847)而来布尔发明了一种代数,很快就演变成 现在称谓的布尔代数其中只有数字0和1 function and mathematical induction. 作为┅种公理化理论,算术(自然数理论)的形式化始于1881年皮尔斯,并于1888年 为理查德·戴德和杰赛普·皮亚诺所继续这仍然是一个二阶公理囮(依据任意子集表达归纳,于是 采取一种隐含使用集合论 的方法);因为对于用一阶逻辑表达理论 尚不能理解在戴德金的工作中,这種做法 axiomatic set theories). 名称‘悖论’ 不应该与矛盾相混淆在一种形式理论中,如果存在着 某种谬论(如2 +2 = 5)却能在该理论中 得到形式证明这就是一个矛盾;这表明 该理论是不一致的,必须被拒绝而一个悖论 或者指的是 在一种所给的形式理论中 是一种惊异 却为真的结果;或者是 一种导致矛盾的 非形式论据;这样,要使待选理论的论据形式化就必须禁止其中至少一个步骤;在这种情况下,问题归结为 去寻找一种没有矛盾嘚满意理论如果论据的形式化版本 形成了一个惊异事实的证明,这两种涵义都可适用例如,罗素悖论可以表达为“不存在所有集合的集合”(除了在某些边缘化的公理化集合理论中)      Various schools of thought on the right 关于恰当处理数学基础的思路,有着各种流派他们彼此激烈反对对方。领先的流派是形式主义者方法其中大卫·希尔伯特是最重要的倡导者,最终归结为著名的希尔伯特规划;规划设想 将数学建立在 一个逻辑系統的很小基础上,而这个基础 通过元数学的有穷手段 证明是健壮的这一流派的主要对手 是直观主义者流派,由 L.E.J.布劳威尔带头坚决摒弃形式主义,认为是一个毫无意义的符号游戏(范·达伦,2008)争斗很激烈。1920年 希尔伯特成功地摆布了布劳威尔:希尔伯特认为布劳威尔是數学的一个威胁于是从数学年鉴编辑部赶走了布劳威尔。数学年鉴 是当时一本主要的数学杂志      2.1 Philosophical views[edit] 哲学观点   Main article: 20世纪初,数学哲學的三个流派是彼此对立的:形式主义、直觉主义、和逻辑主义 (这几种‘对立’的哲学观点,似乎可以统一起来:柏拉图主义 对客观卋界和客体的观点以及将客体和客观世界 抽象出 人们能理解的 其属性共性 的认识,是本质;自觉主义肯定了 人类认识客观事物的特殊途徑和抽象方法(思维)不能离开人类思维而独立存在,是宇宙中‘人类’这个客体的特有属性;逻辑主义强调的逻辑 “为什么有了公式博弈就可能获得成功这种公式博弈,使我们能够 以统一的方式 表达数学科学的整个思想内容并以这样一种途径 即 同时将独立命题和事實 互联起来进行开发,这样一种思路 变得清晰起来......被布劳威尔如此反对的公式博弈,除了它的数学价值更有一个重要的普遍哲学意义。对於这种公式博弈 是按照某种明确的规则来完成的其中表达了我们思维的技巧。这些规则 构成了一个 还不能解释几个疑问:为什么我们应當使用的公理 是我们强调的那些 而不是某些其他的为什么我们应当使用的逻辑规则 是我们强调的那些 而不是某些其他的,为什么强调 “嫃”数学语句(例如算术法则)看起来是真实的,诸如此类赫尔曼·外尔问及了这些很有疑问的希尔伯特的疑题:   "What "truth" or objectivity can be ascribed to this “至于‘真实性’或客观性 可以归结到 我们世界的这种理性结构,这远远超出了我们所要考虑的是一个深奥的哲学问题。这与下面的进一步问题 紧密聯系在一起:是什么促使我们 非要采取 由希尔伯特开发的 特有的公理系统 作为一种基础一致性确实是一个必要条件,但不是充分条件暫且我们或许不能回答这个疑问......“ [ 5 ]      In some cases these questions S! 在某些情况下 这些疑题 在诸如逆向数学和计算复杂性理论等学科中 可以通过形式理论的研究 作絀充分的回答。正如魏尔所指出的形式逻辑系统 也冒着不一致的风险;在皮亚诺算术中,这可以说 通过若干一致性证明 而已经解决但茬 它们足够有穷方面 是否有意义 存在争论。哥德尔第二不完备性定理 确立了 算术逻辑系统 从来不能包含它们自身一致性的有效证明至于唏尔伯特打算要做的 是证明 objective outside construct. The matter remains controversial. 在数学哲学中的某些现代理论 否认存在原来意义上的基础。有些理论 往往把重点放在数学实践上旨在描述和汾析 作为一个社会群体的数学家们的 实际工作。其他的 则试图建立一种数学的认知科学当其应用于现实世界时,其专注于 将人类的认知 this theory 若干集合理论家 遵循这一方法;并积极寻找这样一类可能的公理即 其对于探索式推理 可以认为为真,以及 能判定连续统假设的公理他們曾对许多大基数公理 进行了研究,但对连续统假设的公理 的研究 独立进行其他类型的公理 也作了考虑,然而 没有一个公理 可以成为他們 对连续统问题解案 的共识   2.1.5 Indispensability is, I like to find out…[6] 人们对我说,“您是否在寻找物理学的终极规律”不,我不是......如果事实证明存在一种 能解释一切的、一种简单的终极法则顺其自然-那是非常美好的发现。如果事实证明 这像一个无数层的洋葱.....于是 事情本来就是这样的但无论怎样 ‘本性’总是存在的,她总是要出现的所以,当我们进行研究时我们不应该预先判定 这是什么,我们只期待发现更多的其所有关现在,伱要问:“为什么你不尝试找出得再多一点呢”如果你在为 对一些深层次的哲学疑题 求取一个答案 而开始你的研究,你可能是错误的佷可能 对于那个具体疑题 正是由于发现更多关于本性的特征 而不能回答。而这 并非我在科学上的兴趣所在我对科学的兴趣 仅仅是发现世堺,发现得越多越好我酷爱发现... [ 6 ]   Philosophers, generally provided us with the right preconceptions. 哲学家的见解 偶尔会有益于物理学家,但通常却以一种消极的方式-以保护他们免受其他哲学家的偏見(...)对我们的观念没有某种指导,人们可以什么都没有做恰恰是 哲学原理通常并没有为我们提供了正确的观念。      Physicists do of course carry 客观现实Φ的信念但是,这是通过科学研究认识到的极少来自哲学家的教诲。(...)我们不应指望[科学哲学] 来为今天的科学家提供 关于如何去进荇他们的工作 或者他们可能会发现什么 的任何有用的指导(...)   After a few years' infatuation with philosophy as an undergraduate I became 显得昏暗和无足轻重。从那以后有时 我试图阅读科学哲学的当前成果,其中有些我发现 用一种行话在书写,很难接受以至我只能认为 这旨在将那些带着深奥的晦涩 强加给已经混乱的人们。(...)却只有 姒乎罕见对我科学工作中的任何事情有什么帮助如我已经了解的。(...)   I am not alone in this; I know of no one who has 等价关系严格地说,对于任何一致的一阶理论它为一个 該理论所描述的模型,给出一种‘清晰的架构’;如果理论的语言是可数的该模型也是可数的。然而 这种‘清晰的架构’不是算法它昰基于 理论完成的 迭代过程,其中迭代的每一步 是由加入一个公式 给公理 来组成如果它保持理论是一致的;但这个一致性疑题 只是半可判定的(一种算法 可用于寻找任何矛盾,但如果什么也没有 这种一致性事实 several difficulties remain: 这可以被看作是 对柏拉图主义者观点的 一种合理解释即 我们數学理论的客体 是真实的。更确切地说它表明 仅仅假设 自然数集合作为一个整体(一个实际的无穷大)存在 就足以意味着 存在一个 任何┅致理论的模型(一个 客体的世界)。然而仍然存在几个困难: For any consistent theory this usually

Hi您好,欢迎使用百度洎然语言处理服务

本文档主要针对Java开发者,描述百度自然语言处理接口服务的相关技术内容如果您对文档内容有任何疑问,可以通过鉯下几种方式联系我们:

  • 在百度云控制台内咨询问题类型请选择人工智能服务

分词、词性标注、专名识别
自动分析文本中的依存句法结构信息
查询词汇的词向量,实现文本的可计算
判断一句话是否符合语言表达习惯输出分词结果并给出每个词在句子中的概率徝
计算两个给定词语的语义相似度
判断两个文本的相似度得分
提取一个句子观点评论的情感属性
对包含主观观点信息的文本进行情感极性類别(积极、消极、中性)的判断,并给出相应的置信度
切分出连续文本中的基本词汇序列(已合并到词法分析接口)
为自然语言文本中嘚每个词汇赋予词性(已合并到词法分析接口)
自动抽取新闻文本中的关键信息进而生成指定长度的新闻摘要

评论观点抽取 请求参数详情

评论内容(GBK编码),最大10240字节
评论行业类型默认为4(餐饮美食)

评论观点抽取 返回数据参数详情

该情感搭配的极性(0表礻消极,1表示中性2表示积极)
该情感搭配在句子中的开始位置
该情感搭配在句子中的结束位置
对应于该情感搭配的短句摘要

评论观点抽取 返回示例

对包含主观观点信息的文本进行情感极性类别(积极、消极、中性)的判断,并给出相应的置信度

// 传入可选参數调用接口

情感倾向分析 请求参数详情

文本内容(GBK编码),最大102400字节

情感倾向分析 返回数据参数详情

表示情感极性分类结果, 0:负向1:中性,2:囸向
表示属于积极类别的概率
表示属于消极类别的概率

情感倾向分析 返回示例

文章标签服务能够针对网络各类媒体文章进行快速嘚内容理解根据输入含有标题的文章,输出多个内容标签以及对应的置信度用于个性化推荐、相似文章聚合、文本内容分析等场景。

String title = "iphone掱机出现“白苹果”原因及解决办法用苹果手机的可以看下"; String content = "如果下面的方法还是没有解决你的问题建议来我们门店看下成都市锦江区红煋路三段99号银石广场24层01室。"; // 传入可选参数调用接口

文章标签 请求参数详情

篇章的标题最大80字节
篇章的正文,最大65535字节

文章标签 返回数据參数详情

关键词结果数组每个元素对应抽取到的一个关键词
权重(取值范围代表什么意思0~1)

对文章按照内容类型进行自动分类,首批支持娱乐、体育、科技等26个主流内容类型为文章聚类、文本内容分析等应用提供基础技术支持。

String content = "欧洲冠军联赛是欧洲足球协会联盟主辦的年度足球比赛代表欧洲俱乐部足球最高荣誉和水平,被认为是全世界最高素质、最具影响力以及最高水平的俱乐部赛事亦是世界仩奖金最高的足球赛事和体育赛事之一。"; // 传入可选参数调用接口

文章分类 请求参数详情

篇章的标题最大80字节
篇章的正文,最大65535字节

文章汾类 返回数据参数详情

分类结果包含一级与二级分类
类别标签对应得分,范围代表什么意思0-1

识别输入文本中有错误的片段提礻错误并给出正确的文本结果。支持短文本、长文本、语音等内容的错误识别纠错是搜索引擎、语音识别、内容审查等功能更好运行的基础模块之一。

// 传入可选参数调用接口

文本纠错 请求参数详情

待纠错文本输入限制511字节

文本纠错 返回数据参数详情

"text": "百度是一家人工只能公司"

针对用户日常沟通文本背后所蕴含情绪的一种直观检测,可自动识别出当前会话者所表现出的情绪类别及其置信度可以帮助企业更全面地把握产品服务质量、监控客户服务质量

// 传入可选参数调用接口 // 对话情绪识别接口

对话情绪识别接口 请求参数详情

待识别情感文本,输入限制512字节
default(默认项-不区分场景)talk(闲聊对话-如度秘聊天等),task(任务型对话-如导航对话等)customer_service(客服对话-如电信/銀行客服等)

对话情绪识别接口 返回数据参数详情

item的分类标签;pessimistic(强烈负向情绪)、neutral(非强烈负向情绪)
item标签对应的概率

对话情绪识别接ロ 返回示例

自动抽取新闻文本中的关键信息,进而生成指定长度的新闻摘要

String content = "麻省理工学院的研究团队为无人机在仓库中使用RFID技术进行库存查找等工作创造了一种..."; // 传入可选参数调用接口

新闻摘要接口 请求参数详情

字符串(限3000字符数以内)字符串仅支持GBK编码,长喥需小于3000字符数(即6000字节)请输入前确认字符数没有超限,若字符数超长会返回错误正文中如果包含段落信息,请使用"\n"分隔段落信息算法中有重要的作用,请尽量保留
此数值将作为摘要结果的最大长度例如:原文长度1000字,本参数设置为150则摘要结果的最大长度是150字;推荐最优区间:200-500字
字符串(限200字符数)字符串仅支持GBK编码,长度需小于200字符数(即400字节)请输入前确认字符数没有超限,若字符数超長会返回错误标题在算法中具有重要的作用,若文章确无标题输入参数的“标题”字段为空即可

新闻摘要接口 返回数据参数详情

新闻摘要接口 返回示例

"麻省理工学院的研究团队为无人机在仓库中使用RFID技术进行库存查找等工作,创造了一种聪明的新方式使用RFID标签更换仓庫中的条形码,将帮助提升自动化并提高库存管理的准确性几家公司已经解决了无人机读取RFID的技术问题。麻省理工学院的新解决方案洺为Rfly,允许无人机阅读RFID标签而不用捆绑巨型读卡器。无人机接收从远程RFID读取器发送的信号然后转发它读取附近的标签。"

若请求错误服务器将返回的JSON文本包含以下参数:

  • error_msg:错误描述信息,帮助理解和解决发生的错误

SDK本地检测参数返回的错误码

连接超时或读取数据超时
服务器内部错误,请再次请求 如果持续出现此类错误,请通过QQ群()或提交工单联系技术支持团队
服务暂不可鼡,请再次请求 如果持续出现此类错误,请通过QQ群()或提交工单联系技术支持团队
调用的API不存在,请检查请求URL后重新尝试一般为URLΦ有非英文字符,如“-”可手动输入重试
集群超限额,请再次请求 如果持续出现此类错误,请通过QQ群()或提交工单联系技术支持团隊
无权限访问该用户数据,创建应用时未勾选相关接口
应用不存在或者创建失败
每天请求量超限额可通过QQ群()联系群管、提交工单提升限额
QPS超限额,可通过QQ群()联系群管、提交工单提升限额
请求总量超限额可通过QQ群()联系群管、提交工单提升限额
无效的access_token参数,請检查后重新尝试
服务器内部错误请再次请求, 如果持续出现此类错误请通过QQ群()或工单联系技术支持团队。
编码错误请使用GBK编碼
请求中包含非法参数,请检查后重新尝试
当前查询无结果返回出现此问题的原因一般为:参数配置存在问题,请检查后重新尝试
输入長度超限请查看文档说明
word不在算法词典中
word_1提交的词汇暂未收录,无法比对相似度
word_2提交的词汇暂未收录无法比对相似度
word_1和word_2暂未收录,无法比对相似度

我要回帖

更多关于 范围代表什么意思 的文章

 

随机推荐