被保護メンバがpublicとして継承

#include < iostream >
using namespace std;

class base {
protected:
    int a, b;
public:
    void setab(int n, int m){ a = n; b = m; }
};

class derived : public base {
    int c;
public:
    void setc(int n) { c = n; }
    void showabc(){
        cout << a << ' ' << b << ' ' << c << '\n';
    }
};

int main()
{
    derived ob;
    
    ob.setab(1, 2);
    
    ob.setc(3);
    ob.showabc();
    return 0;
}

被保護メンバの使用

#include < iostream >
using namespace std;

class samp {
    int a;
protected:
    int b;
public:
    int c;
    samp(int n, int m){ a = n; b = m; }
    int geta() { return a; }
    int getb() { return b; }
};

int main()
{
    samp ob(10, 20);
    
    ob.c = 30;
    
    cout << ob.geta() << ' ';
    cout << ob.getb() << ' ' << ob.c << '\n';
    
    return 0;
}

基本クラスのアクセス制御

#include < iostream >
using namespace std;

class base {
    int x;
public:
    void setx(int n){ x = n; }
    void showx() { cout << x << '\n'; }
};

class derived : public base {
    int y;
public:
    void sety(int n){ y = n; }
    void showy() { cout << y << '\n'; }
};

int main()
{
    derived ob;
    
    ob.setx(10);
    ob.sety(20);
    ob.showx();
    ob.showy();
    
    return 0;
}

正規表現リファレンス


正規表現に関する本を貰ったので、移動時間で読み終えました。
「電話番号っぽい文字列」「◯◯から始まるキーワード」「〜でくくられた文字列」のような条件検索の際に活用。Unixではgrepがありますね。

例えば、a,b,cいずれかの文字にマッチするには
[a-c]と書きます。

郵便番号を表す正規表現ならば、
\b\d{3}(-\d{2}-\d{4})\b といった具合です。

本書では、Perl, java, php, ruby, javascriptを扱っています。
分量が少ないので、一度目を通しておくとよいかも。

正規表現ポケットリファレンス (POCKET REFERENCE)

+演算子のオーバーロード

#include < iostream >
using namespace std;

class coord {
    int x, y;
public:
    coord() { x=0; y=0; }
    coord(int i, int j){ x=i; y=j; }
    void get_xy(int &i, int &j){ i=x; j=y; }
    coord operator+(coord ob2);
    coord operator+(int i);
};

coord coord::operator+(coord ob2)
{
    coord temp;
    
    temp.x = x + ob2.x;
    temp.y = y + ob2.y;
    
    return temp;
}

coord coord::operator+(int i)
{
    coord temp;
    
    temp.x = x + i;
    temp.y = y + i;
    
    return temp;
}

int main()
{
    coord o1(10, 10), o2(5, 3), o3;
    int x, y;
    
    o3 = o1 + o2;
    o3.get_xy(x, y);
    cout << "(o1+o2) x: " << x << ", Y: " << y << "\n";
    
    o3 = o1 + 100;
    o3.get_xy(x, y);
    cout << "(o1+100) x: " << x << ", Y: " << y << "\n";
    
    return 0;
}

参照 swap

#include < iostream >
using namespace std;

void swapargs(int &x, int &y);

int main()
{
    int i, j;
    
    i = 10;
    j = 19;
    
    cout << "i: " << i << ", ";
    cout << "j: " << j << "\n";
    
    swapargs(i, j);
    
    cout << "after exchange: ";
    cout << "i: " << i << ", ";
    cout << "j: " << j << "\n";
    
    return 0;
}

void swapargs(int &x, int &y)
{
    int t;
    
    t = x;
    x = y;
    y = t;
}

整数の配列の割り当て

#include < iostream >
using namespace std;

int main()
{
    int *p;
    
    p = new int [5];
    
    if(!p) {
        cout << "memory set error\n";
        return 1;
    }
    
    int i;
    
    for(i=0; i<5; i++) p[i] = i;
    
    for(i=0; i<5; i++){
        cout << "integer type p[" << i << "]is: ";
        cout << p[i] << "\n";
    }
    
    delete [] p;
    
    return 0;
}

オブジェクトを動的に割り当て

#include 
using namespace std;

class samp {
    int i, j;
public:
    void set_ij(int a, int b){ i=a; j=b; }
    int get_product() { return i*j; }
};

int main()
{
    samp *p;
    
    p = new samp;
    if(!p){
        cout << "memory set error\n";
        return 1;
    }
    
    p->set_ij(4, 5);
    cout << "multiply is :" << p->get_product() << "\n";
    delete p;
    return 0;
}