防病毒软件将我的项目视为病毒

时间:2013-03-05 12:33:15

标签: c++ directx virus

美好的一天,我正在尝试为我的游戏创建框架,以便让我更轻松地编码。 我刚刚创建了添加对象的函数,但在创建了创建索引缓冲区的部分后,反病毒一直告诉我:“病毒发现:Win32:Evo-gen [Susp]”,我不知道为什么。 加载对象的函数代码:

HRESULT Framework::AddObject(Object* obj){
    std::vector<short> indices;
    std::vector<VertexType> vertices;
    obj->GetData(indices,vertices);
    IDirect3DVertexBuffer9* cVBuffer;
    IDirect3DIndexBuffer9* cIBuffer;
    int at=vertexBuffers.size();
    vertexBuffers.push_back(cVBuffer);
    indexBuffers.push_back(cIBuffer);
    unsigned int sOfVerts=vertices.size()*sizeof VertexType;
    unsigned int sOfIndices=indices.size()*sizeof(short);
    vCount.push_back(vertices.size());
    iCount.push_back(indices.size());
    HRESULT hr=device->GetDevice()->CreateVertexBuffer(sOfVerts,0,D3DFVF_VertexType,D3DPOOL_DEFAULT,&vertexBuffers[at],NULL);
    if(FAILED(hr)){
        EndWithError("Failed to load object",hr);
        return hr;
    } else {
        void* p_vertices;
        hr=vertexBuffers[at]->Lock(0,sOfVerts,(void**)&p_vertices,0);
        if(FAILED(hr)){
            EndWithError("Failed to lock buffer",hr);
            return hr;
        } else {
            applog<<"Successfuly created VertexBuffer for object "<<obj->GetClass()<<"["<<at<<"], vertices size: "<<sOfVerts<<", vertices count: "<<vertices.size()<<std::endl;
            memcpy(p_vertices,&vertices[0],sOfVerts);
            vertexBuffers[at]->Unlock();
        }
    }
    hr=device->GetDevice()->CreateIndexBuffer(sOfIndices,D3DUSAGE_WRITEONLY,D3DFMT_INDEX16,D3DPOOL_MANAGED,&indexBuffers[at],NULL);
    if(FAILED(hr)){
        EndWithError("Failed to load indices",hr);
        return hr;
    } else {
        void* p_indices;
        hr=indexBuffers[at]->Lock(0,sOfIndices,(void**)&p_indices,0);
        if(FAILED(hr)){
            EndWithError("Failed to lock index buffer",hr);
            return hr;
        } else {
            memcpy(p_indices,&indices[0],sOfIndices);
            indexBuffers[at]->Unlock();            
        }
    }
    return S_OK;
}
//device->GetDevice() - returns IDirect3DDevice9*
//obj->GetData(vector<int>& indices,vector<VertexType>& vertices); //gets vertices and indices
//obj->GetClass() const; - returns name of class of object, because Object is base class for another objects

Render函数如下所示:

void Framework::RenderFrame(){
    IDirect3DDevice9* dev=device->GetDevice();
    if(dev!=NULL){
        dev->Clear(0,NULL,D3DCLEAR_TARGET,D3DCOLOR_XRGB(32,32,64),1.0f,0);
        if(SUCCEEDED(dev->BeginScene())){
            for(unsigned int i=0;i<vertexBuffers.size();i++){
                IDirect3DDevice9* dev=device->GetDevice();
                dev->SetStreamSource( 0, vertexBuffers[i], 0, sizeof( VertexType ) );
                dev->SetFVF( D3DFVF_VertexType );
                dev->SetIndices(indexBuffers[i]);
                //dev->DrawPrimitive( D3DPT_TRIANGLELIST, 0, 1 );
                dev->DrawIndexedPrimitive(D3DPT_TRIANGLELIST,0,0,vCount[i],0,iCount[i]/3);
            }
            dev->EndScene();
        }
        dev->Present(NULL,NULL,NULL,NULL);
    }
}

有谁能告诉我是什么原因,为什么反病毒会将此病毒检测为病毒以及如何解决?

2 个答案:

答案 0 :(得分:2)

问题解决了。它几乎与索引缓冲区无关。 原因是由于2个未闭合的输出文件流。

无论如何,谢谢大家!我至少学到了一些新东西。

答案 1 :(得分:1)

防病毒软件使用“启发式”(用于“高级猜测”的奇特单词!)来检测“坏模式”。这听起来像是“误报”。

正确的解决方法是将问题报告给您的AV提供商,让他们发布新版本的“检测”,不会错误地检测有效代码。但是,除非你有一个非常好的AV提供商,否则你不太可能在接下来的几周内看到很多。

因此,ACTUAL解决方案通常是完全删除AV或用不同的产品替换它[顺便说一句,这两者都非常棘手,因为AV软件往往难以卸载 - 为了好当然,你不希望第一个病毒打到你的机器上卸载你的AV软件 - 这意味着有时AV卸载本身并没有卸载它应该的一切]。

有时只是关闭“实时扫描”就足够了。