std::apply on std:: C++23 ਵਿੱਚ ਉਮੀਦ ਕੀਤੀ ਜਾਂਦੀ ਹੈ

C++

C++ 23 ਵਿੱਚ ਸਟ੍ਰੀਮਲਾਈਨਿੰਗ ਐਰਰ ਹੈਂਡਲਿੰਗ

ਅੱਜ ਦੇ C++ ਵਿਕਾਸ ਵਿੱਚ ਗਲਤੀਆਂ ਨੂੰ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਢੰਗ ਨਾਲ ਸੰਭਾਲਣਾ ਅਤੇ ਵਾਪਸੀ ਮੁੱਲਾਂ ਦਾ ਪ੍ਰਬੰਧਨ ਕਰਨਾ ਜ਼ਰੂਰੀ ਹੈ। {std::expected} ਕਿਸਮਾਂ ਨੂੰ ਵਾਪਸ ਕਰਨ ਵਾਲੇ ਫੰਕਸ਼ਨਾਂ ਨਾਲ ਕੰਮ ਕਰਨ ਦੀ ਖਾਸ ਵਿਧੀ ਵਿੱਚ ਬਹੁਤ ਸਾਰੀਆਂ ਜਾਂਚਾਂ ਅਤੇ ਗਲਤੀ ਹੈਂਡਲਿੰਗ ਕੋਡ ਸ਼ਾਮਲ ਹੁੰਦੇ ਹਨ, ਜੋ ਤਰਕ ਨੂੰ ਗੁੰਝਲਦਾਰ ਬਣਾ ਸਕਦੇ ਹਨ ਅਤੇ ਕੋਡ ਨੂੰ ਬਣਾਈ ਰੱਖਣਾ ਵਧੇਰੇ ਮੁਸ਼ਕਲ ਬਣਾ ਸਕਦੇ ਹਨ।

ਇਹ ਪੇਪਰ ਗਲਤੀ ਪ੍ਰਬੰਧਨ ਨੂੰ ਸਰਲ ਬਣਾਉਣ ਲਈ ਇੱਕ ਵਧੇਰੇ ਵਧੀਆ ਅਤੇ ਆਮ ਵਿਧੀ ਦੀ ਵਰਤੋਂ ਦੀ ਜਾਂਚ ਕਰਦਾ ਹੈ। ਬਾਇਲਰਪਲੇਟ ਕੋਡ ਨੂੰ ਘਟਾਉਣ ਅਤੇ ਪੜ੍ਹਨਯੋਗਤਾ ਵਿੱਚ ਸੁਧਾਰ ਕਰਨ ਲਈ, ਅਸੀਂ ਇੱਕ `magic_apply` ਵਿਧੀ ਬਣਾਉਣ ਦੀ ਜਾਂਚ ਕਰਾਂਗੇ ਜੋ ਬਹੁਤ ਸਾਰੇ {std::expected} ਮੁੱਲਾਂ ਦੇ ਨਤੀਜਿਆਂ ਨੂੰ ਇਕੱਠਾ ਕਰਦੀ ਹੈ ਅਤੇ ਉਹਨਾਂ ਨੂੰ ਕਿਸੇ ਹੋਰ ਫੰਕਸ਼ਨ ਵਿੱਚ ਭੇਜਦੀ ਹੈ।

ਹੁਕਮ ਵਰਣਨ
std::expected ਇੱਕ ਟੈਮਪਲੇਟ ਕਿਸਮ C++ ਵਿੱਚ ਗਲਤੀ ਨਾਲ ਨਜਿੱਠਣ ਲਈ ਵਰਤੀ ਜਾਂਦੀ ਹੈ ਜਿਸ ਵਿੱਚ ਮੁੱਲ ਅਤੇ ਤਰੁੱਟੀਆਂ ਦੋਵਾਂ ਨੂੰ ਸਟੋਰ ਕਰਨ ਦੀ ਸਮਰੱਥਾ ਹੁੰਦੀ ਹੈ।
std::unexpected ਜਦੋਂ std::expected ਨਾਲ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ, ਤਾਂ ਇੱਕ ਅਚਾਨਕ ਗਲਤੀ ਮੁੱਲ ਦਰਸਾਉਂਦਾ ਹੈ।
template<typename...> ਟੈਂਪਲੇਟ ਆਰਗੂਮੈਂਟਾਂ ਦੀ ਇੱਕ ਬੇਅੰਤ ਮਾਤਰਾ ਦੇ ਨਾਲ ਇੱਕ ਵਿਭਿੰਨ ਟੈਂਪਲੇਟ ਦੀ ਰੂਪਰੇਖਾ ਦਿੰਦਾ ਹੈ ਜੋ ਇਹ ਸਵੀਕਾਰ ਕਰ ਸਕਦਾ ਹੈ।
decltype ਟੈਂਪਲੇਟ ਪ੍ਰੋਗਰਾਮਿੰਗ ਵਿੱਚ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ, ਖਾਸ ਕਰਕੇ ਸਮੀਕਰਨ ਦੀ ਕਿਸਮ ਦਾ ਪਤਾ ਲਗਾਉਣ ਲਈ।
args.value() ਜੇਕਰ ਇੱਕ std:: ਉਮੀਦ ਕੀਤੀ ਵਸਤੂ ਦਾ ਇੱਕ ਮੁੱਲ ਹੈ, ਤਾਂ ਇਸ ਵਿੱਚ ਮੌਜੂਦ ਮੁੱਲ ਤੱਕ ਪਹੁੰਚ ਕਰਦਾ ਹੈ।
args.has_value() ਪੁਸ਼ਟੀ ਕਰਦਾ ਹੈ ਕਿ ਕੀ ਇੱਕ ਮੁੱਲ ਇੱਕ std::ਉਮੀਦ ਕੀਤੀ ਵਸਤੂ ਵਿੱਚ ਮੌਜੂਦ ਹੈ।
(... && args.has_value()) ਇਹ ਨਿਰਧਾਰਤ ਕਰਨ ਲਈ ਕਿ ਕੀ ਹਰੇਕ std::ਉਮੀਦ ਕੀਤੀ ਵਸਤੂ ਦੇ ਮੁੱਲ ਹਨ, ਸਮੀਕਰਨ ਫੋਲਡ ਕਰੋ।
func(args.value()...) ਵਿਧੀ ਫੰਕ ਨੂੰ ਕਾਲ ਕਰਨ ਲਈ std:: ਉਮੀਦ ਕੀਤੇ ਆਬਜੈਕਟ ਦੇ ਮੁੱਲਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦਾ ਹੈ।
return unexpected<Err>(args.error()...) std::ਉਮੀਦ ਕੀਤੀਆਂ ਵਸਤੂਆਂ ਦੀਆਂ ਤਰੁੱਟੀਆਂ ਵਾਲੀ ਇੱਕ ਅਣਕਿਆਸੀ ਗਲਤੀ ਵਾਪਸ ਕਰਦਾ ਹੈ।

ਵੇਰੀਏਬਲ ਟੈਂਪਲੇਟਸ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ਪ੍ਰਭਾਵੀ ਗਲਤੀ ਪ੍ਰਬੰਧਨ

