Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
UKOL
112 / 64 / 7
Регистрация: 17.11.2009
Сообщений: 258
#1

Ошибка при компиляции - C++

31.05.2011, 19:18. Просмотров 671. Ответов 1
Метки нет (Все метки)

Прошу вашей помощи, не могу запустить программу, как устранить ошибки?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// sllist.h
#ifndef SLLIST_H__
#define SLLIST_H__
 
#define SL_SUCCESS    0
#define SL_NO_MEM     1
#define SL_ZERO_SIZE  2
 
 
typedef struct SLLIST
{
  int Tag;
  struct SLLIST *Next;
  void *Object;
  size_t Size;
} SLLIST;
 
/* Add new item immediately after current item */
int SLAdd(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Add item to front of list. Care: if you pass
 * this function any node other than the first,
 * you will get Y-branches in your list:
 *
 *    oldroot-->-
 *               \  
 *                >->-passeditem-->-->--oldnext
 *               /
 *    newitem-->-
 *
 * This would be a Bad Thing.
 */
int SLFront(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Add new item right at the end of the list */
int SLAppend(SLLIST **Item, int Tag, void *Object, size_t Size);
 
/* Replace existing data */
int SLUpdate(SLLIST *Item, int NewTag, void *NewObject, size_t NewSize);
 
/* Retrieve data from this node */
void *SLGetData(SLLIST *Item, int *Tag, size_t *Size);
 
/* Delete this item. Returns pointer to
 * next item - caller's responsibility
 * to maintain list integrity.
 */
SLLIST *SLDeleteThis(SLLIST *Item);
 
/* Delete item immediately following
 * the one passed in. List integrity
 * maintained automatically.
 */
void SLDeleteNext(SLLIST *Item);
 
/* Destroy the entire list */
void SLDestroy(SLLIST **List);
 
/* Call func(Tag, ThisItem, Args) for each item */
int SLWalk(SLLIST *List, int(*Func)(int, void *, void *), void *Args);
 
#endif
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
// sllist.cpp
#include <stdlib.h>
#include <string.h>
#include <assert.h>
 
#include "sllist.h"
 
int SLAdd(SLLIST **Item,
          int Tag,
          void *Object,
          size_t Size)
{
  SLLIST *NewItem;
  int Result = SL_SUCCESS;
 
  assert(Item != NULL);
 
  if(Size > 0)
  {
    NewItem = malloc(sizeof *NewItem);
    if(NewItem != NULL)
    {
      NewItem->Tag    = Tag;
      NewItem->Size   = Size;
      NewItem->Object = malloc(Size);
 
      if(NewItem->Object != NULL)
      {
        memcpy(NewItem->Object, Object, Size);
        /* Handle empty list */
        if(NULL == *Item)
        {
          NewItem->Next = NULL;
          *Item = NewItem;
        }
        else /* Insert just after current item */
        {
          NewItem->Next = (*Item)->Next;
          (*Item)->Next = NewItem;
        }
      }
      else
      {
        free(NewItem);
        Result = SL_NO_MEM;
      }
    }
    else
    {
      Result = SL_NO_MEM;
    }
  }
  else
  {
    Result = SL_ZERO_SIZE;
  }
 
  return Result;
}
 
int SLFront(SLLIST **Item,
            int Tag,
            void *Object,
            size_t Size)
{
  int Result = SL_SUCCESS;
 
  SLLIST *p = NULL;
 
  assert(Item != NULL);
 
  Result = SLAdd(&p, Tag, Object, Size);
  if(SL_SUCCESS == Result)
  {
    p->Next = *Item;
    *Item = p;
  }
 
  return Result;
}
 
int SLAppend(SLLIST **Item,
             int Tag,
             void *Object,
             size_t Size)
{
  int Result = SL_SUCCESS;
  SLLIST *EndSeeker;
 
  assert(Item != NULL);
 
  if(NULL == *Item)
  {
    Result = SLAdd(Item, Tag, Object, Size);
  }
  else
  {
    EndSeeker = *Item;
    while(EndSeeker->Next != NULL)
    {
      EndSeeker = EndSeeker->Next;
    }
    Result = SLAdd(&EndSeeker, Tag, Object, Size);
  }
 
  return Result;
}
 
int SLUpdate(SLLIST *Item,
             int NewTag,
             void *NewObject,
             size_t NewSize)
{
  int Result = SL_SUCCESS;
 
  void *p;
  
  if(NewSize > 0)
  {
    p = realloc(Item->Object, NewSize);
    if(NULL != p)
    {
      Item->Object = p;
      memmove(Item->Object, NewObject, NewSize);
      Item->Tag = NewTag;
      Item->Size = NewSize;
    }
    else
    {
      Result = SL_NO_MEM;
    }
  }
  else
  {
    Result = SL_ZERO_SIZE;
  }
 
  return Result;
}
 
void *SLGetData(SLLIST *Item,
                int *Tag,
                size_t *Size)
{
  void *p = NULL;
 
  if(Item != NULL)
  {
    if(Tag != NULL)
    {
      *Tag = Item->Tag;
    }
    if(Size != NULL)
    {
      *Size = Item->Size;
    }
    p = Item->Object;
  }
 
  return p;
}
 
SLLIST *SLDeleteThis(SLLIST *Item)
{
  SLLIST *NextNode = NULL;
 
  if(Item != NULL)
  {
    NextNode = Item->Next;
 
    if(Item->Object != NULL)
    {
      free(Item->Object);
    }
    free(Item);
  }
 
  return NextNode;
}
 
void SLDeleteNext(SLLIST *Item)
{
  if(Item != NULL && Item->Next != NULL)
  {
    Item->Next = SLDeleteThis(Item->Next);
  }
}
 
void SLDestroy(SLLIST **List)
{
  SLLIST *Next;
  if(*List != NULL)
  {
    Next = *List;
    do
    {
      Next = SLDeleteThis(Next);
    } while(Next != NULL);
    *List = NULL;
  }
}
 
int SLWalk(SLLIST *List,
           int(*Func)(int, void *, void *),
           void *Args)
{
  SLLIST *ThisItem;
  int Result = 0;
 
  for(ThisItem = List;
      0 == Result && ThisItem != NULL;
      ThisItem = ThisItem->Next)
  {
    Result = (*Func)(ThisItem->Tag,
                     ThisItem->Object,
                     Args);
  }
 
  return Result;
}
 
/* end of sllist.c */
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
// sllistmn.cpp
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
 
#include "sllist.h"
 
typedef struct BOOK
{
  char Title[30];
  char Author[30];
} BOOK;
 
typedef struct FIELD_INFO
{
  int TitleWidth;
  int AuthWidth;
} FIELD_INFO;
 
int PrintBook(int Tag, void *Memory, void *Args)
{
 // BOOK *b = Memory;
 // FIELD_INFO *f = Args;
 
  assert(Tag == 0);
 
 // printf("Read %*s, by %*s\n",
  //       f->TitleWidth,
  //       b->Title,
   //      f->AuthWidth,
   //      b->Author);
 
  return 0;
}
 
 
int main(void)
{
  BOOK Book[] =
  {
    {"Expert C Programming", "van der Linden"},
    {"C Programming FAQs", "Summit"},
    {"C++ Programming Language", "Stroustrup"},
    {"Algorithms in C", "Sedgewick"},
    {"Teach Yourself BCB", "Reisdorph"},
    {"The Standard C Library", "Plauger"},
    {"C++ Unleashed", "Liberty"},
    {"Data Structures & Algorithms", "Lafore"},
    {"C Programming Language", "Kernighan & Ritchie"},
    {"Linux Unleashed", "Husain and Parker"},
    {"C Unleashed", "Heathfield & Kirby"},
    {"C : A Reference Manual", "Harbison & Steele"},
    {"DOS Programmers Reference", "Dettmann & Johnson"},
    {"C: How to Program", "Deitel & Deitel"},
    {"Builder Unleashed", "Calvert"},
    {"UNIX Unleashed", "Burk and Horvath"}
 
  };
 
  SLLIST *List = NULL;
  SLLIST *Removed = NULL;
 
  BOOK *Data;
 
  FIELD_INFO FldInfo = { 30, 30};
  size_t NumBooks = sizeof Book / sizeof Book[0];
 
  size_t i;
 
  /* Populate the list */
  for(i = 0; i < NumBooks; i++)
  {
    if(SL_SUCCESS !=
          SLFront(&List, 0, Book + i, sizeof(BOOK)))
    {
      puts("Couldn't allocate enough memory.");
      SLDestroy(&List);
      exit(EXIT_FAILURE);
    }
  }
 
  /* Print the list */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Remove one item */
  Removed = List;
 
  for(i = 0; i < NumBooks / 2; i++)
  {
    Removed = Removed->Next;
  }
 
  SLGetData(Removed->Next, NULL, NULL);
  printf("\nRemoving title %s\n\n", Data->Title);
  SLDeleteNext(Removed);
 
  /* Print the list again to confirm deletion */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Destroy the list */
  SLDestroy(&List);
 
  return 0;
}
Visual Studio 2010

Код программы из книги Хэзфилд и Кирби "Искусство програмиирования на С"
Вложения
Тип файла: zip saod.zip (2.60 Мб, 11 просмотров)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.05.2011, 19:18     Ошибка при компиляции
Посмотрите здесь:

Ошибка при компиляции - C++
Доброго времени суток. подскажите пожалуйста почему выходит ошибка? while (!DataModule5-&gt;GroupDestin-&gt;Eof) { ...

Ошибка при компиляции - C++
при компиляции #include&lt;iostream&gt; void main(void) { using namespace std; int number; int numb_row; int choice; ...

Ошибка при компиляции - C++
Я начинающий при компиляции в DEV-C++ выдаёт Compiler: Default compiler Building Makefile: &quot;C:\Dev-Cpp\Makefile.win&quot; Executing ...

Ошибка при компиляции - C++
IDE MSVS 2012. Почитал первые страницы книги, решил поэкспериментировать. При компиляции (F5) сначала пишет, что &quot;Следующий проект устарел...

Ошибка при компиляции - C++
При компиляции программы борланд выдает ошибку Unresolved external '_main' referenced from C:\PROGRAM...

Ошибка при компиляции - C++
Постоянно после компиляции,вне зависимости от кода, выходит эта ошибка на vs .в чем дело?

Ошибка при компиляции - C++
вот код #include &lt;stdio.h&gt; #include &quot;mpi.h&quot; int main(int argc, char* argv) { int ProcNum, ProcRank, RecvRank; MPI_Status...

Ошибка при компиляции(( - C++
Что делать??? в Project-&gt;Options -&gt;Directories/Conditionals все указано правильно.... что только не пробовала.... одно и тоже - не...

Ошибка при компиляции - C++
The &quot;BRCC32&quot; task failed unexpectedly. System.IO.IOException: Файл существует. at System.IO.__Error.WinIOError(Int32 errorCode,...

ошибка при компиляции - C++
при компиляции программы выскакивает такая ошибка 1&gt;.\Debug\?@&gt;3@0&lt;&lt;0 @01&gt;BK A&gt; A?8A:0&lt;8(AB5:).exe.intermediate.manifest : general...

Ошибка при компиляции - C++
Решил посмотреть что из себя предстовляет DirectX . Установил SDK набрал код из примера , компилирую ... и ошибка Сам код ...

Ошибка при компиляции - C++
Ошибки: строки 24, 25, 26, 31 Условие задачи: Дан текст, состоящий из предложений, разделяемых точками. Напишите программу,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
UKOL
112 / 64 / 7
Регистрация: 17.11.2009
Сообщений: 258
31.05.2011, 19:35  [ТС]     Ошибка при компиляции #2
Замена

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
 
#include "sllist.h"
 
typedef struct BOOK
{
  char Title[30];
  char Author[30];
} BOOK;
 
typedef struct FIELD_INFO
{
  int TitleWidth;
  int AuthWidth;
} FIELD_INFO;
 
int PrintBook(int Tag, void *Memory, void *Args)
{
  BOOK *b = Memory;
  FIELD_INFO *f = Args;
 
  assert(Tag == 0);
 
  printf("Read %*s, by %*s\n",
         f->TitleWidth,
         b->Title,
         f->AuthWidth,
         b->Author);
 
  return 0;
}
 
 
int main(void)
{
  BOOK Book[] =
  {
    {"Expert C Programming", "van der Linden"},
    {"C Programming FAQs", "Summit"},
    {"C++ Programming Language", "Stroustrup"},
    {"Algorithms in C", "Sedgewick"},
    {"Teach Yourself BCB", "Reisdorph"},
    {"The Standard C Library", "Plauger"},
    {"C++ Unleashed", "Liberty"},
    {"Data Structures & Algorithms", "Lafore"},
    {"C Programming Language", "Kernighan & Ritchie"},
    {"Linux Unleashed", "Husain and Parker"},
    {"C Unleashed", "Heathfield & Kirby"},
    {"C : A Reference Manual", "Harbison & Steele"},
    {"DOS Programmers Reference", "Dettmann & Johnson"},
    {"C: How to Program", "Deitel & Deitel"},
    {"Builder Unleashed", "Calvert"},
    {"UNIX Unleashed", "Burk and Horvath"}
 
  };
 
  SLLIST *List = NULL;
  SLLIST *Removed = NULL;
 
  BOOK *Data;
 
  FIELD_INFO FldInfo = { 30, 30};
  size_t NumBooks = sizeof Book / sizeof Book[0];
 
  size_t i;
 
  /* Populate the list */
  for(i = 0; i < NumBooks; i++)
  {
    if(SL_SUCCESS !=
          SLFront(&List, 0, Book + i, sizeof(BOOK)))
    {
      puts("Couldn't allocate enough memory.");
      SLDestroy(&List);
      exit(EXIT_FAILURE);
    }
  }
 
  /* Print the list */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Remove one item */
  Removed = List;
 
  for(i = 0; i < NumBooks / 2; i++)
  {
    Removed = Removed->Next;
  }
 
  Data = SLGetData(Removed->Next, NULL, NULL);
  printf("\nRemoving title %s\n\n", Data->Title);
  SLDeleteNext(Removed);
 
  /* Print the list again to confirm deletion */
  SLWalk(List, PrintBook, &FldInfo);
 
  /* Destroy the list */
  SLDestroy(&List);
 
  return 0;
}
Вложения
Тип файла: zip Saos2.zip (2.24 Мб, 7 просмотров)
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru