OpenGL代码的分割错误

OpenGL代码的分割错误,opengl,Opengl,我的理解是,当我试图访问尚未解释的内存时,会出现分段错误。我似乎找不到错误。我已经测试了填充此代码之外的数组的过程,它运行良好,我认为错误一定与我分配的可用空间相似,但我分配了5倍所需的内存,但仍然出现了分段错误,因此我对这一错误非常不确定 #include <cmath> #include <iostream> #ifdef __APPLE__ # include <GL/glew.h> # include <GL/freegl

我的理解是,当我试图访问尚未解释的内存时,会出现分段错误。我似乎找不到错误。我已经测试了填充此代码之外的数组的过程,它运行良好,我认为错误一定与我分配的可用空间相似,但我分配了5倍所需的内存,但仍然出现了分段错误,因此我对这一错误非常不确定

 #include <cmath>
    #include <iostream>

    #ifdef __APPLE__
#  include <GL/glew.h>
#  include <GL/freeglut.h>
#  include <OpenGL/glext.h>
#else
#  include <GL/glew.h>
#  include <GL/freeglut.h>
#  include <GL/glext.h>
#pragma comment(lib, "glew32.lib") // Compiler directive to include the GLEW library.
#endif

#define PI 3.14159265



using namespace std;
/*we have to draw a circular lampshade... USING VERTEX ARRs*/
static float R1 = 10.0;
static float R2 = 8.0;
static float h = 10;
static float H = 10;
static float Xangle = 0.0, Yangle = 0.0, Zangle = 0.0; // Angles to
static int p = 6; // number of subdiviions of 2 * PI
static float *verts = NULL;
static unsigned int *inds = NULL;
//there are 2*(p+1) vertices
//but verts has size, 6*(p+1)
void fillVer(void)
{
    int i,j;
    i = -1;
    for(j = 0; j <= p; j++)
    {
    verts[i++] = R1 * cos(2.0 * PI * (j/p));
        verts[i++] = R1 * sin(2.0 * PI * (j/p));
        verts[i++] = h;
    }
    for(j = 0; j <= p; j++)
    {
    verts[i++] = R2 * cos(2.0 * PI * (j/p));
        verts[i++] = R2 * sin(2.0 * PI * (j/p));
        verts[i++] = H;
    }
}
// there are 2*(p+1) vertices
void fillInd(void)
{
int j = 0;
   for(int i = 0; i <= p; i++)
   {
       inds[j] = i;
       inds[j++] = i+(p+1);
   }
}

void setup(void)
{
    glClearColor(1.0, 1.0, 1.0, 0.0);
    glEnableClientState(GL_VERTEX_ARRAY);
}

void drawScene(void)
{
    glClear(GL_COLOR_BUFFER_BIT);
    glLoadIdentity();
    glColor3f(0,0,0);
    verts = new float[6*(p + 1)];
    inds = new unsigned int[2*(p+1)];
    fillVer();
    fillInd();
    glVertexPointer(3,GL_FLOAT,0,verts);
    glTranslatef(0.0, 0.0, -10.0);
    glRotatef(Zangle, 0.0, 0.0, 1.0);
    glRotatef(Yangle, 0.0, 1.0, 0.0);
    glRotatef(Xangle, 1.0, 0.0, 0.0);
    glPolygonMode(GL_FRONT_AND_BACK,GL_LINE);
    glDrawElements(GL_TRIANGLE_STRIP,2*(p+1),GL_UNSIGNED_INT, inds);
    glFlush();
}

void resize(int w, int h)
{
   glViewport(0, 0, w, h); 
   glMatrixMode(GL_PROJECTION);
   glLoadIdentity();
   glFrustum(-5.0, 5.0, -5.0, 5.0, 5.0, 100.0);
   glMatrixMode(GL_MODELVIEW);
}
void keyInput(unsigned char key, int x, int y)
{
   switch(key) 
   {
      case 27:
         exit(0);
         break;
      case 'x':
         Xangle += 5.0;
         if (Xangle > 360.0) Xangle -= 360.0;
         glutPostRedisplay();
         break;
      case 'X':
         Xangle -= 5.0;
         if (Xangle < 0.0) Xangle += 360.0;
         glutPostRedisplay();
         break;
      case 'y':
         Yangle += 5.0;
         if (Yangle > 360.0) Yangle -= 360.0;
         glutPostRedisplay();
         break;
      case 'Y':
         Yangle -= 5.0;
         if (Yangle < 0.0) Yangle += 360.0;
         glutPostRedisplay();
         break;
      case 'z':
         Zangle += 5.0;
         if (Zangle > 360.0) Zangle -= 360.0;
         glutPostRedisplay();
         break;
      case 'Z':
         Zangle -= 5.0;
         if (Zangle < 0.0) Zangle += 360.0;
         glutPostRedisplay();
         break;
      default:
         break;
   }
}

int main(int argc, char **argv) 
{
   glutInit(&argc, argv);

   glutInitContextVersion(2, 1); 
   glutInitContextProfile(GLUT_COMPATIBILITY_PROFILE); 

   glutInitDisplayMode(GLUT_SINGLE | GLUT_RGBA); 
   glutInitWindowSize(500, 500);
   glutInitWindowPosition(100, 100); 
   glutCreateWindow("hemisphereMultidraw.cpp");
   glutDisplayFunc(drawScene); 
   glutReshapeFunc(resize);
   glutKeyboardFunc(keyInput);
   glewExperimental = GL_TRUE; 
   glewInit(); 
   setup(); 
   glutMainLoop();  
}
应该是

2.0 * (float)(j/p) * PI 
与其他修改一样,该代码工作完美,并绘制了可爱的灯罩

找到一个原因:

int i,j;
i = -1;
for(j = 0; j <= p; j++)
{
    verts[i++] = R1 * cos(2.0 * PI * (j/p));
    verts[i++] = R1 * sin(2.0 * PI * (j/p));
    verts[i++] = h;
}
访问索引
-1
处的数组必然会导致分段错误。您的OpenGL代码看起来不错,但您肯定需要重写
fillVer()
fillInd()
函数

另请参见:找到一个原因:

int i,j;
i = -1;
for(j = 0; j <= p; j++)
{
    verts[i++] = R1 * cos(2.0 * PI * (j/p));
    verts[i++] = R1 * sin(2.0 * PI * (j/p));
    verts[i++] = h;
}
访问索引
-1
处的数组必然会导致分段错误。您的OpenGL代码看起来不错,但您肯定需要重写
fillVer()
fillInd()
函数


另请参见:

是否尝试使用调试器?尝试取消对空点的引用时可能会发生分段错误。尝试写入超过数组结尾时也可能发生分段错误。在
fillVer()
fillInd()
中放置一些打印语句,然后查看
j
的值。很抱歉,我正在Ubuntu中用gedit编写代码。我想我会花一些时间寻找一个像样的IDE,并尽快建立openGL。谢谢大家的建议!您是否尝试过使用调试器?当您尝试取消对空点的引用时,可能会发生分段错误。当您尝试写入超过数组结尾时,也可能会发生分段错误。在
fillVer()
fillInd()
中放置一些打印语句,然后查看
j
的值。很抱歉,我正在Ubuntu中用gedit编写代码。我想我会花一些时间寻找一个像样的IDE,并尽快建立openGL。谢谢大家的建议!最初我是从0开始的。我认为这就是问题所在,因为第一个顶点的“x”分量的索引是1而不是0。我显然忘记了增薪后/增薪前的概念。为了让它正常工作,我做了各种各样的尝试!最初我是从0开始的。我认为这就是问题所在,因为第一个顶点的“x”分量的索引是1而不是0。我显然忘记了增薪后/增薪前的概念。为了让它正常工作,我做了各种各样的尝试!
verts[-1] = R1 * cos(2.0 * PI * (j/p));