ਦ ਟਾਈਪ ਦੀ ਵਰਤੋਂ ਸਕ੍ਰਿਪਟਾਂ ਵਿੱਚ C++ 23 ਵਿੱਚ ਗਲਤੀ ਦੇ ਪ੍ਰਬੰਧਨ ਨੂੰ ਆਸਾਨ ਬਣਾਉਣ ਲਈ ਕੀਤੀ ਜਾਂਦੀ ਹੈ। ਮੁੱਖ ਟੀਚਾ ਇੱਕ ਆਮ ਫੰਕਸ਼ਨ ਨੂੰ ਵਿਕਸਤ ਕਰਨਾ ਹੈ ਜਿਸਨੂੰ ਕਿਹਾ ਜਾਂਦਾ ਹੈ ਜੋ ਕਿ ਕਈ ਦੇ ਆਉਟਪੁੱਟ ਨੂੰ ਸੰਚਾਰਿਤ ਕਰ ਸਕਦਾ ਹੈ ਕਿਸੇ ਹੋਰ ਫੰਕਸ਼ਨ ਲਈ ਮੁੱਲ। ਅਜਿਹਾ ਕਰਨ ਨਾਲ, ਬਹੁਤ ਸਾਰੇ ਲੋਕਾਂ ਦੇ ਨਾਲ ਕੰਮ ਕਰਦੇ ਸਮੇਂ ਔਖੀ ਗਲਤੀ-ਜਾਂਚ ਜੋ ਆਮ ਤੌਰ 'ਤੇ ਜ਼ਰੂਰੀ ਹੁੰਦੀ ਹੈ std::expected ਮੁੱਲ ਘਟਾਏ ਜਾਂਦੇ ਹਨ। ਕਾਫ਼ੀ ਲਚਕਦਾਰ ਹੈ ਕਿਉਂਕਿ ਇਹ ਕਿਸੇ ਵੀ ਸੰਖਿਆ ਨੂੰ ਲੈ ਸਕਦਾ ਹੈ ਵਿਭਿੰਨ ਟੈਂਪਲੇਟਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਮਾਪਦੰਡ। ਕਿਸੇ ਦੀ ਸਮੱਗਰੀ ਦੇ ਨਾਲ ਫੰਕਸ਼ਨ ਨੂੰ ਕਾਲ ਕਰਨ ਤੋਂ ਪਹਿਲਾਂ ਵਸਤੂ, ਦਾ ਬੁਨਿਆਦੀ ਤਰਕ magic_apply ਇੱਕ ਗੁਣਾ ਸਮੀਕਰਨ ਵਰਤਦਾ ਹੈ, , ਸਭ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਵਸਤੂਆਂ ਦੇ ਵੈਧ ਮੁੱਲ ਹਨ।

ਇਸ ਵਿਚਾਰ ਨੂੰ ਸਧਾਰਨ ਕਿਸਮਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਪਹਿਲੀ ਲਿਪੀ ਉਦਾਹਰਨ ਵਿੱਚ ਦਰਸਾਇਆ ਗਿਆ ਹੈ ਜਿਵੇਂ ਕਿ ਅਤੇ . ਇਹ ਪਰਿਭਾਸ਼ਿਤ ਕਰਦਾ ਹੈ ਕਿ ਏ ਫੰਕਸ਼ਨ ਜੋ ਇੱਕ ਬੁਨਿਆਦੀ ਗਣਨਾ ਕਰਦਾ ਹੈ, ਅਤੇ getA ਅਤੇ ਫੰਕਸ਼ਨ ਜੋ ਵਾਪਸ ਆਉਂਦੇ ਹਨ ਕਿਸਮਾਂ। ਜੇਕਰ ਦੋਵਾਂ ਤੋਂ ਮੁੱਲ ਅਤੇ getB ਜਾਇਜ਼ ਹਨ, ਅਸੀਂ ਕਾਲ ਕਰ ਸਕਦੇ ਹਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ ; ਜੇਕਰ ਨਹੀਂ, ਤਾਂ ਗਲਤੀ ਦਾ ਪ੍ਰਚਾਰ ਕੀਤਾ ਜਾਂਦਾ ਹੈ। ਬੋਇਲਰਪਲੇਟ ਕੋਡ ਨੂੰ ਘਟਾ ਕੇ, ਇਹ ਵਿਧੀ ਪੜ੍ਹਨਯੋਗਤਾ ਅਤੇ ਸਾਂਭ-ਸੰਭਾਲ ਨੂੰ ਵਧਾਉਂਦੀ ਹੈ। ਇਸੇ ਤਰ੍ਹਾਂ ਦਾ ਵਿਚਾਰ ਦੂਜੀ ਲਿਪੀ ਵਿੱਚ ਪੇਸ਼ ਕੀਤਾ ਗਿਆ ਹੈ, ਪਰ ਪਹੁੰਚ ਦੀ ਬਹੁਪੱਖੀਤਾ ਨੂੰ ਉਜਾਗਰ ਕਰਨ ਲਈ, ਕਿਸਮਾਂ ਅਤੇ lambda functions ਵਰਤੇ ਜਾਂਦੇ ਹਨ।

