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

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

Войти
Регистрация
Восстановить пароль
 
user-men
22 / 22 / 8
Регистрация: 17.02.2014
Сообщений: 307
#1

Что делает memset в приведенном коде - C++

24.04.2014, 02:10. Просмотров 664. Ответов 10
Метки нет (Все метки)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
void replace(char* text, char* word)
{
    char* buffer = new char[512];
    strcpy(buffer, text);
    int pos = strstr(buffer, word) - buffer;
    while (pos > 0) {
        strcpy(buffer + pos, buffer + pos + strlen(word));
        pos = strstr(buffer, word) - buffer;
    }
    memset(text, 0, strlen(text));
    strcpy(text, buffer);
 
    delete[] buffer;
}
этот код принимает предложение и слово которое нужно удалить из предложения я весь код понял а зачем memset(text, 0, strlen(text)); не знаю объясните что он здеся делает
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
24.04.2014, 02:10
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Что делает memset в приведенном коде (C++):

Что делает (->) в данном коде - C++
TInfo Info; TElem *Elem = new TElem; Elem->Info.Ball = Info.Ball; Не нашел информации в сети, что делает эта...

Что делает эта строка в коде C++? - C++
Сейчас пишу только на C#, когда то писал на delphi. Нужно понять вот эту строку на С++: string szPrice =...

Что делает данная строка в коде - C++
Кто может объяснить что делает данная строка в коде, вот функция в которой она используется(корманная сортировка): int...

С++ напишите, что делает каждая строчка в этом коде?! - C++
#include "stdafx.h" #include <iostream> using namespace std; int sum (int a, int m) { int s=0; for (int i=0; i<a;...

Стандартные действия с числами: что делает >> и & в коде - C++
unsigned char bytes; bytes = ip & 0xFF; bytes = (ip >> 8) & 0xFF; bytes = (ip >> 16) & 0xFF; bytes = (ip >> 24) &...

С++ напишите, что делает каждая строчка в этом коде?! - C++
1. Постановка задачи. Написать перегруженные функции и основную программу, которая их вызывает: а) для вычитания целых...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
cooller
565 / 533 / 120
Регистрация: 25.12.2013
Сообщений: 1,456
24.04.2014, 02:15 #2
user-men, заполняет text нулями
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,924
Записей в блоге: 1
24.04.2014, 02:44 #3
Цитата Сообщение от user-men Посмотреть сообщение
char* buffer = new char[512];
* * strcpy(buffer, text);
и чё будет если строка длиннее 512ти? раз уж используешь динамические массивы, зачем выделять 512 байт ровно???
user-men
22 / 22 / 8
Регистрация: 17.02.2014
Сообщений: 307
24.04.2014, 03:58  [ТС] #4
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
зачем выделять 512 байт ровно???
вообще-то там можно писать гораздо меньше new char[50]; это просто чтобы перестраховаться что вся строка поместится
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,924
Записей в блоге: 1
24.04.2014, 04:53 #5
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от user-men Посмотреть сообщение
это просто чтобы перестраховаться что вся строка поместится
а чтобы совсем совсем перестраховаться можно писать
C++
1
 buffer = new char[strlen(text)+1];
разве нет? при чём же тогда тут 512?

Добавлено через 1 минуту
Цитата Сообщение от user-men Посмотреть сообщение
а зачем memset(text, 0, strlen(text)); не знаю объясните что он здеся делает
вообще-то, не очень то он не нужен. Он заполняет текст нулями, но ведь затем следующая инструкция сразу заполняет его полученной строкой!
user-men
22 / 22 / 8
Регистрация: 17.02.2014
Сообщений: 307
25.04.2014, 17:52  [ТС] #6
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
вообще-то, не очень то он не нужен. Он заполняет текст нулями, но ведь затем следующая инструкция сразу заполняет его полученной строкой!
сравни два скриншота в одном charchar а другому один раз char
так что memset(text, 0, strlen(text)); там нужен

если можешь помоги сделать так чтобы S[] определяло свое количество символов с запасом
char S[] = "const void int basic_iostream thewerego hypot char\0"; - выбивает Run-Time Check Failure #2 - Stack around the variable 'S' was corrupted.

спасибо за помощь

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
#include <iostream>
#include <conio.h>
using namespace std;
 
void replace(char* text, char* word)
{
    char* buffer = new char[strlen(text) + 1];
    strcpy(buffer, text);
    int pos = strstr(buffer, word) - buffer;
    while (pos > 0) {
        strcpy(buffer + pos, buffer + pos + strlen(word));
        pos = strstr(buffer, word) - buffer;
    }
    memset(text, 0, strlen(text));
    strcpy(text, buffer);
 
    delete[] buffer;
}
 
int main()
{
    int i = 0, k = 0, j, p[4], l = 0, b = 0, fj, f, d = 0, m = 0, g = 0, sum;
    char zavd4[20];
    char copy_replacement[20];
    char word[] = "const";
    char replacement[] = "were";
    char for_replacement[] = "are";
    char X[8];
    char S[216] = "array const void int basic_iostream thewerego hypot char\0";
    //1
    cout << S << "\n\n";
    replace(S, word);
    cout <<"1) "<< S << "\n";
    //2
    for (i = 0; i<strlen(S); i++)
    {
        k++;
        if (S[i]=='v')
        {
            break;
        }
    }
    for (i = strlen(S) - 1; i > k-2; i--)
    {
        S[i + 1] = S[i];
        S[i] = 'a';
        if (i == k-1)
        {
            S[i + 1] = 'r';
        }
    }
    cout <<"2) "<< S << "\n";
    //3
    for (j = 0,i = 10; j < 8; i++,j++)
    {
        X[j] = S[i];
        if (j == 7)
        {
            X[j] = '\0';
        }
    }
    cout <<"3) "<< X << "\n";
    //4
        p[1] = 0;
        for (i = 0; i < strlen(S); i++)
        {
            if (S[i] == ' ')
            {
                p[0] = i;
                m = 1;
            }
            if (m == 1)
            {
                for (j = p[1]; j < p[0]; j++)
                {
                    if (S[j] == replacement[0])
                    {
                        for (g = 0, b = j; b < j + strlen(replacement) + 1; b++, g++)
                        {
                            fj = j;
                            copy_replacement[g] = S[b];
                            if (b == j + strlen(replacement))
                            {
                                copy_replacement[g] = '\0';
                            }
                        }
                        for (g = strlen(S); g > j; g--)
                        {
                            S[g + strlen(for_replacement)] = S[g];
                        }
                    }
                }
 
                replace(S, copy_replacement);
 
                p[1] = p[0];
                m = 0;
            }
        }
        for (f = 0, g = fj; f < strlen(for_replacement) - 1; g++, f++)
        {
            S[g] = for_replacement[f];
        }
 
    cout <<"4) "<< S;
    _getch();
    return 0;
}
Миниатюры
Что делает memset в приведенном коде   Что делает memset в приведенном коде  
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,924
Записей в блоге: 1
25.04.2014, 17:58 #7
Цитата Сообщение от user-men Посмотреть сообщение
если можешь помоги сделать так чтобы S[] определяло свое количество символов с запасом
char S[] = "const void int basic_iostream thewerego hypot char\0"; - выбивает Run-Time Check Failure #2 - Stack around the variable 'S' was corrupted.
А чем не устраивает то, что уже есть? Т.Е.
C++
1
char S[216] = "array const void int basic_iostream thewerego hypot char\0";
user-men
22 / 22 / 8
Регистрация: 17.02.2014
Сообщений: 307
25.04.2014, 18:15  [ТС] #8
просто интересно как так можно сделает
DrOffset
7089 / 4230 / 950
Регистрация: 30.01.2014
Сообщений: 7,006
25.04.2014, 19:24 #9
Цитата Сообщение от user-men Посмотреть сообщение
так что memset(text, 0, strlen(text)); там нужен
Можно все-таки убрать и memset и new
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
void replace(char * text, char const * word)
{
    if(size_t wordLen = strlen(word))
    {
        for(char * p = text; (p = strstr(p, word));)
        {
            char * dst = p;
            char * src = p + wordLen;
            while((*dst++ = *src++));
            *dst = 0;
        }
    }
}
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,924
Записей в блоге: 1
25.04.2014, 23:03 #10
Цитата Сообщение от DrOffset Посмотреть сообщение
*dst = 0;
не требуется
DrOffset
7089 / 4230 / 950
Регистрация: 30.01.2014
Сообщений: 7,006
25.04.2014, 23:28 #11
Kuzia domovenok, да там вообще все тело цикла можно заменить на strcpy(p, p + wordLen);

Добавлено через 4 минуты
А, и да. Ноль там нужен, чтобы оставить совместимость с остальным его кодом. Чтобы не допустить поведения как на втором скрине. Автор сказал, что это неправильно. Смысл этого оставляю на его совести
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.04.2014, 23:28
Привет! Вот еще темы с ответами:

Объясните что именно делает функция даном коде - C++
Помогите пожалуйста. Я не могу понять что делает функция которая стоит вначале моего кода, точнее я немогу понять почему там k&lt;=N/2. Ниже...

Объясните что именно делает "x%d, y%d: " или что это в даном коде - C++
#include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; double rast(double x1, double y1, double x2, double y2) // Функція яка...

Что делает функция compare в коде и зачем она нужна в qsort - C++
Объясните, пожалуйста, что делает функция compare (17 строка) в данном случае и зачем она нужна в qsort? #include &lt;stdio.h&gt; ...

Не работает сортировка в приведенном коде - C++
что тут не так? #include &lt;iostream&gt; using namespace std; void en(int* a, int size); void ex(int* a, int size); void...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
25.04.2014, 23:28
Ответ Создать тему
Опции темы

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