线程的内存分配问题

public class Test {


    public static void main(String[] args) throws InterruptedException {
            //创建两个线程 分配堆内存空间 获取一个线程引用 
        ExecutorService executor=Executors.newFixedThreadPool(8);  

        WE we = new WE();

        we.setIw(1);

        executor.submit(new Clas(we));

        we.setIw(2);

        System.out.println("gg");

        executor.submit(new Clas(we));

        executor.shutdown();

        System.out.println(we.getIw());

    }
}


public class WE {
    private volatile Integer iw;


    public WE() {
        super();
    }

    public WE(Integer iw) {
        super();
        this.iw = iw;
    }
//线程类
public class Clas implements Runnable {

    private WE we;

    public Clas(WE we) {
        System.out.println("构造"+Thread.currentThread().getName()+"------"+we);
        this.we = we;
        System.out.println("构造this"+Thread.currentThread().getName()+"------"+this.we);

    }



    @Override
    public void run() {

    //查看对象变化        System.out.println(Thread.currentThread().getName()+"------"+we);
            System.out.println(Thread.currentThread().getName()+we.getIw());
            we.setIw(8);
    }

结果分析
这里写图片描述
我在主线程里面创建了两个线程,并且完成了构造,将一个对象的引用赋值到线程内部,当线程使用对象时全都是去堆内存取的数据,所以取的一个改变了值。

### Linux 环境下线程内存分配机制 在Linux环境中,线程作为轻量级进程存在,其内存分配主要依赖于操作系统的虚拟内存管理和特定API调用来实现。对于新创建的线程而言,内核会为其准备独立的栈空间用于存储局部变量、函数参数等数据结构;而对于共享资源,则允许不同线程间访问相同的地址空间。 #### 栈区分配 每当启动一个新的线程时,操作系统会给该线程分配一块固定大小的栈区[^3]。这块区域主要用于保存临时性的自动变量和返回地址等内容。通常情况下,默认栈尺寸由编译器或运行库设定,并可通过编程接口调整。例如,在POSIX标准下的`pthread_create()`函数中提供了选项来指定初始栈大小: ```c #include <pthread.h> // 创建具有自定义属性的新线程 int pthread_attr_init(pthread_attr_t *attr); int pthread_attr_setstacksize(pthread_attr_t *attr, size_t stacksize); pthread_attr_t attr; pthread_t thread; pthread_attr_init(&attr); // 初始化线程属性对象 pthread_attr_setstacksize(&attr, STACK_SIZE);// 设置期望的栈大小 pthread_create(&thread, &attr, start_routine, arg); // 使用定制化配置创建线程 ``` #### 堆区与匿名映射 除了固定的栈外,程序还可以动态请求额外的工作空间——即所谓的“堆”。在线程上下文中,“堆”的增长并非直接关联单个线程本身,而是整个进程中所有活动实体共同使用的全局资源池。值得注意的是,现代Linux系统倾向于采用基于mmap()系统调用的方法来进行大块连续内存片段的获取,特别是针对那些不需要立即绑定至实际物理页面的情况(如文件映射)。这种策略有助于提高效率并减少碎片化风险。 此外,某些特殊类型的内存分配可能涉及匿名页(anonymous pages),它们并不对应任何磁盘上的具体位置,而仅仅存在于RAM之中供即时读写操作之用。这类页面经常出现在通过malloc()/free()家族成员所获得的对象内部或是其他形式的手动映射过程中。 #### 内存保护措施 为了保障多线程应用程序的安全性和稳定性,Linux还引入了一系列防护手段防止越界访问或其他潜在威胁行为的发生。这其中包括但不限于设置不可执行位(No eXecute bit)阻止恶意代码注入攻击路径,以及利用硬件辅助特性实施细粒度权限控制等等[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值