`std::expected} ਨਾਲ C++ ਗਲਤੀ ਦੇ ਪ੍ਰਬੰਧਨ ਵਿੱਚ ਜਟਿਲਤਾ ਨੂੰ ਘਟਾਉਣਾ

ਵੇਰੀਏਡਿਕ ਟੈਂਪਲੇਟਸ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ C++23 ਸਕ੍ਰਿਪਟ

#include <expected>
#include <string>
#include <iostream>
#include <tuple>

using namespace std;

template<typename Func, typename... Args, typename Err>
auto magic_apply(Func func, const expected<Args, Err>&... args) -> expected<decltype(func(args.value()...)), Err> {
    if ((... && args.has_value())) {
        return func(args.value()...);
    } else {
        return unexpected<Err>(args.error()...);
    }
}

expected<int, string> getA(int x) {
    if (x > 0) return x;
    return unexpected<string>("Error in getA");
}

expected<double, string> getB(double y) {
    if (y > 0) return y;
    return unexpected<string>("Error in getB");
}

double compute_all(int a, double b) {
    return a + b;
}

int main() {
    auto result = magic_apply(compute_all, getA(10), getB(20.5));
    if (result) {
        cout << "Result: " << result.value() << endl;
    } else {
        cout << "Error: " << result.error() << endl;
    }
    return 0;
}

ਵੱਖ-ਵੱਖ {std::expected} ਨਤੀਜੇ C++23 ਮੁੱਲਾਂ ਨੂੰ ਜੋੜਨਾ

C++ 23 ਸਕ੍ਰਿਪਟ Lambda ਫੰਕਸ਼ਨਾਂ ਦੀ ਵਰਤੋਂ ਕਰਦੇ ਹੋਏ

#include <expected>
#include <string>
#include <iostream>

using namespace std;

template<typename Func, typename... Args, typename Err>
auto magic_apply(Func func, const expected<Args, Err>&... args) -> expected<decltype(func(args.value()...)), Err> {
    bool all_valid = (args.has_value() && ...);
    if (all_valid) {
        return func(args.value()...);
    } else {
        return unexpected<Err>(args.error()...);
    }
}

expected<string, string> getA(bool flag) {
    if (flag) return "SuccessA";
    return unexpected<string>("Failed A");
}

expected<string, string> getB(bool flag) {
    if (flag) return "SuccessB";
    return unexpected<string>("Failed B");
}

string compute_all(const string& a, const string& b) {
    return a + " and " + b;
}

int main() {
    auto result = magic_apply(compute_all, getA(true), getB(true));
    if (result) {
        cout << "Result: " << result.value() << endl;
    } else {
        cout << "Error: " << result.error() << endl;
    }
    return 0;
}

ਵੇਰੀਐਡਿਕ ਟੈਂਪਲੇਟਸ ਨਾਲ C++ ਐਰਰ ਹੈਂਡਲਿੰਗ ਵਿੱਚ ਸੁਧਾਰ ਕਰਨਾ

ਦੀ ਸਮਰੱਥਾ ਗੁੰਝਲਦਾਰ ਪ੍ਰਣਾਲੀਆਂ ਵਿੱਚ ਗਲਤੀ ਨਾਲ ਨਜਿੱਠਣ ਵਿੱਚ ਬਹੁਤ ਵਾਧਾ ਕਰਨਾ ਇਸ ਨੂੰ C++ ਵਿੱਚ ਲਗਾਉਣ ਦਾ ਇੱਕ ਹੋਰ ਮਹੱਤਵਪੂਰਨ ਲਾਭ ਹੈ। ਬਹੁਤ ਸਾਰੀਆਂ ਅਸਿੰਕਰੋਨਸ ਕਿਰਿਆਵਾਂ ਦੇ ਨਤੀਜਿਆਂ ਨੂੰ ਨਿਰਵਿਘਨ ਰੂਪ ਵਿੱਚ ਜੋੜਨਾ ਉਹਨਾਂ ਸਥਿਤੀਆਂ ਵਿੱਚ ਜ਼ਰੂਰੀ ਹੁੰਦਾ ਹੈ ਜਦੋਂ ਉਹ ਪੈਦਾ ਕਰਦੇ ਹਨ ਕਿਸਮਾਂ। ਕੋਡ ਨੂੰ ਸਰਲ ਬਣਾਉਣ ਤੋਂ ਇਲਾਵਾ, ਇਹ ਵਿਧੀ ਮਜ਼ਬੂਤ ​​​​ਗਲਤੀ ਪ੍ਰਬੰਧਨ ਦੀ ਗਾਰੰਟੀ ਦਿੰਦੀ ਹੈ। ਦੀ ਇੱਕ ਆਪਹੁਦਰੀ ਸੰਖਿਆ ਨੂੰ ਜੋੜ ਕੇ ਵਧੇਰੇ ਬਹੁਮੁਖੀ ਅਤੇ ਆਮ ਫੰਕਸ਼ਨਾਂ ਨੂੰ ਬਣਾਇਆ ਜਾ ਸਕਦਾ ਹੈ ਨਾਲ ਮੁੱਲ variadic templates.

ਦੀ ਬਹੁਪੱਖੀਤਾ ਇਸ ਨੂੰ ਉਹਨਾਂ ਫੰਕਸ਼ਨਾਂ ਨਾਲ ਵਰਤਣ ਦੀ ਇਜਾਜ਼ਤ ਦਿੰਦਾ ਹੈ ਜੋ ਕਈ ਤਰ੍ਹਾਂ ਦੀਆਂ ਦਲੀਲਾਂ ਵਿੱਚ ਲੈਂਦੇ ਹਨ। ਲਾਗੂ ਕਰਨ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਹੋਰ ਸਰਲ ਬਣਾਇਆ ਗਿਆ ਹੈ , ਜੋ ਕਿ ਸੰਯੁਕਤ ਫੰਕਸ਼ਨ ਕਾਲ ਦੀ ਵਾਪਸੀ ਕਿਸਮ ਨੂੰ ਆਪਣੇ ਆਪ ਹੀ ਘਟਾਉਂਦਾ ਹੈ। ਇਸ ਤੋਂ ਇਲਾਵਾ, ਇਸ ਤਕਨੀਕ ਨੂੰ ਵਿਲੀਨ ਸਮੇਤ ਹੋਰ ਗੁੰਝਲਦਾਰ ਕੰਮਾਂ ਦਾ ਪ੍ਰਬੰਧਨ ਕਰਨ ਲਈ ਵਿਸਤਾਰ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ ਹੋਰ ਗਲਤੀ ਕਿਸਮਾਂ ਵਾਲੇ ਮੁੱਲ ਜਾਂ ਉਹਨਾਂ ਨੂੰ ਫੰਕਸ਼ਨ ਵਿੱਚ ਭੇਜਣ ਤੋਂ ਪਹਿਲਾਂ ਮੁੱਲਾਂ ਨੂੰ ਬਦਲਣਾ। ਇਸਦੀ ਅਨੁਕੂਲਤਾ ਦੇ ਕਾਰਨ, ਪੈਟਰਨ ਨੂੰ ਸਿੱਧੇ ਗਣਨਾ ਤੋਂ ਲੈ ਕੇ ਗੁੰਝਲਦਾਰ ਓਪਰੇਸ਼ਨਾਂ ਤੱਕ, ਕਾਰਜਾਂ ਦੀ ਇੱਕ ਵਿਸ਼ਾਲ ਸ਼੍ਰੇਣੀ ਲਈ ਵਰਤਿਆ ਜਾ ਸਕਦਾ ਹੈ।

ਵੇਰੀਐਡਿਕ ਟੈਂਪਲੇਟਸ ਅਤੇ std::expected ਬਾਰੇ ਅਕਸਰ ਪੁੱਛੇ ਜਾਂਦੇ ਸਵਾਲ

  1. ਕੀ ਹੈ ?
  2. ਇਹ ਇੱਕ C++ ਟੈਂਪਲੇਟ ਕਿਸਮ ਹੈ ਜੋ ਇੱਕ ਗਲਤੀ ਜਾਂ ਇੱਕ ਵੈਧ ਮੁੱਲ ਰੱਖ ਸਕਦੀ ਹੈ ਅਤੇ ਗਲਤੀ ਪ੍ਰਬੰਧਨ ਲਈ ਵਰਤੀ ਜਾਂਦੀ ਹੈ।
  3. ਕਿਵੇਂ ਕਰਦਾ ਹੈ ਕੰਮ?
  4. ਇਹ ਅਨੇਕ ਨਤੀਜਿਆਂ ਨੂੰ ਜੋੜ ਕੇ ਵਾਰ-ਵਾਰ ਗਲਤੀ ਜਾਂਚਾਂ ਦੀ ਜ਼ਰੂਰਤ ਨੂੰ ਖਤਮ ਕਰਦਾ ਹੈ ਮੁੱਲ ਅਤੇ ਉਹਨਾਂ ਨੂੰ ਇੱਕ ਫੰਕਸ਼ਨ ਵਿੱਚ ਪਾਸ ਕਰਨਾ.
  5. ਵਿਭਿੰਨ ਟੈਂਪਲੇਟਸ ਕੀ ਹਨ?
  6. ਵੇਰੀਏਬਲ ਟੈਂਪਲੇਟ ਫੰਕਸ਼ਨ ਡਿਜ਼ਾਇਨ ਵਿੱਚ ਪੈਰਾਮੀਟਰਾਂ ਦੀ ਇੱਕ ਮਨਮਾਨੀ ਸੰਖਿਆ ਨੂੰ ਸਵੀਕਾਰ ਕਰਨ ਲਈ ਫੰਕਸ਼ਨ ਨੂੰ ਸਮਰੱਥ ਬਣਾ ਕੇ ਵੱਡੀ ਆਜ਼ਾਦੀ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਦੇ ਹਨ।
  7. ਕਿਉਂ ਵਰਤੋ ਵਿੱਚ ?
  8. ਦੇ ਮੁੱਲਾਂ ਦੀ ਵਰਤੋਂ ਕਰਨਾ ਆਬਜੈਕਟਸ ਨੂੰ ਸਵੈਚਲਿਤ ਤੌਰ 'ਤੇ ਕਾਲ ਕੀਤੇ ਜਾਣ ਵਾਲੇ ਫੰਕਸ਼ਨ ਦੀ ਵਾਪਸੀ ਕਿਸਮ ਦਾ ਪਤਾ ਲਗਾਉਣ ਲਈ।
  9. ਹੈ ਵੱਖ ਵੱਖ ਗਲਤੀ ਕਿਸਮਾਂ ਨੂੰ ਸੰਭਾਲਣ ਦੇ ਸਮਰੱਥ?
  10. ਹਾਂ, ਇਸ ਨਾਲ ਕੰਮ ਕੀਤਾ ਜਾ ਸਕਦਾ ਹੈ ਕੁਝ ਟਵੀਕਸ ਦੇ ਨਾਲ ਕਈ ਤਰ੍ਹਾਂ ਦੀਆਂ ਗਲਤੀਆਂ ਵਾਲੇ ਮੁੱਲ।
  11. ਕੀ ਫਾਇਦੇ ਵਰਤਦਾ ਹੈ ਪੇਸ਼ਕਸ਼?
  12. ਗਲਤੀਆਂ ਨੂੰ ਸੰਭਾਲਣ ਵੇਲੇ, ਇਹ ਅਪਵਾਦਾਂ ਜਾਂ ਰਿਟਰਨ ਕੋਡਾਂ ਵਰਗੀਆਂ ਹੋਰ ਰਵਾਇਤੀ ਤਕਨੀਕਾਂ ਨਾਲੋਂ ਵਧੇਰੇ ਭਾਵਪੂਰਤ ਅਤੇ ਸਾਫ਼-ਸੁਥਰੀ ਪਹੁੰਚ ਦੀ ਪੇਸ਼ਕਸ਼ ਕਰਦਾ ਹੈ।
  13. ਹੈ ਦਾ ਹਿੱਸਾ ?
  14. ਇਸ ਦੇ ਨਾਲ , ਅਸਲ ਵਿੱਚ, ਇੱਕ ਗਲਤ ਮੁੱਲ ਨੂੰ ਦਰਸਾਉਂਦਾ ਹੈ।
  15. ਕੀ ਅਸਿੰਕ੍ਰੋਨਸ ਐਕਸ਼ਨ ਦੀ ਵਰਤੋਂ ਕੀਤੀ ਜਾ ਸਕਦੀ ਹੈ ?
  16. ਇਹ ਅਸਲ ਵਿੱਚ ਸੰਭਾਲਣ ਲਈ ਅਨੁਕੂਲ ਹੈ ਅਸਿੰਕ੍ਰੋਨਸ ਓਪਰੇਸ਼ਨਾਂ ਦੁਆਰਾ ਵਾਪਸ ਕੀਤੇ ਮੁੱਲ।
  17. ਇੱਕ ਫੋਲਡ ਸਮੀਕਰਨ ਕੀ ਹੈ?
  18. ਇੱਥੇ, C++ ਦੀ ਵਿਸ਼ੇਸ਼ਤਾ ਨੂੰ ਫੋਲਡ ਸਮੀਕਰਨ ਕਿਹਾ ਜਾਂਦਾ ਹੈ, ਇਹ ਜਾਂਚ ਕਰਨ ਲਈ ਵਰਤਿਆ ਜਾਂਦਾ ਹੈ ਕਿ ਕੀ ਸਭ ਵਸਤੂਆਂ ਵਿੱਚ ਇੱਕ ਸਧਾਰਨ ਤਰੀਕੇ ਨਾਲ ਵੈਧ ਮੁੱਲ ਸ਼ਾਮਲ ਹੁੰਦੇ ਹਨ।

C++ 23 ਵਿੱਚ, ਮਲਟੀਪਲ std::ਇੱਛਤ ਮੁੱਲਾਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਇੱਕ ਆਮ ਫੰਕਸ਼ਨ ਨੂੰ ਲਾਗੂ ਕਰਨਾ ਕੋਡ ਪੜ੍ਹਨਯੋਗਤਾ ਵਿੱਚ ਬਹੁਤ ਸੁਧਾਰ ਕਰਦਾ ਹੈ ਅਤੇ ਗਲਤੀ ਨੂੰ ਸੰਭਾਲਣ ਨੂੰ ਬਹੁਤ ਸਰਲ ਬਣਾਉਂਦਾ ਹੈ। ਮੈਜਿਕ_ਐਪਲਾਈ ਫੰਕਸ਼ਨ ਬੋਇਲਰਪਲੇਟ ਕੋਡ ਨੂੰ ਘਟਾਉਂਦਾ ਹੈ ਅਤੇ ਪ੍ਰਕਿਰਿਆ ਕਰਨ ਤੋਂ ਪਹਿਲਾਂ ਸਾਰੇ ਅਨੁਮਾਨਿਤ ਮੁੱਲ ਸਹੀ ਹੋਣ ਨੂੰ ਯਕੀਨੀ ਬਣਾਉਣ ਲਈ ਵਿਭਿੰਨ ਟੈਂਪਲੇਟਾਂ ਦੀ ਵਰਤੋਂ ਕਰਕੇ ਰੱਖ-ਰਖਾਅ ਨੂੰ ਵਧਾਉਂਦਾ ਹੈ। ਇਹ ਵਿਧੀ ਇੱਕ ਲਚਕਦਾਰ ਹੱਲ ਪੇਸ਼ ਕਰਦੀ ਹੈ ਜੋ ਵੱਖ-ਵੱਖ ਸਥਿਤੀਆਂ ਵਿੱਚ ਲਾਗੂ ਕੀਤੀ ਜਾ ਸਕਦੀ ਹੈ ਅਤੇ ਆਧੁਨਿਕ C++ ਪ੍ਰੋਗਰਾਮਿੰਗ ਨੂੰ ਅਸਫਲਤਾਵਾਂ ਨੂੰ ਸੰਭਾਲਣ ਲਈ ਇੱਕ ਸਾਫ਼, ਵਧੇਰੇ ਪ੍ਰਭਾਵਸ਼ਾਲੀ ਤਰੀਕਾ ਪ੍ਰਦਾਨ ਕਰਦੀ ਹੈ।