⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 c_shm_merge.cpp

📁 HP共享内存实现,只要将sql语句配置好,装载共享内存即可
💻 CPP
📖 第 1 页 / 共 5 页
字号:
/***********************************************************************
* Module:  c_shm_merge.cpp
* Author:  Administrator
* Modified: 2005年9月15日 9:03:22
* Purpose: class c_shm_merge 
* Comment: 共享内存实时合帐类
***********************************************************************/

#include "c_shm_merge.h"

vector<MAIN_KEY_INFO> g_main_key;

int itemComp( const void *arg1, const void *arg2 )
{
   //return strcmp( ((SHM_MERGE_LIST*)arg1)->main, ((SHM_MERGE_LIST*)arg2)->main );
	int i,comp_value;
	for(i=0; i<g_main_key.size(); i++)
	{
		if( g_main_key[i].type == STRING_TYPE_D )
			comp_value = strcmp( &((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[i].pos]), &((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[i].pos]) );
		else
			comp_value = memcmp( &((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[i].pos]), &((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[i].pos]), g_main_key[i].size );

		//cout<<g_main_key[i].type<<"|"<<g_main_key[i].pos<<"|"<<g_main_key[i].size<<"|"<<comp_value<<"|"<<&((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[i].pos])<<"|"<<&((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[i].pos])<<"|"<<endl;
		if( comp_value != 0 )
			return comp_value;
	}
	return comp_value;
}

int listItemComp( const void *arg1, const void *arg2 )
{
   return ((ACCT_ITEM_FEE*)arg1)->key - ((ACCT_ITEM_FEE*)arg2)->key ;
}

bool lessByItemKey( const ACCT_ITEM_FEE& tmp1, const ACCT_ITEM_FEE& tmp2 )
{
	return tmp1.key < tmp2.key;
	/*char buf1[30], buf2[30];
	memcpy( buf1, &(tmp1.key), 4 );
	memcpy( buf2, &(tmp2.key), 4 );
	short int item_type1, item_type2, item_source1, item_source2;
	memcpy( &item_type1, &buf1[0], 2 );
	memcpy( &item_type2, &buf2[0], 2 );
	if( item_type1 != item_type2 )
	{
		return item_type1 < item_type2 ;
	}
	else
	{
		memcpy( &item_source1, &buf1[2], 2 );
		memcpy( &item_source2, &buf2[2], 2 );
		return item_source1 < item_source2 ;
	}*/
}

int serialComp( const void *arg1, const void *arg2 )
{
	return (*((int*)arg1)) - (*((int*)arg2)) ;
}

//比较serv_id和计费方式
int servComp( const void *arg1, const void *arg2 )
{
   //return strcmp( ((SHM_MERGE_LIST*)arg1)->main, ((SHM_MERGE_LIST*)arg2)->main );
	int comp_value;
	char buff1[20], buff2[20];
	memcpy( buff1, &((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[0].pos]), g_main_key[0].size );
	buff1[ g_main_key[0].size ] = '\0';
	memcpy( buff2, &((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[0].pos]), g_main_key[0].size );
	buff2[ g_main_key[0].size ] = '\0';
	comp_value = atoi(buff1) - atoi(buff2 );
	if( comp_value != 0 )
	{
		return comp_value;
	}
	else
	{
		memset(buff1,0, g_main_key[1].size);
		memset(buff2,0, g_main_key[1].size);
		memcpy( buff1, &((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[1].pos]), g_main_key[1].size );
		buff1[ g_main_key[1].size ] = '\0';
		memcpy( buff2, &((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[1].pos]), g_main_key[1].size );
		buff2[ g_main_key[1].size ] = '\0';
		comp_value = atoi(buff1) - atoi(buff2 );		
//cout<<buff1<<":"<<buff2<<":"<<comp_value<<endl;
		return comp_value;
	}
}

//add by renkm, 20060415, 只比较serv_id
int servNewComp( const void *arg1, const void *arg2 )
{
   //return strcmp( ((SHM_MERGE_LIST*)arg1)->main, ((SHM_MERGE_LIST*)arg2)->main );
	int comp_value;
	char buff1[20], buff2[20];
	memcpy( buff1, &((((SHM_MERGE_LIST*)arg1)->main)[g_main_key[0].pos]), g_main_key[0].size );
	buff1[ g_main_key[0].size ] = '\0';
	memcpy( buff2, &((((SHM_MERGE_LIST*)arg2)->main)[g_main_key[0].pos]), g_main_key[0].size );
	buff2[ g_main_key[0].size ] = '\0';
	comp_value = atoi(buff1) - atoi(buff2 );

	return comp_value;
}


