Skip to main content

How to use gdb in Ubuntu Terminal

Here's a practical, minimal guide for using GDB in Ubuntu terminal — from launching to setting breakpoints and navigating your code. 🧰 Step 1: Compile with Debug Symbols Use -g and disable optimizations ( -O0 preferred for debugging): bash Copy Edit g++ -g -O0 -o myprog myprog.cpp 🚀 Step 2: Launch GDB bash Copy Edit gdb ./myprog You'll see a (gdb) prompt. 🎯 Step 3: Set Breakpoints You can set breakpoints in three main ways : ✅ a. At a function gdb Copy Edit (gdb) break main ✅ b. At a specific file and line gdb Copy Edit (gdb) break myprog.cpp:42 ✅ c. At a method in a class gdb Copy Edit (gdb) break MyClass::doSomething If the symbol is mangled (C++), GDB usually demangles automatically, especially if compiled with -g . ▶️ Step 4: Run the Program gdb Copy Edit (gdb) run 🧭 Step 5: Navigate Command Meaning next or n Step over current line step or s Step into function call finish Run until current function returns continue or c Continue until...

Program to use gdbm database in C++ : chatGpt ans

 Here's a simple C++ program that demonstrates how to perform basic CRUD (Create, Read, Update, Delete) operations using GDBM (GNU Database Manager). This example will show how to store key-value pairs, retrieve them, update them, and delete them using the GDBM API.

C++ Program with GDBM

cpp
#include <gdbm.h> #include <iostream> #include <cstring> class GDBMWrapper { public: GDBMWrapper(const char* filename) { db = gdbm_open((char*)filename, 512, GDBM_WRCREAT, 0666, 0); if (!db) { throw std::runtime_error("Failed to open GDBM database"); } } ~GDBMWrapper() { if (db) { gdbm_close(db); } } void create(const std::string& key, const std::string& value) { datum db_key = { (char*)key.c_str(), (int)key.size() }; datum db_value = { (char*)value.c_str(), (int)value.size() }; if (gdbm_store(db, db_key, db_value, GDBM_INSERT) != 0) { throw std::runtime_error("Failed to insert record"); } } std::string read(const std::string& key) { datum db_key = { (char*)key.c_str(), (int)key.size() }; datum db_value = gdbm_fetch(db, db_key); if (!db_value.dptr) { throw std::runtime_error("Key not found"); } std::string value(db_value.dptr, db_value.dsize); free(db_value.dptr); return value; } void update(const std::string& key, const std::string& new_value) { datum db_key = { (char*)key.c_str(), (int)key.size() }; datum db_value = { (char*)new_value.c_str(), (int)new_value.size() }; if (gdbm_store(db, db_key, db_value, GDBM_REPLACE) != 0) { throw std::runtime_error("Failed to update record"); } } void remove(const std::string& key) { datum db_key = { (char*)key.c_str(), (int)key.size() }; if (gdbm_delete(db, db_key) != 0) { throw std::runtime_error("Failed to delete record"); } } private: GDBM_FILE db; }; int main() { try { GDBMWrapper db("example.db"); // Create db.create("name", "John Doe"); db.create("email", "johndoe@example.com"); // Read std::cout << "Name: " << db.read("name") << std::endl; std::cout << "Email: " << db.read("email") << std::endl; // Update db.update("email", "john.doe@newdomain.com"); std::cout << "Updated Email: " << db.read("email") << std::endl; // Delete db.remove("name"); std::cout << "Deleted 'name' record." << std::endl; // Try to read the deleted record (will throw an exception) try { std::cout << "Name: " << db.read("name") << std::endl; } catch (const std::exception& e) { std::cerr << "Error: " << e.what() << std::endl; } } catch (const std::exception& e) { std::cerr << "Error: " << e.what() << std::endl; return 1; } return 0; }

Explanation

  • GDBMWrapper Class:

    • This class wraps the GDBM functions to make it easier to manage database operations.
    • The constructor opens the database file, and the destructor ensures the database is closed properly.
    • The create, read, update, and remove methods handle the corresponding CRUD operations using the GDBM API.
  • CRUD Operations:

    • Create: Inserts a new key-value pair using gdbm_store with GDBM_INSERT.
    • Read: Retrieves a value for a given key using gdbm_fetch.
    • Update: Replaces the value for a given key using gdbm_store with GDBM_REPLACE.
    • Delete: Removes a key-value pair using gdbm_delete.
  • Error Handling:

    • The program uses exceptions to handle errors such as failing to open the database, trying to read a non-existent key, etc.

Compilation

To compile this program, you'll need to link against the GDBM library:

sh
g++ -o gdbm_example gdbm_example.cpp -lgdbm

Running the Program

Once compiled, you can run the program:

sh
./gdbm_example

This will perform the CRUD operations, demonstrating how to interact with a GDBM database using C++.

Comments

Popular posts from this blog

Ubuntu Notes: Set up autossh as systemd useful-reminder commands

 sudo vim /etc/systemd/system/permanentAutossh.service ======================================== [Unit] Description=Keeps a tunnel to myOciFreeNat open After=network-online.target [Service] User=<username> Environment="AUTOSSH_GATETIME=0" ExecStart=/usr/bin/autossh -M 0 -q -N -o "ServerAliveInterval 60" -o "ServerAliveCountMax 3" -L 4322:127.0.0.1:5432 -i /<ssh_private_key_file_absolute_path> <username>@<ip_address> -p 22 [Install] WantedBy=multi-user.target ======================================== sudo systemctl daemon-reload sudo systemctl enable permanentAutossh sudo systemctl start permanentAutossh ================== sudo systemctl daemon-reload sudo systemctl restart permanentAutossh sudo systemctl status permanentAutossh ====================== sudo systemctl stop permanentAutossh sudo systemctl disable permanentAutossh sudo rm /etc/systemd/system/permanentAutossh.service

syslog cpp programming: learning using chatGcp

  Introduction to Syslog C++ August 27, 2024 This conversation may reflect the link creator’s personalized data, which isn’t shared and can meaningfully change how the model responds. You said: I am new to syslog in cpp programming n just starting. Can you teach me ChatGPT said: ChatGPT Sure! syslog is a standard for logging system messages in Unix-like operating systems. It provides a way to send log messages to the system log, which can then be collected and analyzed by various tools. Here's a basic guide to get you started with syslog in C++: 1. Include the Necessary Header To use syslog , you need to include the syslog.h header: cpp Copy code # include <syslog.h> 2. Open the Connection to syslog Before sending log messages, you need to open a connection to the syslog system. This is typically done at the start of your program: cpp Copy code openlog ( "your_program_name" , LOG_PID | LOG_CONS, LOG_USER); "your_program_name" : A string representing ...

Ubuntu - C++ Notes: Install & update boost c++ library from git (may contain some error in process mentioned below)

 Boost C++ Library Installation from git in ubuntu: 1. create a directory named boost in your desired location and go to that directory mkdir boost;cd boost; 2. clone boost recursively from git using command git clone --recursive https://github.com/boostorg/boost.git 3. cd boost; sudo ./bootstrap.sh; 4. sudo ./b2; 5. sudo ./b2 install; DONE! --------------------------- Boost C++ Library Update Verson from git in Ubuntu: 1. go to gitDownloads/boost directory cd gitDownloads/boost; 2. git pull; 3. git submodule update --recursive; 4. cd boost; sudo ./bootstrap.sh; 5. sudo ./b2; 6. sudo ./b2 install; DONE!