原子 *** 作对跨进程的共享内存有效吗?
答案是有的。
比如
在nginx里,我们都知道nginx是一个多进程的反向代理服务器,他的ngx_events_module里就有一些原子变量,比如ngx_connection_counter,在ngx_event_module_init函数里指向一块共享内存,是nginx的连接计数统计。
/// if (ngx_shm_alloc(&shm) != NGX_OK) { return NGX_ERROR; } shared = shm.addr; ngx_accept_mutex_ptr = (ngx_atomic_t *) shared; ngx_accept_mutex.spin = (ngx_uint_t) -1; if (ngx_shmtx_create(&ngx_accept_mutex, (ngx_shmtx_sh_t *) shared, cycle->lock_file.data) != NGX_OK) { return NGX_ERROR; } ngx_connection_counter = (ngx_atomic_t *) (shared + 1 * cl); (void) ngx_atomic_cmp_set(ngx_connection_counter, 0, 1); ///
这个连接计数当然是需要跨进程的了
使用时
ngx_atomic_fetch_add(ngx_connection_counter, 1);
可见他的用法上就是跨进程使用原子变量
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)