////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::c_shm_merge()
// Purpose:		构造函数
// Return:     
////////////////////////////////////////////////////////////////////////
c_shm_merge::c_shm_merge()
{
	//p_share_info = new c_share_info();
	//p_share_info->loadAllInfo();

	int i;
	for ( i = 0 ; i < MAX_ITEM_COUNT ; i ++ )
	{
		p_merge_item[i] = new c_shm_merge_item( this );
	}
	p_merge_addition = new c_shm_merge_addition( this );

	v_main_key.reserve(10);
	v_item_key.reserve(10);
	v_item_seq.reserve(10);

	get_next_pos == -1;

	main_key_size = 0;
	
	max_addition_count = 0;

	p_find_charge_main = NULL;
	//cout<<"sizeof pthread_mutex_t:"<<sizeof(pthread_mutex_t)<<endl;

	i_item_seq=0;
	i_sort_seq=1;
	i_element_seq=0;
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::~c_shm_merge()
// Purpose:		析构函数
// Comment:		删除c_share_info对象
// Return:     
////////////////////////////////////////////////////////////////////////
c_shm_merge::~c_shm_merge()
{
	int i;
	for ( i = 0 ; i < MAX_ITEM_COUNT ; i ++ )
	{
		delete p_merge_item[i];
	}
	delete p_merge_addition;
	//delete p_share_info;
	return;
}

/*void c_shm_merge::init( char* mem_name )
{
	SHARE_MEM_INFO* tmp = p_share_info->getMemInfo( mem_name);
	if( tmp == NULL )
	{
		printf("不存在%s的共享内存\n", mem_name );fflush(stdout);
		exit(1);
	}
	c_shm newshm(tmp->share_area_id);
	newshm.getshm();
	c_shm_merge* newmem = newshm.get_mem(mem_name);	

	p_share_mem_info = newmem->p_share_mem_info;
	p_stShareInfo = newmem->p_stShareInfo;
	p_field_info = newmem->p_field_info;
	head_point = newmem->head_point;

	//生成锁
	append_mutex._mutex = newmem->append_mutex._mutex;
	record_count_mutex._mutex = newmem->record_count_mutex._mutex;
	v_update_mutex.clear();
	for( int i = 0 ; i < MAX_ITEM_COUNT ; i ++ )
	{
		c_mutex t_mutex;
		t_mutex._mutex = newmem->p_stShareInfo->update_lock[i];
		v_update_mutex.push_back( t_mutex );
	}
	append_key_mutex._mutex = newmem->append_key_mutex._mutex;
	

	getItemShm();

	//拷贝路径
	strcpy( file_path, newmem->file_path );

	strcpy( backup_dir, para.getChar( "shm", "ShmBackupDir") );
	max_backup_num = para.getInt( "shm", "MaxBackupNum" );
}*/

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::loadData()
// Purpose:     加载数据,继承类可以重写,在初始化后一次调用
// Return:     int 成功:0 失败:errMemDelete,errAppenElement
////////////////////////////////////////////////////////////////////////
int c_shm_merge::loadData(const int sql_seq)
{
	return 0;	
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::unloadData()
// Purpose:		卸载数据
// Comment:		修改标志,同时,将记录数修改为0
// Return:     int,成功:0,失败:errMemUnload
////////////////////////////////////////////////////////////////////////
int c_shm_merge::unloadData()
{
	return 0;
}

int c_shm_merge::appendElement(void* p_main, void* p_item_key, void* p_item)
{
	int mem_seq = getMergeItemSeq( p_main );
	v_update_mutex[mem_seq].enterMutex();
	int tmp = p_merge_item[mem_seq]->addRecord( p_main, p_item_key, p_item );
	v_update_mutex[mem_seq].leaveMutex();
	return tmp;
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::appendElement( void * p_element )
// Purpose:    Implementation of c_shm_merge::appendElement( void * p_element )
// Comment:    在原有数据的后面添加一条记录,同时把记录数加1。用锁。
// Return:     int,成功:0,失败errMemLimited
////////////////////////////////////////////////////////////////////////
int c_shm_merge::appendElement( void * p_element )
{
	char* p_point = ( char * ) p_element;
	
	//确定是在哪一个小块中
	//cout<<"main:"<<v_mem_field_info[v_main_key[0]].field_pos<<"\t"<<(char*)&p_point[v_mem_field_info[v_main_key[0]].field_pos]<<endl
	//	<<"key:"<<v_item_key[0]<<"\t"<<v_mem_field_info[v_item_key[0]].field_pos<<"\t"<<*(int*)&(p_point[v_mem_field_info[v_item_key[0]].field_pos])<<endl
	//	<<"item:"<<*(int*)&(p_point[v_mem_field_info[v_item_seq[0]].field_pos])<<endl;
	int mem_seq = getMergeItemSeq( &p_point[v_mem_field_info[v_main_key[1]].field_pos] );
	return p_merge_item[mem_seq]->addRecord( 
		&(p_point[v_mem_field_info[v_main_key[0]].field_pos]), 
		&(p_point[v_mem_field_info[v_item_key[0]].field_pos]), 
		&(p_point[v_mem_field_info[v_item_seq[0]].field_pos]) );
	//////////////////////只用一块
	//return p_merge_item[0]->addRecord( 
	//	&(p_point[v_mem_field_info[v_main_key[0]].field_pos]), 
	//	&(p_point[v_mem_field_info[v_item_key[0]].field_pos]), 
	//	&(p_point[v_mem_field_info[v_item_seq[0]].field_pos]) );
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::deleteElement(int seq)
// Purpose:    Implementation of c_shm_merge::deleteElement()
// Comment:    删除时做一个删除标记。
// Return:     int
////////////////////////////////////////////////////////////////////////
int c_shm_merge::deleteElement( int seq )
{
	return 0;
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::updateElement( int seq, void* element_value )
// Purpose:    Implementation of c_shm_merge::updateElement( int seq, void* element_value )
// Comment:    实时合帐类,修改记录时,直接修改数据。
// Return:     int
////////////////////////////////////////////////////////////////////////
int c_shm_merge::updateElement( int seq, void* element_value )
{
	return 0;
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::appendElement()
// Purpose:    Implementation of c_shm_merge::appendElement()
// Comment:    添加记录。
//				使用该函数,须先使用SetData,将记录内容添加到buff中,添加时,从buff中获取要修改的记录内容。
// Return:     int,成功:0,失败errMemLimited
////////////////////////////////////////////////////////////////////////
int c_shm_merge::appendElement()
{
	return appendElement(buff);
}

////////////////////////////////////////////////////////////////////////
// Name:       c_shm_merge::updateElement( int seq )
// Purpose:    Implementation of c_shm_merge::updateElement( int seq )
// Comment:    修改时, 不能修改关键字, 只能修改非关键字的部分。
//				使用该函数,须先使用SetData,将记录内容添加到buff中,更新时,从buff中获取要修改的记录内容。
// Return:     int,成功,0,失败:errNoDataSeq, errDataDelete, errChangeKeyValue
////////////////////////////////////////////////////////////////////////
int c_shm_merge::updateElement( int seq )
{
	return updateElement( seq, buff );
}

int c_shm_merge::SetData( int seq, void * buf_v )
{
	return c_shm_mem::SetData( seq, buf_v );
}

int c_shm_merge::getFieldValue(int seq, char* out_value)
{
	return c_shm_mem::getFieldValue(seq, out_value);
}

//初始化各个子块的指针
int c_shm_merge::createItemShm()
{
	//计算item_size;
	item_size = p_share_mem_info->mem_size - SHM_ITEM_SIZE * MAX_ITEM_COUNT ;
	if ( item_size < 0 )
	{
		cout<<"块大小"<<p_share_mem_info->mem_size<<"小于"<<MAX_SERIAL_COUNT*12 + SHM_ITEM_SIZE*MAX_ITEM_COUNT<<",不足分配!"<<endl;
		exit(1);
	}	
	
	int i = 0;
	//int* count;
	////////////////////用多块的情况
	p_serial_list = (int*)head_point;
	p_serial_list[1] = 0;
	p_serial_list[0] = 0;

	//p_shm_mem_load->addition_point = &(p_shm_mem_load->head_point[p_shm_mem_load->p_share_mem_info->mem_size-p_shm_mem_load->p_share_mem_info->addition_size]);
			
	SHM_MERGE_INFO t;
	for( i = 0 ; i < MAX_ITEM_COUNT ; i ++ )
	{	
		p_merge_item[i]->p_merge_info =(SHM_MERGE_INFO*)(head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE*i);
		p_merge_item[i]->p_merge_info->add_record_count = 0;
		p_merge_item[i]->p_merge_info->record_count = 0;
		p_merge_item[i]->p_merge_info->sort_count = 0;
		p_merge_item[i]->p_merge_info->unsort_find_count = 0;
		p_merge_item[i]->head_point = head_point + MAX_SERIAL_COUNT*4+ SHM_ITEM_SIZE*i + ITEM_HEAD_COUNT ;
		p_merge_item[i]->add_head_point = head_point + MAX_SERIAL_COUNT*4 +SHM_ITEM_SIZE*(i+1) - SHM_ITEM_ADD;
		p_merge_item[i]->p_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->head_point;
		p_merge_item[i]->p_add_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->add_head_point;		
		
	}
	p_merge_addition->p_merge_info = (SHM_MERGE_INFO*)(&head_point[MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE*MAX_ITEM_COUNT] );
	p_merge_addition->p_merge_info->record_count = 0;
	p_merge_addition->p_merge_info->add_record_count = 0;
	p_merge_addition->p_merge_info->sort_count = 0;
	p_merge_addition->p_merge_info->unsort_find_count = 0;
	p_merge_addition->head_point = &head_point[MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE*MAX_ITEM_COUNT + ITEM_HEAD_COUNT];
	p_merge_addition->p_merge_list_item = (SHM_MERGE_LIST_ITEM*) p_merge_addition->head_point;
	

	/*
	////////////////////只用一块的情况
	p_merge_item[0]->p_merge_info = (SHM_MERGE_INFO*)head_point;
	p_merge_item[0]->p_merge_info->add_record_count = 0;
	p_merge_item[0]->p_merge_info->record_count = 0;
	p_merge_item[0]->head_point = (char*)head_point + ITEM_HEAD_COUNT ;
	p_merge_item[0]->add_head_point = (char*)head_point + SINGLE_SHM_ITEM_SIZE - SHM_ITEM_ADD ;
	p_merge_item[0]->p_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->head_point;
	p_merge_item[0]->p_add_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->add_head_point;	
	
	p_merge_addition->p_merge_info = (SHM_MERGE_INFO*)(head_point + SINGLE_SHM_ITEM_SIZE );
	p_merge_addition->p_merge_info->record_count = 0;
	p_merge_addition->head_point = head_point + SINGLE_SHM_ITEM_SIZE + ITEM_HEAD_COUNT ;
	p_merge_addition->p_merge_list_item = (SHM_MERGE_LIST_ITEM*) p_merge_addition->head_point;
*/
	return 0;
}

int c_shm_merge::getItemShm()
{
	item_size = p_share_mem_info->mem_size - SHM_ITEM_SIZE * MAX_ITEM_COUNT ;
	if ( item_size < 0 )
	{
		cout<<"块大小小于"<<SHM_ITEM_SIZE * MAX_ITEM_COUNT<<"K,不足分配!"<<endl;
		exit(1);
	}	
	
	int i = 0;

	////////////////////用多块的情况
	p_serial_list = (int*)head_point;
	
	for( i = 0 ; i < MAX_ITEM_COUNT ; i ++ )
	{
		p_merge_item[i]->p_merge_info = (SHM_MERGE_INFO*) (head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * i );
		p_merge_item[i]->head_point = head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * i + ITEM_HEAD_COUNT ;
		p_merge_item[i]->add_head_point = head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * (i + 1) - SHM_ITEM_ADD ;
		p_merge_item[i]->p_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->head_point;
		p_merge_item[i]->p_add_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->add_head_point;
		p_merge_item[i]->m_p_shm_merge_addition = p_merge_addition;
	}
	p_merge_addition->p_merge_info = (SHM_MERGE_INFO*)(head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * MAX_ITEM_COUNT );
	p_merge_addition->head_point = head_point + MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * MAX_ITEM_COUNT + ITEM_HEAD_COUNT ;
	p_merge_addition->p_merge_list_item = (SHM_MERGE_LIST_ITEM*) p_merge_addition->head_point;
	max_addition_count = (p_share_mem_info->mem_size - MAX_SERIAL_COUNT*4 + SHM_ITEM_SIZE * MAX_ITEM_COUNT + ITEM_HEAD_COUNT - 10000)/4;
	/*
	////////////////////只用一块的情况
	p_merge_item[0]->p_merge_info = (SHM_MERGE_INFO*) (head_point + SINGLE_SHM_ITEM_SIZE * 0 );
	p_merge_item[0]->head_point = head_point + SINGLE_SHM_ITEM_SIZE * 0 + ITEM_HEAD_COUNT ;
	p_merge_item[0]->add_head_point = head_point + SINGLE_SHM_ITEM_SIZE * (0 + 1) - SHM_ITEM_ADD ;
	p_merge_item[0]->p_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->head_point;
	p_merge_item[0]->p_add_merge_list = (SHM_MERGE_LIST*) p_merge_item[i]->add_head_point;
	p_merge_item[0]->m_p_shm_merge_addition = p_merge_addition;
	p_merge_addition->p_merge_info = (SHM_MERGE_INFO*)(head_point + SINGLE_SHM_ITEM_SIZE );
	p_merge_addition->head_point = head_point + SINGLE_SHM_ITEM_SIZE + ITEM_HEAD_COUNT ;
	p_merge_addition->p_merge_list_item = (SHM_MERGE_LIST_ITEM*) p_merge_addition->head_point;
	*/
	return 0;
}

int c_shm_merge::setMainKey( const int field_seq )
{
	v_main_key.push_back( field_seq );
	MAIN_KEY_INFO temp;
	int i;
	int pos = 0;
	for(i=0; i<g_main_key.size(); i++)
		pos+=g_main_key[i].size;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -