2014/11/20

boost::shared_ptr Assertion `px != 0' failed.

a.out: /usr/local/include/boost/smart_ptr/shared_ptr.hpp:653: typename boost::detail::sp_member_access<T>::type boost::shared_ptr<T>::operator->() const [with T = classA, typename boost::detail::sp_member_access<T>::type = classA*]: Assertion `px != 0' failed.


When this assertion comes to me, this is because assigned object to the shared_ptr is NULL.

See sample code below.




#include <boost/shared_ptr.hpp>
#include <iostream>

class classA{
private:
    int number_;
public:
    classA(){ number_ = 1;}
public:
    int number() { return number_; }
};

typedef boost::shared_ptr<classA> classA_Ptr;

void makeNull(){
    std::cout << "@sshtel @@@@@@@@@ start function" << std::endl;

    classA_Ptr ap1(new classA());
    std::cout << "@sshtel @@@@@@@@@ ap1:" << ap1->number() <<  std::endl;

    classA *ca = 0;
    classA_Ptr ap2(ca);
    std::cout << "@sshtel @@@@@@@@@ ap2:" << ap2->number() <<  std::endl;

    std::cout << "@sshtel @@@@@@@@@ end of function" << std::endl;
}

int main(){
    makeNull();
    return 0;
}

-----------------------------------------------------------------------------


sshtel@rnd4svr4:~/test/SharedPtr$ ./a.out
@sshtel @@@@@@@@@ start function
@sshtel @@@@@@@@@ ap1:1
a.out: /usr/local/include/boost/smart_ptr/shared_ptr.hpp:653: typename boost::detail::sp_member_access<T>::type boost::shared_ptr<T>::operator->() const [with T = classA, typename boost::detail::sp_member_access<T>::type = classA*]: Assertion `px != 0' failed.
Aborted
sshtel@rnd4svr4:~/test/SharedPtr$
-----------------------------------------------------------------------------



To avoid this dangerous situation, you should check memory result of object allocation every time.





boost::shared_ptr<CLASS> c_ptr;
CLASS *c;
try{
    c = new CLASS();
    c_ptr.reset(c);
}
catch(std::bad_alloc){
    // exception
}

2014/11/01

Ara project's prototype and new era




The Ara project is rising up.
Many people are not convinced about this project due to its limits such as size, price and market chain.
However, this is the only story in current smart phone industry.

There are a couple of reasons why I am really interested in this project.


First of all, the Ara project gives users and developers more freedom of choice.
While typical smart phone ecosystem has opened software-freedom to users and developers , this project will open a new era of ecosystem not only providing further freedom of software but also hardware to users and developers .

For example, it is hardly able to challenge that a tiny venture company enter smartphone market with a new hardware and software because the company should make whole necessary device which is harshly competing already.
If imagine that this project is successful, small ventures or even private developers can develop the modules freely and sell it on the market.

I goes further and say that the hardware module is not limited within typical well-known modules such as AP(Application Processor which consists of CPU, RAM, and Storage device), cameras, and batteries.

Look into the Apple app store or Google play store and count how many kinds of applications are on sale. And imagine a new era of hardware module store with well-optimized software.


Second, this can change typical industrial structure.
To be more specific, many small and middle-sized smart phone module makers provide modules to some big smartphone vendors such as Samsung, LG, Sony, and HTC.

In contrast, if this change comes true, those module makers do not need to do this anymore.
They just can make modules and sell their products on market directly.
Furthermore, it is well known that many big companies have required unfair price down contracts or rebates. So the module makers do not need to depend on major smart phone makers.