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

Реализовать доступ к закрытой переменной - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как перегрузить операторы >> и << для структуры чтоб работалы итераторы? http://www.cyberforum.ru/cpp-beginners/thread742766.html
в файле двумерный массив вида 0 1 2 3 4 5 6 7 8 9 он считывает в двумерный вектор вот такой функцией if(!FileExists(FNAME_MATRIX)) { RED;cout<<"Файл "<<FNAME_MATRIX<<" не найден!\n";GRAY; exit(1); } v.clear();
C++ Перевод из string^ в char как это можно сделать? System::String^ numbron3= textBox11->Text; const char* str_ptr = numbron3.c_str(); Добавлено через 9 минут вываливается ошибка error C2228: выражение слева от ".c_str" должно представлять класс, структуру или объединение http://www.cyberforum.ru/cpp-beginners/thread742763.html
C++ Бинарное дерево. Мне нужно нерекурсивно удалить вершину с заданным значением ключа из бинарного дерева поиска.
Здравствуйте! Мне нужно нерекурсивно удалить вершину с заданным значением ключа из бинарного дерева поиска. Я набросал алгоритм удаления, только рекурсивный. Напишите пожалуйста как избавиться от рекурсии. Node* ReturnMaxLeft(Node* n) { if(!n) return NULL; Node* tmp=n; while(tmp->left) tmp=tmp->left; return tmp;
программа находит самое короткое слово в строке, как сделать, что бы она находила пять самых коротких слов в строке! Спасибо) C++
Здравствуйте! Подскажите пожалуйста! В данном отрывке программа находит самое короткое слово в строке, как сделать, что бы она находила пять самых коротких слов в строке! Спасибо) { int min = 100, count = 0, m = 0; int len = strlen(s); char st; char st2; for (int i = 0; i < len; ++i) { if (s != ' ')
C++ Создать шаблон функции, осуществляющей сортировку данных массива http://www.cyberforum.ru/cpp-beginners/thread742745.html
Создать шаблон функции, осуществляющей сортировку данных массива. Аргументами функции должны быть имя и размер массива. Продемонстрировать работу шаблона на данных различных типов, в том числе, на данных вновь созданного класса – вектор в пространстве с координатами х, у, z, определив для него операции сравнения. Умоляю, помогите написать.
C++ Даже не знаю как ее написать? (Сформировать массив по формуле, вычислить, реорганизовать) Суть в том, что у нас с начало идет 1 лаб/р: I. Ввести массив А II. Сформировать массив B по формуле: B, где B=sin(i+j) III. Вычислить массив C=A+B и вывести IV. Реорганизовать массив C так, чтобы max элемент в каждом столбце поменялся с первым элементом столбца. Вот что получилось #include <stdio.h> #include <conio.h> #include <math.h> подробнее

Показать сообщение отдельно
v.a.l.i.d
 Аватар для v.a.l.i.d
412 / 377 / 10
Регистрация: 21.09.2012
Сообщений: 913
23.12.2012, 13:53     Реализовать доступ к закрытой переменной
Цитата Сообщение от SummerRain Посмотреть сообщение
а если бы там было много переменных?
Цитата Сообщение от ~OhMyGodSoLong~ Посмотреть сообщение
надо как-то вытащить оттуда смещение этого поля, чтобы можно было по указателю до него добраться
вот что получилось для класса с тремя переменными:
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
#include "stdafx.h"
#include "iostream"
using namespace std;
 
class One
{
public:
    One(int i, float f, double d)       { x = i; y = f; z = d;}
    int GetX()      { return x; }
    float GetY()    { return y; }
    double GetZ()   { return z; }
private:
    int x;
    float y;
    double z;
};
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    One one(3, 4, 5);
    int *ptr_int       = (int *)&one;
    float *ptr_float   = (float *)(ptr_int + 1);
    double *ptr_double = (double *)(ptr_float + 1);
 
    cout << one.GetX() << " " << one.GetY() << " " << one.GetZ()  << endl;
    
    *ptr_int = 555;                 // изменение закрытых переменных
    *ptr_float = 666;
    *ptr_double = 777;
 
    cout << one.GetX() << " " << one.GetY() << " " << one.GetZ()  << endl;
 
    system("pause");
    return 0;
}
 
Текущее время: 15:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru