Имеет ли sqlnet.ora то же самое для всех экземпляров Oracle DB. Как вызвать два экземпляра оракула на одном компьютере

Параметры и локальные переменные выделяются в стеке (с ссылочными типами объект живет в куче, а переменная ссылается на этот объект). Стек обычно находится в верхнем конце вашего адресного пространства и, поскольку он используется, он направляется к нижней части адресного пространства (т.е. к нулю).

В вашем процессе также есть куча, которая живет в в нижней части вашего процесса. Когда вы выделяете память, эта куча может расти в верхнем конце вашего адресного пространства. Как вы можете видеть, существует вероятность того, что куча «столкнется» со стеклом (немного как тектонические пластины !!!).

Общей причиной переполнения стека является плохой рекурсивный вызов. Как правило, это вызвано тем, что у ваших рекурсивных функций нет правильного условия завершения, поэтому он навсегда называет себя.

Однако при программировании GUI можно создать непрямую рекурсию. Например, ваше приложение может обрабатывать сообщения с краской, а при их обработке оно может вызывать функцию, которая заставляет систему отправлять другое сообщение с краской. Здесь вы явно не называли себя, но OS / VM сделала это для вас.

Чтобы справиться с ними, вам нужно будет изучить свой код. Если у вас есть функции, которые называют себя, проверьте, что у вас есть условие завершения. Если у вас есть, то проверьте, что при вызове функции вы хотя бы модифицировали один из аргументов, иначе не будет видимых изменений для рекурсивно называемой функции, и условие завершения будет бесполезным.

Если вы у меня нет очевидных рекурсивных функций, затем проверьте, не вызываете ли вы какие-либо библиотечные функции, которые косвенно вызовут вашу функцию (например, неявный случай выше).

0
задан James Z 13 July 2018 в 21:10
поделиться