[英]SystemStackError (stack level too deep)
我正在开发一个 android 应用程序,我需要对已保存的 object 的显示视图做出 json 响应。 尝试一下,我收到:
"SystemStackError (stack level too deep)"
app/controllers/segnalaziones_controller.rb:74:in `create'
app/controllers/segnalaziones_controller.rb:58:in `create'
这是“Segnalazione”controller
include Gft
class SegnalazionesController < ApplicationController
load_and_authorize_resource
respond_to :json
# GET /segnalaziones
# GET /segnalaziones.xml
# before_filter :authorize
def index
@segnalaziones = Segnalazione.order(:dataspedizione)
respond_to do |format|
format.html # index.html.erb
format.xml { render :xml => @segnalaziones }
format.json { render :json => @segnalaziones }
end
end
# GET /segnalaziones/1
# GET /segnalaziones/1.xml
def show
@segnalazione = Segnalazione.find(params[:id])
respond_to do |format|
format.html # show.html.erb
format.xml { render :xml => @segnalazione }
format.json { render :json => @segnalazione }
end
end
# GET /segnalaziones/new
# GET /segnalaziones/new.xml
def new
@segnalazione = Segnalazione.new
respond_to do |format|
format.html # new.html.erb
format.xml { render :xml => @segnalazione }
format.json { render :json => @segnalazione }
end
end
# GET /segnalaziones/1/edit
def edit
@segnalazione = Segnalazione.find(params[:id])
end
# POST /segnalaziones
# POST /segnalaziones.xml
def create
@segnalazione = Segnalazione.new(params[:segnalazione])
@user = User.find_by_id(session[:user_id])
@username = session[:user_name]
@segnalazione.user = session[:user_id]
@segnalazione.dataspedizione = Time.zone.now
@user.last_request_at = Time.zone.now
@user.save
respond_to do |format|
if @segnalazione.save
Gft.spedisci(
@segnalazione.id,
@username,
@segnalazione.mood,
@segnalazione.dove,
@segnalazione.via,
@segnalazione.dataspedizione,
@segnalazione.descrizione,
@segnalazione.immagine.url,
@segnalazione.categoria1,
@segnalazione.categoria2,
@segnalazione.categoria3)
format.html { redirect_to(@segnalazione, :notice => 'Segnalazione creata, verrà visualizzata su mappa fra qualche attimo') }
format.xml { render :xml => @segnalazione, :status => :created, :location => @segnalazione }
format.json { render :json => @segnalazione, :status => :created, :location => @segnalazione }
else
format.html { render :action => "new" }
format.xml { render :xml => @segnalazione.errors, :status => :unprocessable_entity }
format.json { render :json => @segnalazione.errors, :status => :unprocessable_entity }
end
end
end
# PUT /segnalaziones/1
# PUT /segnalaziones/1.xml
def update
@username = session[:user_name]
@segnalazione = Segnalazione.find(params[:id])
respond_to do |format|
if @segnalazione.update_attributes(params[:segnalazione])
Gft.aggiorna(
@segnalazione.id,
@username,
@segnalazione.mood,
@segnalazione.dove,
@segnalazione.via,
@segnalazione.dataspedizione,
@segnalazione.datarisoluzione,
@segnalazione.descrizione,
@segnalazione.immagine.url,
@segnalazione.categoria1,
@segnalazione.categoria2,
@segnalazione.categoria3)
format.html { redirect_to(@segnalazione, :notice => 'Segnalazione aggiornata') }
format.xml { head :ok }
else
format.html { render :action => "edit" }
format.xml { render :xml => @segnalazione.errors, :status => :unprocessable_entity }
end
end
end
# DELETE /segnalaziones/1
# DELETE /segnalaziones/1.xml
def destroy
@segnalazione = Segnalazione.find(params[:id])
@segnalazione.destroy
Gft.elimina(@segnalazione.id)
respond_to do |format|
format.html { redirect_to(admin_url) }
format.xml { head :ok }
end
end
def eliminadatarisoluzione
@segnalazione.datarisoluzione = nil
end
end
如果我“localhost:3000/segnalaziones/2?format=xml”,则会显示 xml。
如果我“localhost:3000/segnalaziones/2?format=json”我再次收到错误页面(堆栈级别太深......)
我试过这个解决方案,但不起作用:
http://dalibornasevic.com/posts/5-ruby-stack-level-too-deep-systemstackerror
解决方案:
代替:
format.json { render :json => @segnalazione, :status => :created, :location => @segnalazione }
我用过
format.json { render :json => @segnalazione.as_json(:only => [:user, :categoria1, :categoria2, :categoria3, :descrizione, :dove, :via]), :status => :created, :location => @segnalazione }
在这里找到帮助: http://jonathanjulian.com/2010/04/rails-to_json-or-as_json/
这就是堆栈溢出问题。 您可以在此处查看各种平台上的堆栈大小。
ulimit命令,它基本上提供对 shell 和由它启动的进程在允许此类控制的系统上可用的资源的控制。
您可以使用 'ulimit -a' 查看当前限制:
[mrblack@ /]# ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 15910
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 1024
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
而且,您可以使用“ulimit -s”命令更改堆栈大小。
ulimit -s 32768 # 设置栈大小为 32M 字节
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.