Hi Zhou, Please have a look at following thread. http://marc.info/?l=axis-c-user&m=118412516705780&w=2
Manjula. On Fri, 2008-01-04 at 17:59 -0500, Hehe Zhou wrote: > Hey, > > The following program will crash when the second thread starts up > [ _beginthread() in main() ]. A unhandled exception error is reported > and program crashes when 2nd thread starts to run ( 1st thread ends > already). This test program is just a multi-threaded version from Math > sample webservice client code of AXIS2. I just excute Math WS client > twice in different thread. But I don't have this problem if Math WS > Client is run in the same thread for two times. Any idea about this. I > checked out the newest AXIS2C code from SVN. Same problem happened. > > Platform: WinXP > Compilor: Visual Studio 2005 Professional > > // MathWSClient.cpp : Defines the entry point for the console > application. > > // > > #include > > "axis2_math_stub.h" > > #include > > <stdio.h> > > #include > > <axiom.h> > > #include > > <axis2_util.h> > > #include > > <axiom_soap.h> > > #include > > <axis2_client.h> > > #include > > <iostream> > > using > > namespace std; > > axiom_node_t * > > build_om_programatically( > > const axutil_env_t *env, > > const axis2_char_t *operation, > > const axis2_char_t *param1, > > const axis2_char_t *param2); > > void > > run(void* param) > > { > > axis2_stub_t *stub = NULL; > > axiom_node_t *node = NULL; > > axis2_status_t status = AXIS2_FAILURE; > > const axutil_env_t *env = NULL; > > const axis2_char_t *address = NULL; > > const axis2_char_t *client_home = NULL; > > axiom_node_t *ret_node = NULL; > > const axis2_char_t *operation = "add"; > > const axis2_char_t *param1 = "40"; > > const axis2_char_t *param2 = "8"; > > env = axutil_env_create_all( > > "math_blocking.log", AXIS2_LOG_LEVEL_TRACE); > > client_home = AXIS2_GETENV( > > "AXIS2C_HOME"); > > if (!client_home || !strcmp (client_home, "")) > > client_home = > > "../.."; > > address = > > "http://localhost:9090/axis2/services/math"; > > printf( > > "Using endpoint : %s\n", address); > > printf( > > "\nInvoking operation %s with params %s and %s\n", operation, param1, > param2); > > node = build_om_programatically(env, operation, param1, param2); > > stub = > > axis2_math_stub_create_with_endpoint_uri_and_client_home(env, address, > client_home); > > /* create node and invoke math */ > > if (stub) > > { > > ret_node = axis2_math_stub_add(stub, env, node); > > } > > if (ret_node) > > { > > if (axiom_node_get_node_type(ret_node, env) == AXIOM_ELEMENT) > > { > > axis2_char_t *result = NULL; > > axiom_element_t *result_ele = > (axiom_element_t*)axiom_node_get_data_element(ret_node, env); > > result = axiom_element_get_text(result_ele, env, ret_node); > > printf( > > "\nResult = %s\n", result); > > } > > else > > { > > axiom_xml_writer_t *writer = NULL; > > axiom_output_t *om_output = NULL; > > axis2_char_t *buffer = NULL; > > writer = axiom_xml_writer_create_for_memory(env, NULL, AXIS2_TRUE, 0, > > AXIS2_XML_PARSER_TYPE_BUFFER); > > om_output = axiom_output_create(env, writer); > > axiom_node_serialize(ret_node, env, om_output); > > buffer = (axis2_char_t*)axiom_xml_writer_get_xml(writer, env); > > printf( > > "\nReceived invalid OM as result : %s\n", buffer); > > if (buffer) > > { > > AXIS2_FREE(env->allocator, buffer); > > buffer = NULL; > > } > > if (om_output) > > { > > axiom_output_free(om_output, env); > > om_output = NULL; > > } > > axiom_xml_writer_free(writer, env); > > } > > } > > else > > { > > AXIS2_LOG_ERROR(env->log, AXIS2_LOG_SI, > > "Stub invoke FAILED: Error code:" > > " %d :: %s", env->error->error_number, > > AXIS2_ERROR_GET_MESSAGE(env->error)); > > printf( > > "math stub invoke FAILED!\n"); > > } > > if (stub) > > { > > axis2_stub_free(stub, env); > > } > > if (env) > > { > > axutil_env_free((axutil_env_t *) env); > > env = NULL; > > } > > _endthread(); > > } > > int > > main(int argc, char* argv[]) > > { > > _beginthread(run, 0, NULL); > > Sleep(5000); > > _beginthread(run, 0, NULL); > > Sleep(5000); > > return 0; > > } > > axiom_node_t * > > build_om_programatically( > > const axutil_env_t *env, > > const axis2_char_t *operation, > > const axis2_char_t *param1, > > const axis2_char_t *param2) > > { > > axiom_node_t *math_om_node = NULL; > > axiom_element_t* math_om_ele = NULL; > > axiom_node_t* text_om_node = NULL; > > axiom_element_t * text_om_ele = NULL; > > axiom_namespace_t *ns1 = NULL; > > > > axiom_xml_writer_t *xml_writer = NULL; > > axiom_output_t *om_output = NULL; > > axis2_char_t *buffer = NULL; > > ns1 = axiom_namespace_create(env, > > "http://ws.apache.org/axis2/services/math", "ns1"); > > math_om_ele = axiom_element_create(env, NULL, operation, ns1, > &math_om_node); > > text_om_ele = axiom_element_create(env, math_om_node, > > "param1", NULL, &text_om_node); > > axiom_element_set_text(text_om_ele, env, param1, text_om_node); > > text_om_ele = axiom_element_create(env, math_om_node, > > "param2", NULL, &text_om_node); > > axiom_element_set_text(text_om_ele, env, param2, text_om_node); > > xml_writer = axiom_xml_writer_create_for_memory(env, NULL, > AXIS2_FALSE, AXIS2_FALSE, > > AXIS2_XML_PARSER_TYPE_BUFFER); > > om_output = axiom_output_create(env, xml_writer); > > axiom_node_serialize(math_om_node, env, om_output); > > buffer = (axis2_char_t*)axiom_xml_writer_get_xml(xml_writer, env); > > AXIS2_LOG_DEBUG(env->log, AXIS2_LOG_SI, > > "\nSending OM node in XML : %s \n", buffer); > > if (om_output) > > { > > axiom_output_free(om_output, env); > > om_output = NULL; > > } > > return math_om_node; > > } > > > --------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]